2017-07-26 09:41:17 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2017 Statoil ASA
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
2017-07-26 09:41:17 -05:00
|
|
|
// 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.
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
2017-07-26 09:41:17 -05:00
|
|
|
// 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.
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
|
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
2017-07-26 09:41:17 -05:00
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "RicfCommandFileExecutor.h"
|
|
|
|
|
2017-07-27 07:26:59 -05:00
|
|
|
#include "RiaLogging.h"
|
|
|
|
|
2018-02-05 01:47:10 -06:00
|
|
|
#include "RicfCloseProject.h"
|
|
|
|
#include "RicfCommandObject.h"
|
|
|
|
#include "RicfOpenProject.h"
|
|
|
|
#include "RicfReplaceCase.h"
|
|
|
|
#include "RifcCommandFileReader.h"
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
namespace caf
|
|
|
|
{
|
|
|
|
template <>
|
|
|
|
void RicfCommandFileExecutor::ExportTypeEnum::setUp()
|
|
|
|
{
|
|
|
|
addItem( RicfCommandFileExecutor::COMPLETIONS, "COMPLETIONS", "Completions" );
|
|
|
|
addItem( RicfCommandFileExecutor::PROPERTIES, "PROPERTIES", "Properties" );
|
|
|
|
addItem( RicfCommandFileExecutor::SNAPSHOTS, "SNAPSHOTS", "Snapshots" );
|
|
|
|
addItem( RicfCommandFileExecutor::STATISTICS, "STATISTICS", "Statistics" );
|
|
|
|
addItem( RicfCommandFileExecutor::WELLPATHS, "WELLPATHS", "Well Path" );
|
|
|
|
addItem( RicfCommandFileExecutor::CELLS, "CELLS", "Cells" );
|
|
|
|
addItem( RicfCommandFileExecutor::LGRS, "LGRS", "Lgrs" );
|
|
|
|
setDefault( RicfCommandFileExecutor::COMPLETIONS );
|
2017-07-26 09:41:17 -05:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
} // namespace caf
|
2017-07-26 09:41:17 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
RicfCommandFileExecutor::RicfCommandFileExecutor() {}
|
2017-07-26 09:41:17 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
RicfCommandFileExecutor::~RicfCommandFileExecutor() {}
|
2017-07-26 09:41:17 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
void RicfCommandFileExecutor::executeCommands( QTextStream& stream )
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RicfMessages messages;
|
2018-02-05 01:47:10 -06:00
|
|
|
std::vector<RicfCommandObject*> executableCommands;
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
2018-10-04 03:40:48 -05:00
|
|
|
clearCachedData();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<RicfCommandObject*> fileCommands =
|
|
|
|
RicfCommandFileReader::readCommands( stream, caf::PdmDefaultObjectFactory::instance(), &messages );
|
|
|
|
for ( auto message : messages.m_messages )
|
2017-07-27 07:26:59 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( message.first == RicfMessages::MESSAGE_WARNING )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaLogging::warning( QString( "Command file parsing warning: %1" ).arg( message.second ) );
|
2018-02-05 01:47:10 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaLogging::error( QString( "Command file parsing error: %1" ).arg( message.second ) );
|
2018-02-05 01:47:10 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( auto& command : fileCommands )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
delete command;
|
|
|
|
command = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
2017-07-27 07:26:59 -05:00
|
|
|
}
|
2018-02-05 01:47:10 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( auto fileCommand : fileCommands )
|
2018-09-14 01:34:17 -05:00
|
|
|
{
|
|
|
|
fileCommand->initAfterReadRecursively();
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
executableCommands = RicfCommandFileExecutor::prepareFileCommandsForExecution( fileCommands );
|
2017-07-26 09:41:17 -05:00
|
|
|
}
|
2018-02-05 01:47:10 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( auto& command : executableCommands )
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
|
|
|
command->execute();
|
2018-02-05 01:47:10 -06:00
|
|
|
|
|
|
|
delete command;
|
|
|
|
command = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
// All command objects should be deleted and grounded at this point
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( auto c : executableCommands )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
CAF_ASSERT( c == nullptr );
|
2017-07-26 09:41:17 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-11-03 05:19:24 -06:00
|
|
|
void RicfCommandFileExecutor::setExportPath( ExportType type, const QString& path )
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
|
|
|
m_exportPaths[type] = path;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
QString RicfCommandFileExecutor::getExportPath( ExportType type ) const
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
auto it = m_exportPaths.find( type );
|
2017-07-26 09:41:17 -05:00
|
|
|
QString path;
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( it != m_exportPaths.end() )
|
2017-07-26 09:41:17 -05:00
|
|
|
{
|
|
|
|
path = it->second;
|
|
|
|
}
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
|
2017-07-28 04:28:55 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-28 04:28:55 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
void RicfCommandFileExecutor::setLastProjectPath( const QString& path )
|
2017-07-28 04:28:55 -05:00
|
|
|
{
|
|
|
|
m_lastProjectPath = path;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-28 04:28:55 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QString RicfCommandFileExecutor::getLastProjectPath() const
|
|
|
|
{
|
|
|
|
return m_lastProjectPath;
|
|
|
|
}
|
|
|
|
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2017-07-26 09:41:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RicfCommandFileExecutor* RicfCommandFileExecutor::instance()
|
|
|
|
{
|
|
|
|
static RicfCommandFileExecutor* commandFileExecutorInstance = new RicfCommandFileExecutor();
|
|
|
|
return commandFileExecutorInstance;
|
|
|
|
}
|
2018-02-05 01:47:10 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-02-05 01:47:10 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<RicfCommandObject*>
|
|
|
|
RicfCommandFileExecutor::prepareFileCommandsForExecution( const std::vector<RicfCommandObject*>& commandsReadFromFile )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
// This function will merge multiple RicfSingleCaseReplace object by a single RicfMultiCaseReplace object
|
|
|
|
// A command file version for multi case replace was rejected by @hhgs 2018-02-02
|
|
|
|
//
|
|
|
|
// The reason for this is based on two requirements
|
|
|
|
// 1. Ability to aggregate info from multiple replaceCase() statements in a command file
|
|
|
|
// 2. Improve performance, as a replace case is implemented by reading a project file from XML and replace file paths
|
|
|
|
// during project loading
|
|
|
|
|
|
|
|
std::vector<RicfCommandObject*> executableCommands;
|
|
|
|
{
|
|
|
|
std::vector<RicfSingleCaseReplace*> objectsToBeDeleted;
|
|
|
|
std::vector<RicfSingleCaseReplace*> batchOfReplaceCaseFileObjects;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
2018-02-05 01:47:10 -06:00
|
|
|
std::map<int, QString> aggregatedCasePathPairs;
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( RicfCommandObject* command : commandsReadFromFile )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RicfSingleCaseReplace* fileReplaceCase = dynamic_cast<RicfSingleCaseReplace*>( command );
|
|
|
|
if ( fileReplaceCase )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
aggregatedCasePathPairs[fileReplaceCase->caseId()] = fileReplaceCase->filePath();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
batchOfReplaceCaseFileObjects.push_back( fileReplaceCase );
|
|
|
|
objectsToBeDeleted.push_back( fileReplaceCase );
|
2018-02-05 01:47:10 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( !batchOfReplaceCaseFileObjects.empty() )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
RicfMultiCaseReplace* multiCaseReplace = new RicfMultiCaseReplace;
|
2019-09-06 03:40:57 -05:00
|
|
|
multiCaseReplace->setCaseReplacePairs( aggregatedCasePathPairs );
|
2018-02-05 01:47:10 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
executableCommands.push_back( multiCaseReplace );
|
2018-02-05 01:47:10 -06:00
|
|
|
|
|
|
|
batchOfReplaceCaseFileObjects.clear();
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( dynamic_cast<RicfOpenProject*>( command ) || dynamic_cast<RicfCloseProject*>( command ) )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
// Reset aggregation when openProject or closeProject is issued
|
|
|
|
aggregatedCasePathPairs.clear();
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
executableCommands.push_back( command );
|
2018-02-05 01:47:10 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Delete RicfSingleCaseReplace objects, as they are replaced by RicfMultiCaseReplace
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( auto objToDelete : objectsToBeDeleted )
|
2018-02-05 01:47:10 -06:00
|
|
|
{
|
|
|
|
delete objToDelete;
|
|
|
|
objToDelete = nullptr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return executableCommands;
|
|
|
|
}
|
2018-10-04 03:40:48 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-10-04 03:40:48 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicfCommandFileExecutor::clearCachedData()
|
|
|
|
{
|
|
|
|
m_exportPaths.clear();
|
|
|
|
m_lastProjectPath.clear();
|
|
|
|
}
|