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
|
/*=========================================================================
Program: ParaView
Module: vtkCommandOptionsXMLParser.h
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.
=========================================================================*/
/**
* @class vtkCommandOptionsXMLParser
* @brief ParaView options storage
*
* An object of this class represents a storage for ParaView options
*
* These options can be retrieved during run-time, set using configuration file
* or using Command Line Arguments.
*/
#ifndef vtkCommandOptionsXMLParser_h
#define vtkCommandOptionsXMLParser_h
#include "vtkCommandOptions.h" // for enum
#include "vtkPVCommonModule.h" // needed for export macro
#include "vtkXMLParser.h"
class vtkCommandOptionsXMLParserInternal;
class vtkCommandOptions;
class VTKPVCOMMON_EXPORT vtkCommandOptionsXMLParser : public vtkXMLParser
{
public:
static vtkCommandOptionsXMLParser* New();
vtkTypeMacro(vtkCommandOptionsXMLParser, vtkXMLParser);
void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
//@{
/**
* Add arguments to the xml parser. These should be the
* long arguments from the vtkCommandOptions class of the form
* --foo, and pass in the variable that needs to be set with the value.
*/
void AddBooleanArgument(const char* longarg, int* var, int type = 0);
void AddArgument(const char* longarg, int* var, int type = 0);
void AddArgument(const char* longarg, char** var, int type = 0);
void SetPVOptions(vtkCommandOptions* o) { this->PVOptions = o; }
protected:
//@}
/**
* Default constructor.
*/
vtkCommandOptionsXMLParser();
/**
* Destructor.
*/
virtual ~vtkCommandOptionsXMLParser();
// Called when a new element is opened in the XML source. Should be
// replaced by subclasses to handle each element.
// name = Name of new element.
// atts = Null-terminated array of attribute name/value pairs.
// Even indices are attribute names, and odd indices are values.
virtual void StartElement(const char* name, const char** atts) VTK_OVERRIDE;
// Called at the end of an element in the XML source opened when
// StartElement was called.
virtual void EndElement(const char* name) VTK_OVERRIDE;
// Call to process the .. of <Option>...</>
void HandleOption(const char** atts);
// Call to process the .. of <Option>...</>
void HandleProcessType(const char** atts);
virtual void SetProcessType(const char* ptype);
void SetProcessTypeInt(int ptype);
private:
vtkCommandOptionsXMLParser(const vtkCommandOptionsXMLParser&) VTK_DELETE_FUNCTION;
void operator=(const vtkCommandOptionsXMLParser&) VTK_DELETE_FUNCTION;
int InPVXTag;
vtkCommandOptions* PVOptions;
vtkCommandOptionsXMLParserInternal* Internals;
};
#endif // #ifndef vtkCommandOptionsXMLParser_h
|