2017-05-10 05:19:46 -05:00
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// Copyright (C) 2011- Statoil ASA
|
|
|
|
|
// Copyright (C) 2013- Ceetron Solutions AS
|
|
|
|
|
// Copyright (C) 2011-2012 Ceetron AS
|
2019-09-06 03:40:57 -05:00
|
|
|
|
//
|
2017-05-10 05:19:46 -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-05-10 05:19:46 -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-05-10 05:19:46 -05:00
|
|
|
|
// for more details.
|
|
|
|
|
//
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
#include "RifWellPathImporter.h"
|
|
|
|
|
|
|
|
|
|
#include "RifJsonEncodeDecode.h"
|
|
|
|
|
|
|
|
|
|
#include <fstream>
|
|
|
|
|
|
2017-05-15 06:40:13 -05:00
|
|
|
|
#include "cafUtils.h"
|
|
|
|
|
|
2017-05-10 05:19:46 -05:00
|
|
|
|
#include <QFileInfo>
|
|
|
|
|
|
2017-05-15 07:06:40 -05:00
|
|
|
|
#include <algorithm>
|
2019-09-06 03:40:57 -05:00
|
|
|
|
#include <cmath>
|
2017-05-15 07:06:40 -05:00
|
|
|
|
|
2017-05-10 05:19:46 -05:00
|
|
|
|
#define ASCII_FILE_DEFAULT_START_INDEX 0
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellData RifWellPathImporter::readWellData( const QString& filePath, size_t indexInFile )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
CVF_ASSERT( caf::Utils::fileExists( filePath ) );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( isJsonFile( filePath ) )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readJsonWellData( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readAsciiWellData( filePath, indexInFile );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellData RifWellPathImporter::readWellData( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readWellData( filePath, ASCII_FILE_DEFAULT_START_INDEX );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellMetaData RifWellPathImporter::readWellMetaData( const QString& filePath, size_t indexInFile )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
CVF_ASSERT( caf::Utils::fileExists( filePath ) );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( isJsonFile( filePath ) )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readJsonWellMetaData( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readAsciiWellMetaData( filePath, indexInFile );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellMetaData RifWellPathImporter::readWellMetaData( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return readWellMetaData( filePath, ASCII_FILE_DEFAULT_START_INDEX );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
size_t RifWellPathImporter::wellDataCount( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( isJsonFile( filePath ) )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// Only support JSON files with single well data currently
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2020-02-12 04:43:15 -06:00
|
|
|
|
std::map<QString, std::vector<RifWellPathImporter::WellData>>::iterator it =
|
|
|
|
|
m_fileNameToWellDataGroupMap.find( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
// If we have the file in the map, assume it is already read.
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( it != m_fileNameToWellDataGroupMap.end() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
return it->second.size();
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
readAllAsciiWellData( filePath );
|
|
|
|
|
it = m_fileNameToWellDataGroupMap.find( filePath );
|
|
|
|
|
CVF_ASSERT( it != m_fileNameToWellDataGroupMap.end() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
return it->second.size();
|
|
|
|
|
;
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
bool RifWellPathImporter::isJsonFile( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
QFileInfo fileInfo( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( fileInfo.suffix().compare( "json" ) == 0 )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellMetaData RifWellPathImporter::readJsonWellMetaData( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
ResInsightInternalJson::JsonReader jsonReader;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
QMap<QString, QVariant> jsonMap = jsonReader.decodeFile( filePath );
|
|
|
|
|
WellMetaData metadata;
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
metadata.m_id = jsonMap["id"].toString();
|
|
|
|
|
metadata.m_name = jsonMap["name"].toString();
|
2017-05-10 05:19:46 -05:00
|
|
|
|
metadata.m_sourceSystem = jsonMap["sourceSystem"].toString();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
metadata.m_utmZone = jsonMap["utmZone"].toString();
|
|
|
|
|
metadata.m_updateUser = jsonMap["updateUser"].toString();
|
|
|
|
|
metadata.m_surveyType = jsonMap["surveyType"].toString();
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
// Convert updateDate from the following format:
|
2019-09-06 03:40:57 -05:00
|
|
|
|
// "Number of milliseconds elapsed since midnight Coordinated Universal Time (UTC)
|
2017-05-10 05:19:46 -05:00
|
|
|
|
// of January 1, 1970, not counting leap seconds"
|
2020-02-12 04:43:15 -06:00
|
|
|
|
QString updateDateStr = jsonMap["updateDate"].toString().trimmed();
|
|
|
|
|
uint updateDateUint = updateDateStr.toULongLong() / 1000; // Should be within 32 bit, maximum number is 4294967295
|
|
|
|
|
// which corresponds to year 2106
|
2019-09-06 03:40:57 -05:00
|
|
|
|
metadata.m_updateDate.setTime_t( updateDateUint );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
return metadata;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellData RifWellPathImporter::readJsonWellData( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
ResInsightInternalJson::JsonReader jsonReader;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
QMap<QString, QVariant> jsonMap = jsonReader.decodeFile( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
double datumElevation = jsonMap["datumElevation"].toDouble();
|
|
|
|
|
QList<QVariant> pathList = jsonMap["path"].toList();
|
|
|
|
|
WellData wellData;
|
2017-08-15 08:16:29 -05:00
|
|
|
|
wellData.m_wellPathGeometry = new RigWellPath;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellData.m_wellPathGeometry->setDatumElevation( datumElevation );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
wellData.m_name = jsonMap["name"].toString();
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
foreach ( QVariant point, pathList )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
QMap<QString, QVariant> coordinateMap = point.toMap();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
cvf::Vec3d vec3d( coordinateMap["east"].toDouble(),
|
|
|
|
|
coordinateMap["north"].toDouble(),
|
|
|
|
|
-( coordinateMap["tvd"].toDouble() - datumElevation ) );
|
|
|
|
|
wellData.m_wellPathGeometry->m_wellPathPoints.push_back( vec3d );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
double measuredDepth = coordinateMap["md"].toDouble();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellData.m_wellPathGeometry->m_measuredDepths.push_back( measuredDepth );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
return wellData;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
void RifWellPathImporter::readAllAsciiWellData( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2020-02-12 04:43:15 -06:00
|
|
|
|
std::map<QString, std::vector<RifWellPathImporter::WellData>>::iterator it =
|
|
|
|
|
m_fileNameToWellDataGroupMap.find( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
// If we have the file in the map, assume it is already read.
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( it != m_fileNameToWellDataGroupMap.end() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Create the data container
|
|
|
|
|
std::vector<RifWellPathImporter::WellData>& fileWellDataArray = m_fileNameToWellDataGroupMap[filePath];
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
std::ifstream stream( filePath.toLatin1().data() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
bool hasReadWellPointInCurrentWell = false;
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
while ( stream.good() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
double x( HUGE_VAL ), y( HUGE_VAL ), tvd( HUGE_VAL ), md( HUGE_VAL );
|
2018-06-28 05:58:34 -05:00
|
|
|
|
|
2017-05-10 05:19:46 -05:00
|
|
|
|
// First check if we can read a number
|
|
|
|
|
stream >> x;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( stream.good() ) // If we can, assume this line is a well point entry
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
stream >> y >> tvd >> md;
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( x != HUGE_VAL && y != HUGE_VAL && tvd != HUGE_VAL && md != HUGE_VAL )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( !fileWellDataArray.size() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
fileWellDataArray.push_back( RifWellPathImporter::WellData() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
fileWellDataArray.back().m_wellPathGeometry = new RigWellPath();
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
cvf::Vec3d wellPoint( x, y, -tvd );
|
|
|
|
|
fileWellDataArray.back().m_wellPathGeometry->m_wellPathPoints.push_back( wellPoint );
|
|
|
|
|
fileWellDataArray.back().m_wellPathGeometry->m_measuredDepths.push_back( md );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
hasReadWellPointInCurrentWell = true;
|
|
|
|
|
}
|
2018-06-29 04:19:05 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( !stream.good() )
|
2018-06-29 04:19:05 -05:00
|
|
|
|
{
|
|
|
|
|
// -999 or otherwise to few numbers before some word
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( x != -999 )
|
2018-06-29 04:19:05 -05:00
|
|
|
|
{
|
|
|
|
|
// Error in file: missing numbers at this line
|
|
|
|
|
}
|
|
|
|
|
stream.clear();
|
|
|
|
|
}
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Could not read one double.
|
|
|
|
|
// we assume there is a comment line or a well path description
|
|
|
|
|
stream.clear();
|
|
|
|
|
|
|
|
|
|
std::string line;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
std::getline( stream, line, '\n' );
|
|
|
|
|
// Skip possible comment lines (-- is used in eclipse, so Haakon H<>gst<73>l considered it smart to skip these
|
|
|
|
|
// here as well) The first "-" is eaten by the stream >> x above
|
|
|
|
|
if ( line.find( "-" ) == 0 || line.find( "#" ) == 0 )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// Comment line, just ignore
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Find the first and the last position of any quotes (and do not care to match quotes)
|
2019-09-06 03:40:57 -05:00
|
|
|
|
size_t quoteStartIdx = line.find_first_of( "'`<60><><EFBFBD>" );
|
|
|
|
|
size_t quoteEndIdx = line.find_last_of( "'`<60><><EFBFBD>" );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
|
|
|
|
std::string wellName;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
bool haveAPossibleWellStart = false;
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( quoteStartIdx < line.size() - 1 )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// Extract the text between the quotes
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellName = line.substr( quoteStartIdx + 1, quoteEndIdx - 1 - quoteStartIdx );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
haveAPossibleWellStart = true;
|
|
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
|
else if ( quoteStartIdx > line.length() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// We did not find any quotes
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
// Supported alternatives are
|
2017-05-10 05:19:46 -05:00
|
|
|
|
// name <WellNameA>
|
|
|
|
|
// wellname: <WellNameA>
|
|
|
|
|
std::string lineLowerCase = line;
|
2020-02-12 04:43:15 -06:00
|
|
|
|
transform( lineLowerCase.begin(), lineLowerCase.end(), lineLowerCase.begin(), []( const char c ) -> char {
|
|
|
|
|
return (char)::tolower( c );
|
|
|
|
|
} );
|
2019-09-06 03:40:57 -05:00
|
|
|
|
|
|
|
|
|
std::string tokenName = "name";
|
|
|
|
|
std::size_t foundNameIdx = lineLowerCase.find( tokenName );
|
|
|
|
|
if ( foundNameIdx != std::string::npos )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
std::string tokenColon = ":";
|
|
|
|
|
std::size_t foundColonIdx = lineLowerCase.find( tokenColon, foundNameIdx );
|
|
|
|
|
if ( foundColonIdx != std::string::npos )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellName = line.substr( foundColonIdx + tokenColon.length() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellName = line.substr( foundNameIdx + tokenName.length() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
haveAPossibleWellStart = true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Interpret the whole line as the well name.
|
|
|
|
|
|
|
|
|
|
QString name = line.c_str();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( !name.trimmed().isEmpty() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
wellName = name.trimmed().toStdString();
|
2017-05-10 05:19:46 -05:00
|
|
|
|
haveAPossibleWellStart = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( haveAPossibleWellStart )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// Create a new Well data if we have read some data into the previous one.
|
|
|
|
|
// if not, just overwrite the name
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( hasReadWellPointInCurrentWell || fileWellDataArray.size() == 0 )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
fileWellDataArray.push_back( RifWellPathImporter::WellData() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
fileWellDataArray.back().m_wellPathGeometry = new RigWellPath();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString name = wellName.c_str();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( !name.trimmed().isEmpty() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2020-06-03 15:31:58 -05:00
|
|
|
|
// Do not overwrite the name acquired from a line above, if this line is empty
|
2017-05-10 05:19:46 -05:00
|
|
|
|
fileWellDataArray.back().m_name = name.trimmed();
|
|
|
|
|
}
|
|
|
|
|
hasReadWellPointInCurrentWell = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellData RifWellPathImporter::readAsciiWellData( const QString& filePath, size_t indexInFile )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
readAllAsciiWellData( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2020-02-12 04:43:15 -06:00
|
|
|
|
std::map<QString, std::vector<RifWellPathImporter::WellData>>::iterator it =
|
|
|
|
|
m_fileNameToWellDataGroupMap.find( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
CVF_ASSERT( it != m_fileNameToWellDataGroupMap.end() );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
|
if ( indexInFile < it->second.size() )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
return it->second[indexInFile];
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Error : The ascii well path file does not contain that many well paths
|
|
|
|
|
return RifWellPathImporter::WellData();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
RifWellPathImporter::WellMetaData RifWellPathImporter::readAsciiWellMetaData( const QString& filePath, size_t indexInFile )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
|
|
|
|
// No metadata in ASCII files
|
|
|
|
|
return WellMetaData();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RifWellPathImporter::clear()
|
|
|
|
|
{
|
|
|
|
|
m_fileNameToWellDataGroupMap.clear();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
///
|
2017-05-10 05:19:46 -05:00
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
|
void RifWellPathImporter::removeFilePath( const QString& filePath )
|
2017-05-10 05:19:46 -05:00
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
|
m_fileNameToWellDataGroupMap.erase( filePath );
|
2017-05-10 05:19:46 -05:00
|
|
|
|
}
|