///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017 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. // ///////////////////////////////////////////////////////////////////////////////// #include "RimSummaryCalculationCollection.h" #include "RimCalculatedSummaryCase.h" #include "RimSummaryCalculation.h" #include "cafPdmUiGroup.h" #include "cafPdmUiTreeSelectionEditor.h" CAF_PDM_SOURCE_INIT(RimSummaryCalculationCollection, "RimSummaryCalculationCollection"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCalculationCollection::RimSummaryCalculationCollection() { CAF_PDM_InitObject("Calculation Collection", ":/chain.png", "", ""); CAF_PDM_InitFieldNoDefault(&m_calcuations, "Calculations", "Calculations", "", "", ""); m_calcuations.uiCapability()->setUiEditorTypeName(caf::PdmUiTreeSelectionEditor::uiEditorTypeName()); CAF_PDM_InitFieldNoDefault(&m_calcuationSummaryCase, "CalculationsSummaryCase", "Calculations Summary Case", "", "", ""); m_calcuationSummaryCase.xmlCapability()->disableIO(); m_calcuationSummaryCase = new RimCalculatedSummaryCase; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCalculation* RimSummaryCalculationCollection::addCalculation() { RimSummaryCalculation* calculation = new RimSummaryCalculation; QString varName = QString("Calculation_%1").arg(m_calcuations.size() + 1); calculation->setDescription(varName); calculation->setExpression(varName + " := x + y"); calculation->parseExpression(); m_calcuations.push_back(calculation); rebuildCaseMetaData(); return calculation; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCalculation* RimSummaryCalculationCollection::addCalculationCopy(const RimSummaryCalculation* sourceCalculation) { RimSummaryCalculation* calcCopy = dynamic_cast( sourceCalculation->xmlCapability()->copyByXmlSerialization(caf::PdmDefaultObjectFactory::instance())); CVF_ASSERT(calcCopy); std::set calcNames; for (const auto& calc : m_calcuations) { calcNames.insert(calc->findLeftHandSide(calc->expression())); } QString expression = calcCopy->expression(); QString currVarName = calcCopy->findLeftHandSide(expression); QString newVarName = currVarName; while (calcNames.count(newVarName) > 0) { newVarName += "_copy"; } expression.replace(currVarName, newVarName); calcCopy->setExpression(expression); m_calcuations.push_back(calcCopy); calcCopy->resolveReferencesRecursively(); rebuildCaseMetaData(); calcCopy->parseExpression(); return calcCopy; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimSummaryCalculationCollection::deleteCalculation(RimSummaryCalculation* calculation) { m_calcuations.removeChildObject(calculation); rebuildCaseMetaData(); delete calculation; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RimSummaryCalculationCollection::calculations() const { return m_calcuations.childObjects(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCase* RimSummaryCalculationCollection::calculationSummaryCase() { return m_calcuationSummaryCase(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimSummaryCalculationCollection::deleteAllContainedObjects() { m_calcuations.deleteAllChildObjects(); rebuildCaseMetaData(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimSummaryCalculationCollection::rebuildCaseMetaData() { m_calcuationSummaryCase->buildMetaData(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimSummaryCalculationCollection::initAfterRead() { rebuildCaseMetaData(); }