VTK  9.0.1
vtkXMLCompositeDataWriter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: ParaView
4  Module: vtkXMLCompositeDataWriter.h
5 
6  Copyright (c) Kitware, Inc.
7  All rights reserved.
8  See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
26 #ifndef vtkXMLCompositeDataWriter_h
27 #define vtkXMLCompositeDataWriter_h
28 
29 #include "vtkIOXMLModule.h" // For export macro
30 #include "vtkStdString.h" // needed for vtkStdString.
31 #include "vtkXMLWriter.h"
32 
33 class vtkCallbackCommand;
35 class vtkXMLDataElement;
36 class vtkXMLCompositeDataWriterInternals;
37 
38 class VTKIOXML_EXPORT vtkXMLCompositeDataWriter : public vtkXMLWriter
39 {
40 public:
42  void PrintSelf(ostream& os, vtkIndent indent) override;
43 
47  const char* GetDefaultFileExtension() override;
48 
57  vtkGetMacro(GhostLevel, int);
58  vtkSetMacro(GhostLevel, int);
60 
62 
65  vtkGetMacro(WriteMetaFile, int);
66  virtual void SetWriteMetaFile(int flag);
68 
74 
75 protected:
78 
84  int GetDataSetMajorVersion() override { return 1; }
85  int GetDataSetMinorVersion() override { return 0; }
86 
91 
92  // see algorithm for more info
94 
97 
98  int WriteData() override;
99  const char* GetDataSetName() override;
100 
101  // Create a default executive.
103 
105 
110 
114  unsigned int GetNumberOfDataTypes();
115 
120 
121  // Methods to create the set of writers matching the set of inputs.
124 
125  // Methods to help construct internal file names.
127  const char* GetFilePrefix();
128  const char* GetFilePath();
129 
134  const char* GetDefaultFileExtensionForDataSet(int dataset_type);
135 
142 
143  // Make a directory.
144  void MakeDirectory(const char* name);
145 
146  // Remove a directory.
147  void RemoveADirectory(const char* name);
148 
149  // Internal implementation details.
150  vtkXMLCompositeDataWriterInternals* Internal;
151 
152  // The number of ghost levels to write for unstructured data.
154 
161 
162  // Callback registered with the InternalProgressObserver.
163  static void ProgressCallbackFunction(vtkObject*, unsigned long, void*, void*);
164  // Progress callback from internal writer.
165  virtual void ProgressCallback(vtkAlgorithm* w);
166 
167  // The observer to report progress from the internal writer.
169 
179  virtual int WriteComposite(
180  vtkCompositeDataSet* compositeData, vtkXMLDataElement* element, int& writerIdx) = 0;
181 
193  vtkDataObject* dObj, vtkXMLDataElement* element, int& writerIdx, const char* fileName);
194 
199  virtual void RemoveWrittenFiles(const char* SubDirectory);
200 
201 private:
203  void operator=(const vtkXMLCompositeDataWriter&) = delete;
204 };
205 
206 #endif
vtkStdString.h
vtkXMLCompositeDataWriter::FillDataTypes
virtual void FillDataTypes(vtkCompositeDataSet *)
Determine the data types for each of the leaf nodes.
vtkXMLCompositeDataWriter::vtkXMLCompositeDataWriter
vtkXMLCompositeDataWriter()
vtkXMLCompositeDataWriter::ProcessRequest
vtkTypeBool ProcessRequest(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
See the vtkAlgorithm for a description of what these do.
vtkXMLCompositeDataWriter::WriteMetaFile
int WriteMetaFile
Whether to write the collection file on this node.
Definition: vtkXMLCompositeDataWriter.h:160
vtx::types::Piece
std::map< DataSetType, DataSet > Piece
Definition: VTXTypes.h:54
vtkXMLCompositeDataWriter::RemoveWrittenFiles
virtual void RemoveWrittenFiles(const char *SubDirectory)
Utility function to remove any already written files in case writer failed.
vtkXMLCompositeDataWriter::WriteMetaFileIfRequested
int WriteMetaFileIfRequested()
Write the collection file if it is requested.
vtkXMLCompositeDataWriter::SplitFileName
void SplitFileName()
vtkXMLCompositeDataWriter::GetWriter
vtkXMLWriter * GetWriter(int index)
vtkAlgorithm
Superclass for all sources, filters, and sinks in VTK.
Definition: vtkAlgorithm.h:54
vtkXMLCompositeDataWriter::InternalProgressObserver
vtkCallbackCommand * InternalProgressObserver
Definition: vtkXMLCompositeDataWriter.h:168
vtkInformationVector
Store zero or more vtkInformation instances.
Definition: vtkInformationVector.h:36
vtkXMLCompositeDataWriter::CreateDefaultExecutive
vtkExecutive * CreateDefaultExecutive() override
Create a default executive.
vtkXMLWriter.h
vtkObject
abstract base class for most VTK objects
Definition: vtkObject.h:54
vtkXMLCompositeDataWriter::ProgressCallbackFunction
static void ProgressCallbackFunction(vtkObject *, unsigned long, void *, void *)
vtkXMLCompositeDataWriter::RequestData
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
vtkXMLCompositeDataWriter::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkCompositeDataSet
abstract superclass for composite (multi-block or AMR) datasets
Definition: vtkCompositeDataSet.h:46
vtkXMLCompositeDataWriter::CreatePieceFileName
vtkStdString CreatePieceFileName(int Piece)
Create a filename for the given index.
vtkX3D::port
@ port
Definition: vtkX3D.h:453
vtkExecutive
Superclass for all pipeline executives in VTK.
Definition: vtkExecutive.h:47
vtkXMLCompositeDataWriter::RemoveADirectory
void RemoveADirectory(const char *name)
vtkXMLCompositeDataWriter::GetDefaultFileExtensionForDataSet
const char * GetDefaultFileExtensionForDataSet(int dataset_type)
Returns the default extension to use for the given dataset type.
vtkXMLWriter
Superclass for VTK's XML file writers.
Definition: vtkXMLWriter.h:62
vtkXMLCompositeDataWriter::WriteData
int WriteData() override
vtkXMLCompositeDataWriter::GetDataSetMinorVersion
int GetDataSetMinorVersion() override
Definition: vtkXMLCompositeDataWriter.h:85
vtkXMLCompositeDataWriter::GhostLevel
int GhostLevel
Definition: vtkXMLCompositeDataWriter.h:153
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:34
vtkXMLCompositeDataWriter::GetDataSetName
const char * GetDataSetName() override
vtkXMLCompositeDataWriter::RequestUpdateExtent
int RequestUpdateExtent(vtkInformation *, vtkInformationVector **, vtkInformationVector *)
vtkXMLCompositeDataWriter::Internal
vtkXMLCompositeDataWriterInternals * Internal
Definition: vtkXMLCompositeDataWriter.h:150
vtkXMLDataElement
Represents an XML element and those nested inside.
Definition: vtkXMLDataElement.h:37
vtkXMLCompositeDataWriter::GetFilePath
const char * GetFilePath()
vtkX3D::name
@ name
Definition: vtkX3D.h:225
vtkXMLCompositeDataWriter::GetDataSetMajorVersion
int GetDataSetMajorVersion() override
Methods to define the file's major and minor version numbers.
Definition: vtkXMLCompositeDataWriter.h:84
vtkXMLCompositeDataWriter::WriteNonCompositeData
virtual int WriteNonCompositeData(vtkDataObject *dObj, vtkXMLDataElement *element, int &writerIdx, const char *fileName)
Internal method to write a non vtkCompositeDataSet subclass as well as add in the file name to the me...
vtkXMLCompositeDataWriter::CreateWriters
void CreateWriters(vtkCompositeDataSet *)
vtkXMLCompositeDataWriter::GetDefaultFileExtension
const char * GetDefaultFileExtension() override
Get the default file extension for files written by this writer.
vtkXMLCompositeDataWriter::GetDataTypesPointer
int * GetDataTypesPointer()
Returns the array pointer to the array of leaf nodes.
vtkInformation
Store vtkAlgorithm input/output information.
Definition: vtkInformation.h:65
vtkX3D::info
@ info
Definition: vtkX3D.h:382
vtkXMLCompositeDataWriter::FillInputPortInformation
int FillInputPortInformation(int port, vtkInformation *info) override
Fill the input port information objects for this algorithm.
vtkXMLCompositeDataWriter::SetWriteMetaFile
virtual void SetWriteMetaFile(int flag)
vtkCallbackCommand
supports function callbacks
Definition: vtkCallbackCommand.h:45
vtkStdString
Wrapper around std::string to keep symbols short.
Definition: vtkStdString.h:35
vtkXMLCompositeDataWriter::GetNumberOfDataTypes
unsigned int GetNumberOfDataTypes()
Returns the number of leaf nodes (also includes empty leaf nodes).
vtkXMLCompositeDataWriter::MakeDirectory
void MakeDirectory(const char *name)
vtkDataObject
general representation of visualization data
Definition: vtkDataObject.h:60
vtkXMLCompositeDataWriter
Writer for multi-group datasets.
Definition: vtkXMLCompositeDataWriter.h:39
vtkX3D::index
@ index
Definition: vtkX3D.h:252
vtkXMLCompositeDataWriter::WriteComposite
virtual int WriteComposite(vtkCompositeDataSet *compositeData, vtkXMLDataElement *element, int &writerIdx)=0
Internal method called recursively to create the xml tree for the children of compositeData as well a...
vtkXMLCompositeDataWriter::~vtkXMLCompositeDataWriter
~vtkXMLCompositeDataWriter() override
vtkTypeBool
int vtkTypeBool
Definition: vtkABI.h:69
vtkXMLCompositeDataWriter::InputInformation
vtkInformation * InputInformation
Definition: vtkXMLCompositeDataWriter.h:104
vtkXMLCompositeDataWriter::GetFilePrefix
const char * GetFilePrefix()
vtkXMLCompositeDataWriter::ProgressCallback
virtual void ProgressCallback(vtkAlgorithm *w)