///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2016- Statoil ASA // // 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 "cafPdmChildArrayField.h" #include "cafPdmObject.h" #include "cafSignal.h" #include #include class RimGridSummaryCase; class RimSummaryCase; class RimFileSummaryCase; class RimEclipseResultCase; class RimSummaryCaseCollection; class RifSummaryCaseFileResultInfo; //================================================================================================== /// //================================================================================================== class RimSummaryCaseMainCollection : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: caf::Signal<> dataSourceHasChanged; public: RimSummaryCaseMainCollection(); ~RimSummaryCaseMainCollection() override; RimSummaryCase* summaryCase( size_t idx ); size_t summaryCaseCount() const; std::vector allSummaryCases() const; std::vector topLevelSummaryCases() const; std::vector summaryCaseCollections() const; std::vector createSummaryCasesFromFileInfos( const std::vector& summaryHeaderFileInfos, bool showProgress = false ); RimSummaryCase* findSummaryCaseFromEclipseResultCase( const RimEclipseResultCase* eclResCase ) const; RimSummaryCase* findSummaryCaseFromFileName( const QString& fileName ) const; void convertGridSummaryCasesToFileSummaryCases( RimGridSummaryCase* gridSummaryCase ); void addCases( const std::vector cases ); void addCase( RimSummaryCase* summaryCase ); void removeCase( RimSummaryCase* summaryCase, bool notifyChange = true ); void removeCases( std::vector& cases ); RimSummaryCaseCollection* addCaseCollection( std::vector summaryCases, const QString& coolectionName, bool isEnsemble, std::function allocator = defaultAllocator ); void removeCaseCollection( RimSummaryCaseCollection* caseCollection ); void loadAllSummaryCaseData(); QString uniqueShortNameForCase( RimSummaryCase* summaryCase ); void updateAutoShortName(); void onProjectBeingSaved(); private: void initAfterRead() override; static void loadSummaryCaseData( std::vector summaryCases ); static void loadFileSummaryCaseData( std::vector fileSummaryCases ); static void reassignSummaryCurves( const RimGridSummaryCase* fromGridCase, RimFileSummaryCase* toFileCase ); static RimSummaryCaseCollection* defaultAllocator(); void onCaseNameChanged( const SignalEmitter* emitter ); private: caf::PdmChildArrayField m_cases; caf::PdmChildArrayField m_caseCollections; };