///////////////////////////////////////////////////////////////////////////////// // // 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 "cvfBase.h" #include "cvfObject.h" #include "cvfCollection.h" #include "RiaEclipseUnitTools.h" #include "RifReaderInterface.h" #include "RigFault.h" #include "ert/ecl/ecl_kw.h" #include #include class RigEclipseCaseData; class QFile; //-------------------------------------------------------------------------------------------------- /// Structure used to cache file position of keywords //-------------------------------------------------------------------------------------------------- struct RifKeywordAndFilePos { QString keyword; qint64 filePos; }; //================================================================================================== // // Class for access to Eclipse "keyword" files using libecl // //================================================================================================== class RifEclipseInputFileTools : public cvf::Object { public: RifEclipseInputFileTools(); ~RifEclipseInputFileTools() override; static bool openGridFile(const QString& fileName, RigEclipseCaseData* eclipseCase, bool readFaultData, QString* errorMessages); static bool exportGrid(const QString& gridFileName, RigEclipseCaseData* eclipseCase, bool exportInLocalCoordinates, const cvf::UByteArray* cellVisibilityOverrideForActnum = nullptr, const cvf::Vec3st& min = cvf::Vec3st::ZERO, const cvf::Vec3st& max = cvf::Vec3st::UNDEFINED, const cvf::Vec3st& refinement = cvf::Vec3st(1, 1, 1)); static bool exportKeywords(const QString& resultFileName, RigEclipseCaseData* eclipseCase, const std::vector& keywords, const QString& fileWriteMode, const cvf::Vec3st& min = cvf::Vec3st::ZERO, const cvf::Vec3st& max = cvf::Vec3st::UNDEFINED, const cvf::Vec3st& refinement = cvf::Vec3st(1, 1, 1)); static void saveFault(QString completeFilename, const RigMainGrid* mainGrid, const std::vector& faultFaces, QString faultName, const cvf::Vec3st& min = cvf::Vec3st::ZERO, const cvf::Vec3st& max = cvf::Vec3st::UNDEFINED, const cvf::Vec3st& refinement = cvf::Vec3st(1, 1, 1)); static void saveFault(QTextStream& stream, const RigMainGrid* mainGrid, const std::vector& faultFaces, QString faultName, const cvf::Vec3st& min = cvf::Vec3st::ZERO, const cvf::Vec3st& max = cvf::Vec3st::UNDEFINED, const cvf::Vec3st& refinement = cvf::Vec3st(1, 1, 1)); static void saveFaults(QTextStream& stream, const RigMainGrid* mainGrid, const cvf::Vec3st& min = cvf::Vec3st::ZERO, const cvf::Vec3st& max = cvf::Vec3st::UNDEFINED, const cvf::Vec3st& refinement = cvf::Vec3st(1, 1, 1)); // Returns map of assigned resultName and Eclipse Keyword. static std::map readProperties(const QString& fileName, RigEclipseCaseData* eclipseCase); static bool readProperty (const QString& fileName, RigEclipseCaseData* eclipseCase, const QString& eclipseKeyWord, const QString& resultName ); static void readFaultsInGridSection(const QString& fileName, cvf::Collection* faults, std::vector* filenamesWithFaults, const QString& faultIncludeFileAbsolutePathPrefix); static void readFaults(const QString& fileName, const std::vector< RifKeywordAndFilePos >& fileKeywords, cvf::Collection* faults); static void parseAndReadFaults(const QString& fileName, cvf::Collection* faults); static void readFaults(QFile &data, qint64 filePos, cvf::Collection* faults, bool* isEditKeywordDetected); static void findKeywordsOnFile(const QString &fileName, std::vector< RifKeywordAndFilePos >* keywords); static void parseAndReadPathAliasKeyword(const QString &fileName, std::vector< std::pair >* pathAliasDefinitions); static bool readFaultsAndParseIncludeStatementsRecursively( QFile& file, qint64 startPos, const std::vector< std::pair >& pathAliasDefinitions, cvf::Collection* faults, std::vector* filenamesWithFaults, bool* isEditKeywordDetected, const QString& faultIncludeFileAbsolutePathPrefix); static bool readKeywordAndParseIncludeStatementsRecursively(const QString& keyword, const QString& keywordToStopParsing, QFile& file, qint64 startPos, const std::vector< std::pair >& pathAliasDefinitions, QStringList* keywordDataContent, std::vector* filenamesContainingKeyword, bool* isEditKeywordDetected, const QString& faultIncludeFileAbsolutePathPrefix // rename to includeStatementAbsolutePathPrefix ); static void readKeywordDataContent(QFile &data, qint64 filePos, QStringList* textContent, bool* isEditKeywordDetected); static RiaEclipseUnitTools::UnitSystem readUnitSystem(QFile& file, qint64 gridunitPos); static cvf::StructGridInterface::FaceEnum faceEnumFromText(const QString& faceString); private: static bool readDataFromKeyword(ecl_kw_type* eclipseKeywordData, RigEclipseCaseData* caseData, const QString& resultName, QString* errMsg); static void findGridKeywordPositions(const std::vector< RifKeywordAndFilePos >& keywords, qint64* coordPos, qint64* zcornPos, qint64* specgridPos, qint64* actnumPos, qint64* mapaxesPos, qint64* gridunitPos); static size_t findFaultByName(const cvf::Collection& faults, const QString& name); static qint64 findKeyword(const QString& keyword, QFile& file, qint64 startPos); static bool isValidDataKeyword(const QString& keyword); static void writeFaultLine(QTextStream& stream, QString faultName, size_t i, size_t j, size_t startK, size_t endK, cvf::StructGridInterface::FaceType faceType); static QString faultFaceText(cvf::StructGridInterface::FaceType faceType); private: static const std::vector& invalidPropertyDataKeywords(); };