1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
|
/*=========================================================================
Program: ParaView
Module: vtkPVEnsembleDataReaderInformation.cxx
Copyright (c) Kitware, Inc.
All rights reserved.
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
#include "vtkPVEnsembleDataReaderInformation.h"
#include "vtkClientServerStream.h"
#include "vtkEnsembleDataReader.h"
#include "vtkObjectFactory.h"
#include <cassert>
class vtkPVEnsembleDataReaderInformation::vtkInternal
{
public:
std::vector<vtkStdString> FilePaths;
};
vtkStandardNewMacro(vtkPVEnsembleDataReaderInformation);
//-----------------------------------------------------------------------------
vtkPVEnsembleDataReaderInformation::vtkPVEnsembleDataReaderInformation()
: Internal(new vtkPVEnsembleDataReaderInformation::vtkInternal())
{
this->SetRootOnly(1);
}
//-----------------------------------------------------------------------------
vtkPVEnsembleDataReaderInformation::~vtkPVEnsembleDataReaderInformation()
{
delete this->Internal;
this->Internal = NULL;
}
//-----------------------------------------------------------------------------
void vtkPVEnsembleDataReaderInformation::CopyFromObject(vtkObject* obj)
{
vtkEnsembleDataReader *reader = vtkEnsembleDataReader::SafeDownCast(obj);
if (!reader)
{
vtkErrorMacro(
"vtkPVEnsembleDataReaderInformation requires a valid "
"vtkEnsembleDataReader instance.");
return;
}
reader->UpdateMetaData();
unsigned int count = reader->GetNumberOfMembers();
this->Internal->FilePaths.resize(count);
for (unsigned int rowIndex = 0; rowIndex < count; ++rowIndex)
{
this->Internal->FilePaths[rowIndex] = reader->GetFilePath(rowIndex);
}
}
//-----------------------------------------------------------------------------
void vtkPVEnsembleDataReaderInformation::CopyToStream(vtkClientServerStream* stream)
{
*stream << vtkClientServerStream::Reply;
*stream << static_cast<unsigned int>(this->Internal->FilePaths.size());
for (size_t i = 0; i < this->Internal->FilePaths.size(); ++i)
{
*stream << this->Internal->FilePaths[i];
}
*stream << vtkClientServerStream::End;
}
//-----------------------------------------------------------------------------
void vtkPVEnsembleDataReaderInformation::CopyFromStream(const vtkClientServerStream* stream)
{
this->Internal->FilePaths.clear();
int offset = 0;
unsigned int filePathCount = 0;
if (!stream->GetArgument(0, offset++, &filePathCount))
{
vtkErrorMacro("Error parsing file path count.");
return;
}
this->Internal->FilePaths.resize(filePathCount);
vtkStdString filePath;
for (unsigned int i = 0; i < filePathCount; ++i)
{
if (!stream->GetArgument(0, offset++, &filePath))
{
vtkErrorMacro("Error parsing file path.");
}
this->Internal->FilePaths[i] = filePath;
}
}
//-----------------------------------------------------------------------------
unsigned int vtkPVEnsembleDataReaderInformation::GetFileCount()
{
return static_cast<unsigned int>(this->Internal->FilePaths.size());
}
//-----------------------------------------------------------------------------
vtkStdString vtkPVEnsembleDataReaderInformation::GetFilePath(int unsigned i)
{
unsigned int count = static_cast<unsigned int>(this->Internal->FilePaths.size());
if (i >= count)
{
vtkErrorMacro("Bad index sent to GetFilePath.");
return vtkStdString();
}
return this->Internal->FilePaths[i];
}
//-----------------------------------------------------------------------------
void vtkPVEnsembleDataReaderInformation::PrintSelf(ostream& os, vtkIndent indent)
{
this->Superclass::PrintSelf(os, indent);
// File paths
os << indent << "File Paths: " << endl;
for (size_t i = 0; i < this->Internal->FilePaths.size(); ++i)
{
os << indent.GetNextIndent() << this->Internal->FilePaths[i].c_str() << endl;
}
}
|