Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1501 lines
45 KiB

2 years ago
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkGenericEnSightReader.cxx,v $
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm 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 "vtkGenericEnSightReader.h"
#include "vtkCallbackCommand.h"
#include "vtkDataArrayCollection.h"
#include "vtkDataArraySelection.h"
#include "vtkDataSet.h"
#include "vtkEnSight6BinaryReader.h"
#include "vtkEnSight6Reader.h"
#include "vtkEnSightGoldBinaryReader.h"
#include "vtkEnSightGoldReader.h"
#include "vtkIdListCollection.h"
#include "vtkObjectFactory.h"
#include <vtkstd/string>
#include <vtkstd/map>
#include <assert.h>
#include <ctype.h> /* isspace */
vtkCxxRevisionMacro(vtkGenericEnSightReader, "$Revision: 1.74 $");
vtkStandardNewMacro(vtkGenericEnSightReader);
vtkCxxSetObjectMacro(vtkGenericEnSightReader,TimeSets,
vtkDataArrayCollection);
class TranslationTableType
{
public:
vtkstd::map<int,int> PartIdMap;
};
//----------------------------------------------------------------------------
vtkGenericEnSightReader::vtkGenericEnSightReader()
{
this->Reader = NULL;
this->IS = NULL;
this->IFile = NULL;
this->CaseFileName = NULL;
this->GeometryFileName = NULL;
this->FilePath = NULL;
this->VariableTypes = NULL;
this->ComplexVariableTypes = NULL;
this->VariableDescriptions = NULL;
this->ComplexVariableDescriptions = NULL;
this->NumberOfVariables = 0;
this->NumberOfComplexVariables = 0;
this->NumberOfScalarsPerNode = 0;
this->NumberOfVectorsPerNode = 0;
this->NumberOfTensorsSymmPerNode = 0;
this->NumberOfScalarsPerElement = 0;
this->NumberOfVectorsPerElement = 0;
this->NumberOfTensorsSymmPerElement = 0;
this->NumberOfScalarsPerMeasuredNode = 0;
this->NumberOfVectorsPerMeasuredNode = 0;
this->NumberOfComplexScalarsPerNode = 0;
this->NumberOfComplexVectorsPerNode = 0;
this->NumberOfComplexScalarsPerElement = 0;
this->NumberOfComplexVectorsPerElement = 0;
this->TimeValue = 0;
this->MinimumTimeValue = 0;
this->MaximumTimeValue = 0;
this->TimeValueInitialized = 0;
this->TimeSets = NULL;
this->ReadAllVariables = 1;
this->ByteOrder = FILE_UNKNOWN_ENDIAN;
this->EnSightVersion = -1;
this->PointDataArraySelection = vtkDataArraySelection::New();
this->CellDataArraySelection = vtkDataArraySelection::New();
// Setup the selection callback to modify this object when an array
// selection is changed.
this->SelectionObserver = vtkCallbackCommand::New();
this->SelectionObserver->SetCallback(
&vtkGenericEnSightReader::SelectionModifiedCallback);
this->SelectionObserver->SetClientData(this);
this->PointDataArraySelection->AddObserver(vtkCommand::ModifiedEvent,
this->SelectionObserver);
this->CellDataArraySelection->AddObserver(vtkCommand::ModifiedEvent,
this->SelectionObserver);
this->SelectionModifiedDoNotCallModified = 0;
this->TranslationTable = new TranslationTableType;
this->SetNumberOfOutputPorts(0);
}
//----------------------------------------------------------------------------
vtkGenericEnSightReader::~vtkGenericEnSightReader()
{
int i;
if (this->Reader)
{
this->Reader->Delete();
this->Reader = NULL;
}
if (this->IS)
{
delete this->IS;
this->IS = NULL;
}
if (this->CaseFileName)
{
delete [] this->CaseFileName;
this->CaseFileName = NULL;
}
if (this->GeometryFileName)
{
delete [] this->GeometryFileName;
this->GeometryFileName = NULL;
}
if (this->FilePath)
{
delete [] this->FilePath;
this->FilePath = NULL;
}
if (this->NumberOfVariables > 0)
{
for (i = 0; i < this->NumberOfVariables; i++)
{
delete [] this->VariableDescriptions[i];
}
delete [] this->VariableDescriptions;
delete [] this->VariableTypes;
this->VariableDescriptions = NULL;
this->VariableTypes = NULL;
}
if (this->NumberOfComplexVariables > 0)
{
for (i = 0; i < this->NumberOfComplexVariables; i++)
{
delete [] this->ComplexVariableDescriptions[i];
}
delete [] this->ComplexVariableDescriptions;
delete [] this->ComplexVariableTypes;
this->ComplexVariableDescriptions = NULL;
this->ComplexVariableTypes = NULL;
}
this->SetTimeSets(0);
this->CellDataArraySelection->RemoveObserver(this->SelectionObserver);
this->PointDataArraySelection->RemoveObserver(this->SelectionObserver);
this->SelectionObserver->Delete();
this->CellDataArraySelection->Delete();
this->PointDataArraySelection->Delete();
delete this->TranslationTable;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::Execute()
{
int i;
if ( !this->Reader )
{
return;
}
// Set the real reader's data array selections from ours.
this->SetReaderDataArraySelectionSetsFromSelf();
this->Reader->SetTimeValue(this->GetTimeValue());
this->Reader->Update();
this->NumberOfScalarsPerNode = this->Reader->GetNumberOfScalarsPerNode();
this->NumberOfVectorsPerNode = this->Reader->GetNumberOfVectorsPerNode();
this->NumberOfTensorsSymmPerNode =
this->Reader->GetNumberOfTensorsSymmPerNode();
this->NumberOfScalarsPerElement =
this->Reader->GetNumberOfScalarsPerElement();
this->NumberOfVectorsPerElement =
this->Reader->GetNumberOfVectorsPerElement();
this->NumberOfTensorsSymmPerElement =
this->Reader->GetNumberOfTensorsSymmPerElement();
this->NumberOfScalarsPerMeasuredNode =
this->Reader->GetNumberOfScalarsPerMeasuredNode();
this->NumberOfVectorsPerMeasuredNode =
this->Reader->GetNumberOfVectorsPerMeasuredNode();
this->NumberOfComplexScalarsPerNode =
this->Reader->GetNumberOfComplexScalarsPerNode();
this->NumberOfComplexVectorsPerNode =
this->Reader->GetNumberOfComplexVectorsPerNode();
this->NumberOfComplexScalarsPerElement =
this->Reader->GetNumberOfComplexScalarsPerElement();
this->NumberOfComplexVectorsPerElement =
this->Reader->GetNumberOfComplexScalarsPerElement();
for (i = 0; i < this->Reader->GetNumberOfOutputs(); i++)
{
vtkDataObject* output = this->GetOutput(i);
if ( ! output )
{
// Copy the output rather than setting directly.
// When we set directly, the internal reader looses its output.
// Next execute, a new output is added,
// and another partid is added too.
vtkDataObject* tmp = this->Reader->GetOutput(i);
if( tmp )
{
output = tmp->NewInstance();
this->SetNthOutput(i, output); // law: this causes the extra partid bug
output->ShallowCopy(tmp);
output->CopyInformation(tmp);
output->Delete();
// Used later.
//output = NULL;
}
else
{
this->SetNthOutput(i, 0);
}
}
else
{
// We don't know the number of outputs or whole extent of the
// internal reader's data until after it executes. Therefore,
// the update extent of the reader is set to empty. Since the
// reader ignores the update extent anyway, it reads correctly,
// but then this shallow copy destroys this reader's update
// extent. Save it and restore.
int tempExtent[6];
output->GetUpdateExtent(tempExtent);
output->ShallowCopy(this->Reader->GetOutput(i));
output->SetUpdateExtent(tempExtent);
}
// Since most unstructured filters in VTK generate all their data once,
// make it the default.
// protected: if ( output->GetExtentType() == VTK_PIECES_EXTENT )
if (output && ( output->IsA("vtkPolyData") || output->IsA("vtkUnstructuredGrid")))
{
output->SetMaximumNumberOfPieces(1);
}
}
for (i = 0; i < this->Reader->GetNumberOfVariables(); i++)
{
this->AddVariableDescription(this->Reader->GetDescription(i));
this->AddVariableType(this->Reader->GetVariableType(i));
this->NumberOfVariables++;
}
for (i = 0; i < this->Reader->GetNumberOfComplexVariables(); i++)
{
this->AddComplexVariableDescription(
this->Reader->GetComplexDescription(i));
this->AddComplexVariableType(this->Reader->GetComplexVariableType(i));
this->NumberOfComplexVariables++;
}
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetTimeValue(float value)
{
vtkDebugMacro(<< this->GetClassName() << " (" << this << "): setting TimeValue to " << value);
if (this->TimeValue != value)
{
this->TimeValue = value;
this->Modified();
}
this->TimeValueInitialized = 1;
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::DetermineEnSightVersion()
{
char line[256], subLine[256], subLine1[256], subLine2[256], binaryLine[81];
int stringRead;
int timeSet = 1, fileSet = 1;
int xtimeSet= 1, xfileSet= 1;
char *fileName = NULL;
if (!this->CaseFileName)
{
vtkErrorMacro("A case file name must be specified.");
return -1;
}
vtkstd::string sfilename = "";
if (this->FilePath)
{
sfilename = this->FilePath;
if (sfilename.at(sfilename.length()-1) != '/')
{
sfilename += "/";
}
sfilename += this->CaseFileName;
vtkDebugMacro("full path to case file: "
<< sfilename.c_str());
}
else
{
sfilename = this->CaseFileName;
}
this->IS = new ifstream(sfilename.c_str(), ios::in);
if (this->IS->fail())
{
vtkErrorMacro("Unable to open file: " << sfilename.c_str());
delete this->IS;
this->IS = NULL;
return -1;
}
this->ReadNextDataLine(line);
if (strncmp(line, "FORMAT", 6) == 0)
{
// found the FORMAT section
vtkDebugMacro("*** FORMAT section");
this->ReadNextDataLine(line);
stringRead = sscanf(line, " %*s %*s %s", subLine);
if (stringRead == 1)
{
sscanf(line, " %*s %s %s", subLine1, subLine2);
if (strncmp(subLine1,"ensight",7) == 0)
{
if (strncmp(subLine2,"gold",4) == 0)
{
this->ReadNextDataLine(line);
if (strncmp(line, "GEOMETRY", 8) == 0)
{
// found the GEOMETRY section
vtkDebugMacro("*** GEOMETRY section");
this->ReadNextDataLine(line);
if (strncmp(line, "model:", 6) == 0)
{
if (sscanf(line, " %*s %d %d %s", &xtimeSet, &fileSet, subLine) == 3)
{
timeSet = xtimeSet;
fileSet = xfileSet;
this->SetGeometryFileName(subLine);
}
else if (sscanf(line, " %*s %d%*[ \t]%s", &xtimeSet, subLine) == 2)
{
timeSet = xtimeSet;
this->SetGeometryFileName(subLine);
}
else if (sscanf(line, " %*s %s", subLine) == 1)
{
this->SetGeometryFileName(subLine);
}
} // geometry file name set
delete this->IS;
this->IS = NULL;
fileName = new char[strlen(this->GeometryFileName) + 1];
strcpy(fileName, this->GeometryFileName);
if (!fileName)
{
vtkErrorMacro(
"A GeometryFileName must be specified in the case file.");
return 0;
}
if (strrchr(fileName, '*') != NULL)
{
// reopen case file; find right time set and fill in
// wildcards from there if possible; if not, then find right
// file set and fill in wildcards from there.
this->ReplaceWildcards(fileName, timeSet, fileSet);
}
sfilename = "";
if (this->FilePath)
{
sfilename = this->FilePath;
if (sfilename.at(sfilename.length()-1) != '/')
{
sfilename += "/";
}
sfilename += fileName;
vtkDebugMacro("full path to geometry file: "
<< sfilename.c_str());
}
else
{
sfilename = fileName;
}
// got full path to geometry file
this->IFile = fopen(sfilename.c_str(), "rb");
if (this->IFile == NULL)
{
vtkErrorMacro("Unable to open file: " << sfilename.c_str());
vtkWarningMacro("Assuming binary file.");
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_GOLD_BINARY;
} // end if IFile == NULL
this->ReadBinaryLine(binaryLine);
binaryLine[80] = '\0';
sscanf(binaryLine, " %*s %s", subLine);
// If the file is ascii, there might not be a null
// terminator. This leads to a UMR in sscanf
if (strncmp(subLine,"Binary",6) == 0 ||
strncmp(subLine,"binary",6) == 0)
{
fclose(this->IFile);
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_GOLD_BINARY;
} //end if binary
fclose(this->IFile);
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_GOLD;
} // if we found the geometry section in the case file
} // if ensight gold file
} // if regular ensight file (not master_server)
else if (strncmp(subLine1,"master_server",13) == 0)
{
return vtkGenericEnSightReader::ENSIGHT_MASTER_SERVER;
}
} // if the type line is like "type: xxxx xxxx"
else
{
this->ReadNextDataLine(line);
if (strncmp(line, "GEOMETRY", 8) == 0)
{
// found the GEOMETRY section
vtkDebugMacro("*** GEOMETRY section");
this->ReadNextDataLine(line);
if (strncmp(line, "model:", 6) == 0)
{
if (sscanf(line, " %*s %d %d %s", &xtimeSet, &fileSet, subLine) == 3)
{
timeSet = xtimeSet;
fileSet = xfileSet;
this->SetGeometryFileName(subLine);
}
else if (sscanf(line, " %*s %d%*[ \t]%s", &xtimeSet, subLine) == 2)
{
timeSet = xtimeSet;
this->SetGeometryFileName(subLine);
}
else if (sscanf(line, " %*s %s", subLine) == 1)
{
this->SetGeometryFileName(subLine);
}
} // geometry file name set
fileName = new char[strlen(this->GeometryFileName) + 1];
strcpy(fileName, this->GeometryFileName);
delete this->IS;
this->IS = NULL;
if (!fileName)
{
vtkErrorMacro(
"A GeometryFileName must be specified in the case file.");
return 0;
}
if (strrchr(fileName, '*') != NULL)
{
// reopen case file; find right time set and fill in wildcards from
// there if possible; if not, then find right file set and fill in
// wildcards from there.
this->ReplaceWildcards(fileName, timeSet, fileSet);
}
sfilename = "";
if (this->FilePath)
{
sfilename = this->FilePath;
if (sfilename.at(sfilename.length()-1) != '/')
{
sfilename += "/";
}
sfilename += fileName;
vtkDebugMacro("full path to geometry file: "
<< sfilename.c_str());
}
else
{
sfilename = fileName;
}
// got full path to geometry file
this->IFile = fopen(sfilename.c_str(), "rb");
if (this->IFile == NULL)
{
vtkErrorMacro("Unable to open file: " << sfilename.c_str());
vtkWarningMacro("Assuming binary file.");
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_6_BINARY;
} // end if IFile == NULL
this->ReadBinaryLine(binaryLine);
// If the file is ascii, there might not be a null
// terminator. This leads to a UMR in sscanf
binaryLine[80] = '\0';
sscanf(binaryLine, " %*s %s", subLine);
if (strncmp(subLine,"Binary",6) == 0)
{
fclose(this->IFile);
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_6_BINARY;
} //end if binary
fclose(this->IFile);
this->IFile = NULL;
delete [] fileName;
return vtkGenericEnSightReader::ENSIGHT_6;
} // if we found the geometry section in the case file
} // not ensight gold
} // if we found the format section in the case file
if (fileName)
{
delete [] fileName;
}
return -1;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetCaseFileName(const char* fileName)
{
char *endingSlash;
char *path, *newFileName;
int position, numChars;
if ( this->CaseFileName && fileName &&
(!strcmp(this->CaseFileName, fileName)))
{
return;
}
if (this->CaseFileName)
{
delete [] this->CaseFileName;
}
if (fileName)
{
this->CaseFileName = new char[strlen(fileName)+1];
strcpy(this->CaseFileName, fileName);
}
else
{
this->CaseFileName = NULL;
}
this->Modified();
if (!this->CaseFileName)
{
return;
}
// strip off the path and save it as FilePath if it was included in the
// filename
if ((endingSlash = strrchr(this->CaseFileName, '/')))
{
position = endingSlash - this->CaseFileName + 1;
path = new char[position + 1];
numChars = static_cast<int>(strlen(this->CaseFileName));
newFileName = new char[numChars - position + 1];
strcpy(path, "");
strncat(path, this->CaseFileName, position);
this->SetFilePath(path);
strcpy(newFileName, this->CaseFileName + position);
strcpy(this->CaseFileName, newFileName);
delete [] path;
delete [] newFileName;
}
}
//----------------------------------------------------------------------------
// Internal function to read in a line up to 256 characters.
// Returns zero if there was an error.
int vtkGenericEnSightReader::ReadLine(char result[256])
{
this->IS->getline(result,256);
// if (this->IS->eof())
if (this->IS->fail())
{
return 0;
}
return 1;
}
//----------------------------------------------------------------------------
// Internal function to read in a line (from a binary file) up
// to 80 characters. Returns zero if there was an error.
int vtkGenericEnSightReader::ReadBinaryLine(char result[80])
{
fread(result, sizeof(char), 80, this->IFile);
if (feof(this->IFile) || ferror(this->IFile))
{
return 0;
}
return 1;
}
//----------------------------------------------------------------------------
// Internal function that skips blank lines and comment lines
// and reads the next line it finds (up to 256 characters).
// Returns 0 is there was an error.
int vtkGenericEnSightReader::ReadNextDataLine(char result[256])
{
int isComment = 1;
int value = 1;
while( isComment && value )
{
value = this->ReadLine(result);
if( *result && result[0] != '#' )
{
size_t len = strlen( result );
unsigned int i = 0;
while( i < len && isspace( result[i] ) )
{
++i;
}
// If there was only space characters this is a comment, thus skip it
if( i != len )
{
// The line was not empty, not begining by '#' and not composed
// of only white space, this is not a comment
isComment = 0;
}
}
}
return value;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::Update()
{
int i;
this->UpdateInformation();
this->Execute();
for (i = 0; i < this->GetNumberOfOutputs(); i++)
{
if ( this->GetOutput(i) )
{
this->GetOutput(i)->DataHasBeenGenerated();
this->GetOutput(i)->SetUpdateExtentToWholeExtent();
}
}
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::ExecuteInformation()
{
int version = this->DetermineEnSightVersion();
int createReader = 1;
if (version == vtkGenericEnSightReader::ENSIGHT_6)
{
vtkDebugMacro("EnSight6");
if (this->Reader)
{
if (strcmp(this->Reader->GetClassName(), "vtkEnSight6Reader") == 0)
{
createReader = 0;
}
else
{
this->Reader->Delete();
}
}
if (createReader)
{
this->Reader = vtkEnSight6Reader::New();
}
}
else if (version == vtkGenericEnSightReader::ENSIGHT_6_BINARY)
{
vtkDebugMacro("EnSight6 binary");
if (this->Reader)
{
if (strcmp(this->Reader->GetClassName(), "vtkEnSight6BinaryReader") == 0)
{
createReader = 0;
}
else
{
this->Reader->Delete();
}
}
if (createReader)
{
this->Reader = vtkEnSight6BinaryReader::New();
}
}
else if (version == vtkGenericEnSightReader::ENSIGHT_GOLD)
{
vtkDebugMacro("EnSightGold");
if (this->Reader)
{
if (strcmp(this->Reader->GetClassName(), "vtkEnSightGoldReader") == 0)
{
createReader = 0;
}
else
{
this->Reader->Delete();
}
}
if (createReader)
{
this->Reader = vtkEnSightGoldReader::New();
}
}
else if (version == vtkGenericEnSightReader::ENSIGHT_GOLD_BINARY)
{
vtkDebugMacro("EnSightGold binary");
if (this->Reader)
{
if (strcmp(this->Reader->GetClassName(),
"vtkEnSightGoldBinaryReader") == 0)
{
createReader = 0;
}
else
{
this->Reader->Delete();
}
}
if (createReader)
{
this->Reader = vtkEnSightGoldBinaryReader::New();
}
}
else
{
vtkErrorMacro("Error determining EnSightVersion");
this->EnSightVersion = -1;
return;
}
this->EnSightVersion = version;
// Copy current array selections to internal reader.
this->SetReaderDataArraySelectionSetsFromSelf();
this->Reader->SetReadAllVariables(this->ReadAllVariables);
this->Reader->SetCaseFileName(this->GetCaseFileName());
this->Reader->SetFilePath(this->GetFilePath());
this->Reader->SetByteOrder(this->ByteOrder);
this->Reader->UpdateInformation();
this->SetTimeSets(this->Reader->GetTimeSets());
if(!this->TimeValueInitialized)
{
this->SetTimeValue(this->Reader->GetTimeValue());
}
this->MinimumTimeValue = this->Reader->GetMinimumTimeValue();
this->MaximumTimeValue = this->Reader->GetMaximumTimeValue();
// Copy new data array selections from internal reader.
this->SetDataArraySelectionSetsFromReader();
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::AddVariableDescription(const char* description)
{
int size = this->NumberOfVariables;
int i;
char ** newDescriptionList = new char *[size]; // temporary array
// copy descriptions to temporary array
for (i = 0; i < size; i++)
{
newDescriptionList[i] =
new char[strlen(this->VariableDescriptions[i]) + 1];
strcpy(newDescriptionList[i], this->VariableDescriptions[i]);
delete [] this->VariableDescriptions[i];
}
if (this->VariableDescriptions)
{
delete [] this->VariableDescriptions;
}
// make room for new description
this->VariableDescriptions = new char *[size+1];
// copy existing descriptions back to first array
for (i = 0; i < size; i++)
{
this->VariableDescriptions[i] =
new char[strlen(newDescriptionList[i]) + 1];
strcpy(this->VariableDescriptions[i], newDescriptionList[i]);
delete [] newDescriptionList[i];
}
delete [] newDescriptionList;
// add new description at end of first array
this->VariableDescriptions[size] = new char[strlen(description) + 1];
strcpy(this->VariableDescriptions[size], description);
vtkDebugMacro("description: " << this->VariableDescriptions[size]);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::AddComplexVariableDescription(const char* description)
{
int i;
int size = this->NumberOfComplexVariables;
char ** newDescriptionList = new char *[size]; // temporary array
// copy descriptions to temporary array
for (i = 0; i < size; i++)
{
newDescriptionList[i] =
new char[strlen(this->ComplexVariableDescriptions[i]) + 1];
strcpy(newDescriptionList[i], this->ComplexVariableDescriptions[i]);
delete [] this->ComplexVariableDescriptions[i];
}
delete [] this->ComplexVariableDescriptions;
// make room for new description
this->ComplexVariableDescriptions = new char *[size+1];
// copy existing descriptions back to first array
for (i = 0; i < size; i++)
{
this->ComplexVariableDescriptions[i] =
new char[strlen(newDescriptionList[i]) + 1];
strcpy(this->ComplexVariableDescriptions[i], newDescriptionList[i]);
delete [] newDescriptionList[i];
}
delete [] newDescriptionList;
// add new description at end of first array
this->ComplexVariableDescriptions[size] =
new char[strlen(description) + 1];
strcpy(this->ComplexVariableDescriptions[size], description);
vtkDebugMacro("description: "
<< this->ComplexVariableDescriptions[size]);
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetNumberOfVariables(int type)
{
switch (type)
{
case vtkEnSightReader::SCALAR_PER_NODE:
return this->GetNumberOfScalarsPerNode();
case vtkEnSightReader::VECTOR_PER_NODE:
return this->GetNumberOfVectorsPerNode();
case vtkEnSightReader::TENSOR_SYMM_PER_NODE:
return this->GetNumberOfTensorsSymmPerNode();
case vtkEnSightReader::SCALAR_PER_ELEMENT:
return this->GetNumberOfScalarsPerElement();
case vtkEnSightReader::VECTOR_PER_ELEMENT:
return this->GetNumberOfVectorsPerElement();
case vtkEnSightReader::TENSOR_SYMM_PER_ELEMENT:
return this->GetNumberOfTensorsSymmPerElement();
case vtkEnSightReader::SCALAR_PER_MEASURED_NODE:
return this->GetNumberOfScalarsPerMeasuredNode();
case vtkEnSightReader::VECTOR_PER_MEASURED_NODE:
return this->GetNumberOfVectorsPerMeasuredNode();
case vtkEnSightReader::COMPLEX_SCALAR_PER_NODE:
return this->GetNumberOfComplexScalarsPerNode();
case vtkEnSightReader::COMPLEX_VECTOR_PER_NODE:
return this->GetNumberOfComplexVectorsPerNode();
case vtkEnSightReader::COMPLEX_SCALAR_PER_ELEMENT:
return this->GetNumberOfComplexScalarsPerElement();
case vtkEnSightReader::COMPLEX_VECTOR_PER_ELEMENT:
return this->GetNumberOfComplexVectorsPerElement();
default:
vtkWarningMacro("unknow variable type");
return -1;
}
}
//----------------------------------------------------------------------------
const char* vtkGenericEnSightReader::GetDescription(int n)
{
if (n < this->NumberOfVariables)
{
return this->VariableDescriptions[n];
}
return NULL;
}
//----------------------------------------------------------------------------
const char* vtkGenericEnSightReader::GetComplexDescription(int n)
{
if (n < this->NumberOfComplexVariables)
{
return this->ComplexVariableDescriptions[n];
}
return NULL;
}
//----------------------------------------------------------------------------
const char* vtkGenericEnSightReader::GetDescription(int n, int type)
{
int i, numMatches = 0;
if (type < 8)
{
for (i = 0; i < this->NumberOfVariables; i++)
{
if (this->VariableTypes[i] == type)
{
if (numMatches == n)
{
return this->VariableDescriptions[i];
}
else
{
numMatches++;
}
}
}
}
else
{
for (i = 0; i < this->NumberOfVariables; i++)
{
if (this->ComplexVariableTypes[i] == type)
{
if (numMatches == n)
{
return this->ComplexVariableDescriptions[i];
}
else
{
numMatches++;
}
}
}
}
return NULL;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::AddVariableType(int variableType)
{
int size;
int i;
int *types;
size = this->NumberOfVariables;
types = new int[size];
for (i = 0; i < size; i++)
{
types[i] = this->VariableTypes[i];
}
delete [] this->VariableTypes;
this->VariableTypes = new int[size+1];
for (i = 0; i < size; i++)
{
this->VariableTypes[i] = types[i];
}
delete [] types;
this->VariableTypes[size] = variableType;
vtkDebugMacro("variable type: " << this->VariableTypes[size]);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::AddComplexVariableType(int variableType)
{
int i;
int* types = NULL;
int size = this->NumberOfComplexVariables;
if (size > 0)
{
types = new int[size];
for (i = 0; i < size; i++)
{
types[i] = this->ComplexVariableTypes[i];
}
delete [] this->ComplexVariableTypes;
}
this->ComplexVariableTypes = new int[size+1];
for (i = 0; i < size; i++)
{
this->ComplexVariableTypes[i] = types[i];
}
if (size > 0)
{
delete [] types;
}
this->ComplexVariableTypes[size] = variableType;
vtkDebugMacro("complex variable type: "
<< this->ComplexVariableTypes[size]);
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetVariableType(int n)
{
if (n < this->NumberOfVariables)
{
return this->VariableTypes[n];
}
return -1;
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetComplexVariableType(int n)
{
if (n < this->NumberOfComplexVariables)
{
return this->ComplexVariableTypes[n];
}
return -1;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::ReplaceWildcards(char* fileName, int timeSet,
int fileSet)
{
char line[256], subLine[256];
int cmpTimeSet, cmpFileSet, fileNameNum;
vtkstd::string sfilename;
if (this->FilePath)
{
sfilename = this->FilePath;
if (sfilename.at(sfilename.length()-1) != '/')
{
sfilename += "/";
}
sfilename += this->CaseFileName;
vtkDebugMacro("full path to case file: "
<< sfilename.c_str());
}
else
{
sfilename = this->CaseFileName;
}
this->IS = new ifstream(sfilename.c_str(), ios::in);
// We already know we have a valid case file if we've gotten to this point.
this->ReadLine(line);
while (strncmp(line, "TIME", 4) != 0)
{
this->ReadLine(line);
}
this->ReadNextDataLine(line);
sscanf(line, " %*s %*s %d", &cmpTimeSet);
while (cmpTimeSet != timeSet)
{
this->ReadNextDataLine(line);
this->ReadNextDataLine(line);
sscanf(line, " %s", subLine);
if (strncmp(subLine, "filename", 8) == 0)
{
this->ReadNextDataLine(line);
}
if (strncmp(subLine, "filename", 8) == 0)
{
this->ReadNextDataLine(line);
}
sscanf(line, " %*s %*s %d", &cmpTimeSet);
}
this->ReadNextDataLine(line); // number of timesteps
this->ReadNextDataLine(line);
sscanf(line, " %s", subLine);
if (strncmp(subLine, "filename", 8) == 0)
{
sscanf(line, " %*s %s", subLine);
if (strncmp(subLine, "start", 5) == 0)
{
sscanf(line, " %*s %*s %*s %d", &fileNameNum);
}
else
{
sscanf(line, " %*s %*s %d", &fileNameNum);
}
this->ReplaceWildcardsHelper(fileName, fileNameNum);
}
else
{
while (strncmp(line, "FILE", 4) != 0)
{
this->ReadLine(line);
}
this->ReadNextDataLine(line);
sscanf(line, " %*s %*s %d", &cmpFileSet);
while (cmpFileSet != fileSet)
{
this->ReadNextDataLine(line);
this->ReadNextDataLine(line);
sscanf(line, " %s", subLine);
if (strncmp(subLine, "filename", 8) == 0)
{
this->ReadNextDataLine(line);
}
sscanf(line, " %*s %*s %d", &cmpFileSet);
}
this->ReadNextDataLine(line);
sscanf(line, " %*s %*s %d", &fileNameNum);
this->ReplaceWildcardsHelper(fileName, fileNameNum);
}
delete this->IS;
this->IS = NULL;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::ReplaceWildcardsHelper(char* fileName, int num)
{
int wildcardPos, numWildcards, numDigits = 1, i;
int tmpNum = num, multTen = 1;
char newChar;
int newNum;
wildcardPos = static_cast<int>(strcspn(fileName, "*"));
numWildcards = static_cast<int>(strspn(fileName + wildcardPos, "*"));
tmpNum /= 10;
while (tmpNum >= 1)
{
numDigits++;
multTen *= 10;
tmpNum /= 10;
}
for (i = 0; i < numWildcards - numDigits; i++)
{
fileName[i + wildcardPos] = '0';
}
tmpNum = num;
for (i = numWildcards - numDigits; i < numWildcards; i++)
{
newNum = tmpNum / multTen;
switch (newNum)
{
case 0:
newChar = '0';
break;
case 1:
newChar = '1';
break;
case 2:
newChar = '2';
break;
case 3:
newChar = '3';
break;
case 4:
newChar = '4';
break;
case 5:
newChar = '5';
break;
case 6:
newChar = '6';
break;
case 7:
newChar = '7';
break;
case 8:
newChar = '8';
break;
case 9:
newChar = '9';
break;
default:
// This case should never be reached.
return;
}
assert( newChar == ('0' + newNum) );
fileName[i + wildcardPos] = newChar;
tmpNum -= multTen * newNum;
multTen /= 10;
}
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetByteOrderToBigEndian()
{
this->ByteOrder = FILE_BIG_ENDIAN;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetByteOrderToLittleEndian()
{
this->ByteOrder = FILE_LITTLE_ENDIAN;
}
//----------------------------------------------------------------------------
const char *vtkGenericEnSightReader::GetByteOrderAsString()
{
if ( this->ByteOrder == FILE_LITTLE_ENDIAN)
{
return "LittleEndian";
}
else
{
return "BigEndian";
}
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::PrintSelf(ostream& os, vtkIndent indent)
{
this->Superclass::PrintSelf(os,indent);
os << indent << "CaseFileName: "
<< (this->CaseFileName ? this->CaseFileName : "(none)") << endl;
os << indent << "FilePath: "
<< (this->FilePath ? this->FilePath : "(none)") << endl;
os << indent << "NumberOfComplexVariables: "
<< this->NumberOfComplexVariables << endl;
os << indent << "NumberOfVariables: "
<< this->NumberOfVariables << endl;
os << indent << "NumberOfComplexScalarsPerNode: "
<< this->NumberOfComplexScalarsPerNode << endl;
os << indent << "NumberOfVectorsPerElement :"
<< this->NumberOfVectorsPerElement << endl;
os << indent << "NumberOfTensorsSymmPerElement: "
<< this->NumberOfTensorsSymmPerElement << endl;
os << indent << "NumberOfComplexVectorsPerNode: "
<< this->NumberOfComplexVectorsPerNode << endl;
os << indent << "NumberOfScalarsPerElement: "
<< this->NumberOfScalarsPerElement << endl;
os << indent << "NumberOfComplexVectorsPerElement: "
<< this->NumberOfComplexVectorsPerElement << endl;
os << indent << "NumberOfComplexScalarsPerElement: "
<< this->NumberOfComplexScalarsPerElement << endl;
os << indent << "NumberOfTensorsSymmPerNode: "
<< this->NumberOfTensorsSymmPerNode << endl;
os << indent << "NumberOfScalarsPerMeasuredNode: "
<< this->NumberOfScalarsPerMeasuredNode << endl;
os << indent << "NumberOfVectorsPerMeasuredNode: "
<< this->NumberOfVectorsPerMeasuredNode << endl;
os << indent << "NumberOfScalarsPerNode: "
<< this->NumberOfScalarsPerNode << endl;
os << indent << "NumberOfVectorsPerNode: "
<< this->NumberOfVectorsPerNode << endl;
os << indent << "TimeValue: " << this->TimeValue << endl;
os << indent << "MinimumTimeValue: " << this->MinimumTimeValue << endl;
os << indent << "MaximumTimeValue: " << this->MaximumTimeValue << endl;
os << indent << "TimeSets: " << this->TimeSets << endl;
os << indent << "ReadAllVariables: " << this->ReadAllVariables << endl;
os << indent << "ByteOrder: " << this->ByteOrder << endl;
os << indent << "CellDataArraySelection: " << this->CellDataArraySelection
<< endl;
os << indent << "PointDataArraySelection: " << this->PointDataArraySelection
<< endl;
}
//----------------------------------------------------------------------------
char** vtkGenericEnSightReader::CreateStringArray(int numStrings)
{
char** strings = new char*[numStrings];
int i;
for(i=0; i < numStrings; ++i)
{
strings[i] = 0;
}
return strings;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::DestroyStringArray(int numStrings,
char** strings)
{
int i;
for(i=0; i < numStrings; ++i)
{
if(strings[i])
{
delete [] strings[i];
}
}
delete[] strings;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetDataArraySelectionSetsFromVariables()
{
int numPointArrays = (this->NumberOfScalarsPerNode +
this->NumberOfVectorsPerNode +
this->NumberOfTensorsSymmPerNode +
this->NumberOfScalarsPerMeasuredNode +
this->NumberOfVectorsPerMeasuredNode +
this->NumberOfComplexScalarsPerNode +
this->NumberOfComplexVectorsPerNode);
int numCellArrays = (this->NumberOfScalarsPerElement +
this->NumberOfVectorsPerElement +
this->NumberOfTensorsSymmPerElement +
this->NumberOfComplexScalarsPerElement +
this->NumberOfComplexVectorsPerElement);
char** pointNames = this->CreateStringArray(numPointArrays);
char** cellNames = this->CreateStringArray(numCellArrays);
int pointArrayCount = 0;
int cellArrayCount = 0;
int i;
for(i=0; i < this->NumberOfVariables; ++i)
{
switch (this->VariableTypes[i])
{
case vtkEnSightReader::SCALAR_PER_NODE:
case vtkEnSightReader::VECTOR_PER_NODE:
case vtkEnSightReader::TENSOR_SYMM_PER_NODE:
case vtkEnSightReader::SCALAR_PER_MEASURED_NODE:
case vtkEnSightReader::VECTOR_PER_MEASURED_NODE:
pointNames[pointArrayCount] =
new char[strlen(this->VariableDescriptions[i])+1];
strcpy(pointNames[pointArrayCount], this->VariableDescriptions[i]);
++pointArrayCount;
break;
case vtkEnSightReader::SCALAR_PER_ELEMENT:
case vtkEnSightReader::VECTOR_PER_ELEMENT:
case vtkEnSightReader::TENSOR_SYMM_PER_ELEMENT:
cellNames[cellArrayCount] =
new char[strlen(this->VariableDescriptions[i])+1];
strcpy(cellNames[cellArrayCount], this->VariableDescriptions[i]);
++cellArrayCount;
break;
}
}
for(i=0; i < this->NumberOfComplexVariables; ++i)
{
switch(this->ComplexVariableTypes[i])
{
case vtkEnSightReader::COMPLEX_SCALAR_PER_NODE:
case vtkEnSightReader::COMPLEX_VECTOR_PER_NODE:
pointNames[pointArrayCount] =
new char[strlen(this->ComplexVariableDescriptions[i])+1];
strcpy(pointNames[pointArrayCount],
this->ComplexVariableDescriptions[i]);
++pointArrayCount;
break;
case vtkEnSightReader::COMPLEX_SCALAR_PER_ELEMENT:
case vtkEnSightReader::COMPLEX_VECTOR_PER_ELEMENT:
cellNames[cellArrayCount] =
new char[strlen(this->ComplexVariableDescriptions[i])+1];
strcpy(cellNames[cellArrayCount],
this->ComplexVariableDescriptions[i]);
++cellArrayCount;
break;
}
}
this->PointDataArraySelection->SetArraysWithDefault(pointNames,
numPointArrays,
this->ReadAllVariables);
this->CellDataArraySelection->SetArraysWithDefault(cellNames,
numCellArrays,
this->ReadAllVariables);
this->DestroyStringArray(numPointArrays, pointNames);
this->DestroyStringArray(numCellArrays, cellNames);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetDataArraySelectionSetsFromReader()
{
this->SelectionModifiedDoNotCallModified = 1;
this->PointDataArraySelection->CopySelections(
this->Reader->GetPointDataArraySelection());
this->CellDataArraySelection->CopySelections(
this->Reader->GetCellDataArraySelection());
this->SelectionModifiedDoNotCallModified = 0;
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetReaderDataArraySelectionSetsFromSelf()
{
// Set the real reader's data array selections from ours.
this->Reader->GetPointDataArraySelection()->CopySelections(
this->PointDataArraySelection);
this->Reader->GetCellDataArraySelection()->CopySelections(
this->CellDataArraySelection);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SelectionModifiedCallback(vtkObject*,
unsigned long,
void* clientdata,
void*)
{
static_cast<vtkGenericEnSightReader*>(clientdata)->SelectionModified();
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SelectionModified()
{
if(!this->SelectionModifiedDoNotCallModified)
{
this->Modified();
}
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetNumberOfPointArrays()
{
return this->PointDataArraySelection->GetNumberOfArrays();
}
//----------------------------------------------------------------------------
const char* vtkGenericEnSightReader::GetPointArrayName(int index)
{
return this->PointDataArraySelection->GetArrayName(index);
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetPointArrayStatus(const char* name)
{
return this->PointDataArraySelection->ArrayIsEnabled(name);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetPointArrayStatus(const char* name, int status)
{
if(status)
{
this->PointDataArraySelection->EnableArray(name);
}
else
{
this->PointDataArraySelection->DisableArray(name);
}
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetNumberOfCellArrays()
{
return this->CellDataArraySelection->GetNumberOfArrays();
}
//----------------------------------------------------------------------------
const char* vtkGenericEnSightReader::GetCellArrayName(int index)
{
return this->CellDataArraySelection->GetArrayName(index);
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::GetCellArrayStatus(const char* name)
{
return this->CellDataArraySelection->ArrayIsEnabled(name);
}
//----------------------------------------------------------------------------
void vtkGenericEnSightReader::SetCellArrayStatus(const char* name, int status)
{
if(status)
{
this->CellDataArraySelection->EnableArray(name);
}
else
{
this->CellDataArraySelection->DisableArray(name);
}
}
//----------------------------------------------------------------------------
int vtkGenericEnSightReader::InsertNewPartId(int partId)
{
int lastId = this->TranslationTable->PartIdMap.size();
this->TranslationTable->PartIdMap.insert(
vtkstd::map<int,int>::value_type(partId, lastId));
lastId = this->TranslationTable->PartIdMap[partId];
//assert( lastId == this->PartIdTranslationTable[partId] );
return lastId;
}