You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

80 lines
2.7 KiB
C++

/*=========================================================================
Program: Visualization Toolkit
Module: vtkXMLPUniformGridAMRWriter.h
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.
=========================================================================*/
/**
* @class vtkXMLPUniformGridAMRWriter
* @brief parallel writer for
* vtkUniformGridAMR and subclasses.
*
* vtkXMLPCompositeDataWriter writes (in parallel or serially) vtkUniformGridAMR
* and subclasses. When running in parallel all processes are expected to have
* the same meta-data (i.e. amr-boxes, structure, etc.) however they may now
* have the missing data-blocks. This class extends
* vtkXMLUniformGridAMRWriter to communicate information about data blocks
* to the root node so that the root node can write the XML file describing the
* structure correctly.
*/
#ifndef vtkXMLPUniformGridAMRWriter_h
#define vtkXMLPUniformGridAMRWriter_h
#include "vtkIOParallelXMLModule.h" // For export macro
#include "vtkXMLUniformGridAMRWriter.h"
class vtkMultiProcessController;
class VTKIOPARALLELXML_EXPORT vtkXMLPUniformGridAMRWriter : public vtkXMLUniformGridAMRWriter
{
public:
static vtkXMLPUniformGridAMRWriter* New();
vtkTypeMacro(vtkXMLPUniformGridAMRWriter, vtkXMLUniformGridAMRWriter);
void PrintSelf(ostream& os, vtkIndent indent) override;
//@{
/**
* Controller used to communicate data type of blocks.
* By default, the global controller is used. If you want another
* controller to be used, set it with this.
* If no controller is set, only the local blocks will be written
* to the meta-file.
*/
virtual void SetController(vtkMultiProcessController*);
vtkGetObjectMacro(Controller, vtkMultiProcessController);
//@}
/**
* Set whether this instance will write the meta-file. WriteMetaFile
* is set to flag only on process 0 and all other processes have
* WriteMetaFile set to 0 by default.
*/
void SetWriteMetaFile(int flag) override;
protected:
vtkXMLPUniformGridAMRWriter();
~vtkXMLPUniformGridAMRWriter() override;
/**
* Overridden to reduce information about data-types across all processes.
*/
void FillDataTypes(vtkCompositeDataSet*) override;
vtkMultiProcessController* Controller;
private:
vtkXMLPUniformGridAMRWriter(const vtkXMLPUniformGridAMRWriter&) = delete;
void operator=(const vtkXMLPUniformGridAMRWriter&) = delete;
};
#endif