///////////////////////////////////////////////////////////////////////////////// // // 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 "RimObservedEclipseUserData.h" #include "RiaLogging.h" #include "RifColumnBasedUserData.h" #include "RifColumnBasedUserDataParser.h" #include "RifKeywordVectorParser.h" #include "RifKeywordVectorUserData.h" #include "RifSummaryReaderInterface.h" #include "cafUtils.h" #include CAF_PDM_SOURCE_INIT( RimObservedEclipseUserData, "RimObservedEclipseUserData" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimObservedEclipseUserData::RimObservedEclipseUserData() { CAF_PDM_InitObject( "Observed RSMSPEC Column Based Data File", ":/ObservedRSMDataFile16x16.png", "", "" ); m_summaryHeaderFilename.uiCapability()->setUiName( "File" ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimObservedEclipseUserData::~RimObservedEclipseUserData() { } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimObservedEclipseUserData::createSummaryReaderInterface() { m_summeryReader = nullptr; if ( caf::Utils::fileExists( this->summaryHeaderFilename() ) ) { QFile file( this->summaryHeaderFilename() ); if ( !file.open( QIODevice::ReadOnly | QIODevice::Text ) ) { RiaLogging::error( QString( "Failed to open %1" ).arg( this->summaryHeaderFilename() ) ); return; } QTextStream in( &file ); QString fileContents = in.readAll(); fileContents.replace( "\t", " " ); if ( RifKeywordVectorParser::canBeParsed( fileContents ) ) { RifKeywordVectorUserData* keywordVectorUserData = new RifKeywordVectorUserData(); if ( keywordVectorUserData->parse( fileContents, customWellName() ) ) { m_summeryReader = keywordVectorUserData; } } else { RifColumnBasedUserData* columnBaseUserData = new RifColumnBasedUserData(); if ( columnBaseUserData->parse( fileContents, &m_errorText ) ) { m_summeryReader = columnBaseUserData; } } } else { m_summeryReader = nullptr; } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RifSummaryReaderInterface* RimObservedEclipseUserData::summaryReader() { if ( m_summeryReader.isNull() ) { createSummaryReaderInterface(); } return m_summeryReader.p(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RimObservedEclipseUserData::errorMessagesFromReader() { return m_errorText; }