///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2019- Equinor 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 "RimObservedFmuRftData.h" //================================================================================================== // // // //================================================================================================== CAF_PDM_SOURCE_INIT( RimObservedFmuRftData, "ObservedFmuRftData" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimObservedFmuRftData::RimObservedFmuRftData() { CAF_PDM_InitObject( "Observed FMU Data", ":/ObservedRFTDataFile16x16.png" ); CAF_PDM_InitFieldNoDefault( &m_directoryPath, "Directory", "Directory" ); m_directoryPath.uiCapability()->setUiReadOnly( true ); CAF_PDM_InitFieldNoDefault( &m_wells, "Wells", "Wells" ); m_wells.xmlCapability()->disableIO(); m_wells.uiCapability()->setUiReadOnly( true ); m_wells.registerGetMethod( this, &RimObservedFmuRftData::wells ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimObservedFmuRftData::setDirectoryPath( const QString& path ) { m_directoryPath = path; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimObservedFmuRftData::createRftReaderInterface() { m_fmuRftReader = new RifReaderFmuRft( m_directoryPath ); m_fmuRftReader->load(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RifReaderRftInterface* RimObservedFmuRftData::rftReader() { if ( m_fmuRftReader.isNull() ) { createRftReaderInterface(); } return m_fmuRftReader.p(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimObservedFmuRftData::hasWell( const QString& wellPathName ) const { std::vector allWells = wells(); for ( const QString& well : allWells ) { if ( well == wellPathName ) { return true; } } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RimObservedFmuRftData::wells() const { if ( m_fmuRftReader.p() ) { std::set wellNames = const_cast( m_fmuRftReader.p() )->wellNames(); return std::vector( wellNames.begin(), wellNames.end() ); } return std::vector(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RimObservedFmuRftData::labels( const RifEclipseRftAddress& rftAddress ) { if ( m_fmuRftReader.p() ) { return const_cast( m_fmuRftReader.p() )->labels( rftAddress ); } return {}; }