///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RiaDefines.h" #include "cvfObject.h" #include #include class RigStimPlanFractureDefinition; class QXmlStreamReader; class QStringRef; class RifStimPlanXmlReader { public: enum class MirrorMode { MIRROR_OFF = 0, MIRROR_ON = 1, MIRROR_AUTO = 2 }; static cvf::ref readStimPlanXMLFile( const QString& stimPlanFileName, double conductivityScalingFactor, MirrorMode mirrorMode, RiaDefines::EclipseUnitSystem requiredUnit, QString* errorMessage ); private: static void readStimplanGridAndTimesteps( QXmlStreamReader& xmlStream, RigStimPlanFractureDefinition* stimPlanFileData, MirrorMode mirrorMode, RiaDefines::EclipseUnitSystem requiredUnit ); static double getAttributeValueDouble( QXmlStreamReader& xmlStream, const QString& parameterName ); static QString getAttributeValueString( QXmlStreamReader& xmlStream, const QString& parameterName ); static void getGriddingValues( QXmlStreamReader& xmlStream, std::vector& gridValues, size_t& startNegValues ); static std::vector> getAllDepthDataAtTimeStep( QXmlStreamReader& xmlStream ); static std::vector valuesInRequiredUnitSystem( RiaDefines::EclipseUnitSystem sourceUnit, RiaDefines::EclipseUnitSystem requiredUnit, const std::vector& values ); static double valueInRequiredUnitSystem( RiaDefines::EclipseUnitSystem sourceUnit, RiaDefines::EclipseUnitSystem requiredUnit, double value ); static bool isTextEqual( const QStringRef& text, const QString& compareText ); };