///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2021- 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 "RimcSurface.h" #include "RimCase.h" #include "RimSurface.h" #include "RimcDataContainerString.h" #include "RigSurface.h" #include "RifSurfaceExporter.h" #include "cafPdmFieldScriptingCapability.h" #include "cafPdmObjectScriptingCapability.h" #include CAF_PDM_OBJECT_METHOD_SOURCE_INIT( RimSurface, RimcSurface_exportToFile, "ExportToFile" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimcSurface_exportToFile::RimcSurface_exportToFile( caf::PdmObjectHandle* self ) : caf::PdmObjectMethod( self ) { CAF_PDM_InitObject( "Export Surface To fiole", "", "", "Export a surface to file" ); CAF_PDM_InitScriptableFieldNoDefault( &m_fileName, "FileName", "", "", "", "Filename to export surface to" ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- caf::PdmObjectHandle* RimcSurface_exportToFile::execute() { RimSurface* surface = self(); auto dataObject = new RimcDataContainerString(); if ( surface ) { RigSurface* surfaceData = surface->surfaceData(); RifSurfaceExporter::writeGocadTSurfFile( m_fileName(), surface->userDescription(), surfaceData->vertices(), surfaceData->triangleIndices() ); dataObject->m_stringValues = { m_fileName() }; } return dataObject; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimcSurface_exportToFile::resultIsPersistent() const { return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::unique_ptr RimcSurface_exportToFile::defaultResult() const { return std::unique_ptr( new RimcDataContainerString() ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimcSurface_exportToFile::isNullptrValidResult() const { return true; }