mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
Added one common class used to transfer data using socket. This class is used both from the Octave plugins and from the socket server code in ResInsight
133 lines
4.0 KiB
C++
133 lines
4.0 KiB
C++
//
|
|
// Copyright (C) 2011-2012 Statoil ASA, Ceetron AS
|
|
//
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RiaStdInclude.h"
|
|
|
|
#include "RiaApplication.h"
|
|
#include "RiaPreferences.h"
|
|
|
|
#include "RiaSocketTools.h"
|
|
#include "RiaSocketServer.h"
|
|
#include "RimCase.h"
|
|
#include "RimCaseCollection.h"
|
|
#include "RimIdenticalGridCaseGroup.h"
|
|
#include "RimInputCase.h"
|
|
|
|
#include "RimReservoirView.h"
|
|
#include "RimResultSlot.h"
|
|
#include "RimCellEdgeResultSlot.h"
|
|
#include "RimCellRangeFilterCollection.h"
|
|
#include "RimCellPropertyFilterCollection.h"
|
|
#include "RimWellCollection.h"
|
|
#include "Rim3dOverlayInfoConfig.h"
|
|
#include "RimReservoirCellResultsCacher.h"
|
|
|
|
#include "RimInputPropertyCollection.h"
|
|
|
|
#include "RiaSocketDataTransfer.h"
|
|
|
|
#include <QTcpSocket>
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimCase* RiaSocketTools::findCaseFromArgs(RiaSocketServer* server, const QList<QByteArray>& args)
|
|
{
|
|
RimCase* rimCase = NULL;
|
|
int caseId = -1;
|
|
|
|
if (args.size() > 1)
|
|
{
|
|
caseId = args[1].toInt();
|
|
}
|
|
rimCase = server->findReservoir(caseId);
|
|
|
|
if (rimCase == NULL)
|
|
{
|
|
// TODO: Display error message a different place to avoid socket comm to be halted.
|
|
//server->errorMessageDialog()->showMessage(RiaSocketServer::tr("ResInsight SocketServer: \n") + RiaSocketServer::tr("Could not find the Case with CaseId : \"%1\"").arg(caseId));
|
|
}
|
|
|
|
return rimCase;
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RiaSocketTools::getCaseInfoFromCase(RimCase* rimCase, qint64& caseId, QString& caseName, QString& caseType, qint64& caseGroupId)
|
|
{
|
|
CVF_ASSERT(rimCase);
|
|
|
|
caseId = rimCase->caseId;
|
|
caseName = rimCase->caseUserDescription;
|
|
|
|
RimCaseCollection* caseCollection = rimCase->parentCaseCollection();
|
|
if (caseCollection)
|
|
{
|
|
caseGroupId = caseCollection->parentCaseGroup()->groupId;
|
|
|
|
if (RimIdenticalGridCaseGroup::isStatisticsCaseCollection(caseCollection))
|
|
{
|
|
caseType = "StatisticsCase";
|
|
}
|
|
else
|
|
{
|
|
caseType = "SourceCase";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
caseGroupId = -1;
|
|
|
|
if (dynamic_cast<RimInputCase*>(rimCase))
|
|
{
|
|
caseType = "InputCase";
|
|
}
|
|
else
|
|
{
|
|
caseType = "ResultCase";
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool RiaSocketTools::writeBlockData(RiaSocketServer* server, QTcpSocket* socket, const char* data, quint64 bytesToWrite)
|
|
{
|
|
cvf::Timer timer;
|
|
|
|
QStringList errorMessages;
|
|
bool writeSucceded = RiaSocketDataTransfer::writeBlockDataToSocket(socket, data, bytesToWrite, errorMessages);
|
|
|
|
if (server)
|
|
{
|
|
for (int i = 0; i < errorMessages.size(); i++)
|
|
{
|
|
server->errorMessageDialog()->showMessage(errorMessages[i]);
|
|
}
|
|
|
|
double totalTimeMS = timer.time() * 1000.0;
|
|
QString resultInfo = QString("Total time '%1 ms'").arg(totalTimeMS);
|
|
|
|
server->errorMessageDialog()->showMessage(resultInfo);
|
|
}
|
|
|
|
return writeSucceded;
|
|
}
|