///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2011- Statoil ASA // Copyright (C) 2013- Ceetron Solutions AS // Copyright (C) 2011-2012 Ceetron AS // // ResInsight is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. // // See the GNU General Public License at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RiaDefines.h" #include "RiaEclipseUnitTools.h" #include "cafPdmChildArrayField.h" #include "cafPdmChildField.h" #include "cafPdmDocument.h" #include "cvfCollection.h" #include class RigEclipseCaseData; class RigGridManager; class RigMainGrid; class RigWellPath; class RimTextAnnotation; class RimReachCircleAnnotation; class RimPolylinesAnnotation; class RimSummaryCalculationCollection; class RimCase; class RimCommandObject; class RimDialogData; class RimEclipseCase; class RimGeoMechCase; class RimIdenticalGridCaseGroup; class RimMainPlotCollection; class RimMultiSnapshotDefinition; class RimObservedData; class RimOilField; class RimScriptCollection; class RimSummaryCase; class RimSummaryCaseCollection; class RimSummaryCaseMainCollection; class Rim3dView; class RimGridView; class RimViewLinker; class RimViewLinkerCollection; class RimWellPath; class RimWellPathImport; class RimFractureTemplateCollection; class RimFractureTemplate; namespace caf { class PdmUiTreeOrdering; } class QAction; class QMenu; //================================================================================================== /// /// //================================================================================================== class RimProject : public caf::PdmDocument { CAF_PDM_HEADER_INIT; public: RimProject(void); ~RimProject(void) override; caf::PdmChildArrayField oilFields; caf::PdmChildField scriptCollection; caf::PdmChildField wellPathImport; caf::PdmChildField mainPlotCollection; caf::PdmChildField viewLinkerCollection; caf::PdmChildField calculationCollection; caf::PdmChildArrayField commandObjects; caf::PdmChildArrayField multiSnapshotDefinitions; caf::PdmField mainWindowTreeViewState; caf::PdmField mainWindowCurrentModelIndexPath; caf::PdmField plotWindowTreeViewState; caf::PdmField plotWindowCurrentModelIndexPath; void setScriptDirectories(const QString& scriptDirectories); QString projectFileVersionString() const; bool isProjectFileVersionEqualOrOlderThan(const QString& otherProjectFileVersion) const; void close(); void setProjectFileNameAndUpdateDependencies(const QString& projectFileName); void assignCaseIdToCase(RimCase* reservoirCase); void assignIdToCaseGroup(RimIdenticalGridCaseGroup* caseGroup); void allCases(std::vector& cases) const; std::vector allSummaryCases() const; std::vector summaryGroups() const; RimSummaryCaseMainCollection* firstSummaryCaseMainCollection() const; void allVisibleViews(std::vector& views) const; void allVisibleGridViews(std::vector& views) const; void allNotLinkedViews(std::vector& views); void scheduleCreateDisplayModelAndRedrawAllViews(); void computeUtmAreaOfInterest(); void allOilFields(std::vector& allOilFields) const; RimOilField* activeOilField(); const RimOilField* activeOilField() const; void actionsBasedOnSelection(QMenu& contextMenu); bool show3DWindow() const; bool showPlotWindow() const; void reloadCompletionTypeResultsInAllViews(); void reloadCompletionTypeResultsForEclipseCase(RimEclipseCase* eclipseCase); RimDialogData* dialogData() const; std::vector eclipseCases() const; RimEclipseCase* eclipseCaseFromGridFileName(const QString& gridFileName) const; std::vector simulationWellNames() const; RimWellPath* wellPathFromSimWellName(const QString& simWellName, int branchIndex = -1); RimWellPath* wellPathByName(const QString& wellPathName) const; std::vector allWellPaths() const; std::vector textAnnotations() const; std::vector reachCircleAnnotations() const; std::vector polylineAnnotations() const; std::vector geoMechCases() const; std::vector allFractureTemplateCollections() const; std::vector allFractureTemplates() const; RiaEclipseUnitTools::UnitSystemType commonUnitSystemForAllCases() const; protected: // Overridden methods void initScriptDirectories(); void initAfterRead() override; void setupBeforeSave() override; void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "") override; private: template void fieldContentsByType(caf::PdmObjectHandle* object, std::vector& typedFields); private: caf::PdmField m_projectFileVersionString; caf::PdmChildField m_dialogData; caf::PdmField m_show3DWindow; caf::PdmField m_showPlotWindow; caf::PdmField nextValidCaseId; // Unique case ID within a project, used to identify a case from Octave scripts caf::PdmField nextValidCaseGroupId; // Unique case group ID within a project, used to identify a case group from Octave scripts caf::PdmChildArrayField casesObsolete; // obsolete caf::PdmChildArrayField caseGroupsObsolete; // obsolete }; //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- template void RimProject::fieldContentsByType(caf::PdmObjectHandle* object, std::vector& typedFields) { if (!object) return; std::vector allFieldsInObject; object->fields(allFieldsInObject); std::vector children; for (const auto& field : allFieldsInObject) { caf::PdmField* typedField = dynamic_cast*>(field); if (typedField) typedFields.push_back(&typedField->v()); caf::PdmField< std::vector >* typedFieldInVector = dynamic_cast >*>(field); if (typedFieldInVector) { for (T& typedFieldFromVector : typedFieldInVector->v()) { typedFields.push_back(&typedFieldFromVector); } } field->childObjects(&children); } for (const auto& child : children) { fieldContentsByType(child, typedFields); } }