VTK
vtkXMLDataElement.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkXMLDataElement.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm 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 =========================================================================*/
28 #ifndef vtkXMLDataElement_h
29 #define vtkXMLDataElement_h
30 
31 #include "vtkCommonDataModelModule.h" // For export macro
32 #include "vtkObject.h"
33 
34 class vtkXMLDataParser;
35 
36 class VTKCOMMONDATAMODEL_EXPORT vtkXMLDataElement : public vtkObject
37 {
38 public:
40  void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
41  static vtkXMLDataElement* New();
42 
44 
47  vtkGetStringMacro(Name);
48  virtual void SetName (const char* _arg);
50 
52 
56  vtkSetStringMacro(Id);
58 
63  const char* GetAttribute(const char* name);
64 
69  void SetAttribute(const char* name, const char* value);
70 
72 
75  void SetCharacterData(const char* c, int length);
76  void AddCharacterData(const char* c, size_t length);
77  vtkGetStringMacro(CharacterData);
79 
81 
85  int GetScalarAttribute(const char* name, int& value);
86  int GetScalarAttribute(const char* name, float& value);
87  int GetScalarAttribute(const char* name, double& value);
88  int GetScalarAttribute(const char* name, long& value);
89  int GetScalarAttribute(const char* name, unsigned long& value);
91 
93 
99  void SetIntAttribute(const char* name, int value);
100  void SetFloatAttribute(const char* name, float value);
101  void SetDoubleAttribute(const char* name, double value);
102  void SetUnsignedLongAttribute(const char* name, unsigned long value);
104 
106 
110  int GetVectorAttribute(const char* name, int length, int* value);
111  int GetVectorAttribute(const char* name, int length, float* value);
112  int GetVectorAttribute(const char* name, int length, double* value);
113  int GetVectorAttribute(const char* name, int length, long* value);
114  int GetVectorAttribute(const char* name, int length, unsigned long* value);
116 
118 
121  void SetVectorAttribute(const char* name, int length, const int* value);
122  void SetVectorAttribute(const char* name, int length, const float* value);
123  void SetVectorAttribute(const char* name, int length, const double* value);
124  void SetVectorAttribute(const char* name, int length, const unsigned long* value);
126 
127  int GetScalarAttribute(const char* name, long long& value);
128  int GetVectorAttribute(const char* name, int length, long long* value);
129  void SetVectorAttribute(const char* name, int length, long long const* value);
130  int GetScalarAttribute(const char* name, unsigned long long& value);
131  int GetVectorAttribute(const char* name, int length, unsigned long long* value);
132  void SetVectorAttribute(const char* name, int length, unsigned long long const* value);
133 
138  int GetWordTypeAttribute(const char* name, int& value);
139 
141 
144  vtkGetMacro(NumberOfAttributes, int);
146 
151  const char* GetAttributeName(int idx);
152 
157  const char* GetAttributeValue(int idx);
158 
160 
163  virtual void RemoveAttribute(const char *name);
164  virtual void RemoveAllAttributes();
166 
168 
171  vtkXMLDataElement* GetParent();
172  void SetParent(vtkXMLDataElement* parent);
174 
178  virtual vtkXMLDataElement* GetRoot();
179 
183  int GetNumberOfNestedElements();
184 
188  vtkXMLDataElement* GetNestedElement(int index);
189 
193  void AddNestedElement(vtkXMLDataElement* element);
194 
198  virtual void RemoveNestedElement(vtkXMLDataElement *);
199 
203  virtual void RemoveAllNestedElements();
204 
206 
212  vtkXMLDataElement* FindNestedElement(const char* id);
213  vtkXMLDataElement* FindNestedElementWithName(const char* name);
214  vtkXMLDataElement* FindNestedElementWithNameAndId(
215  const char* name, const char* id);
216  vtkXMLDataElement* FindNestedElementWithNameAndAttribute(
217  const char* name, const char* att_name, const char* att_value);
219 
224  vtkXMLDataElement* LookupElementWithName(const char* name);
225 
229  vtkXMLDataElement* LookupElement(const char* id);
230 
232 
235  vtkGetMacro(XMLByteIndex, vtkTypeInt64);
236  vtkSetMacro(XMLByteIndex, vtkTypeInt64);
238 
246  virtual int IsEqualTo(vtkXMLDataElement *elem);
247 
254  virtual void DeepCopy(vtkXMLDataElement *elem);
255 
257 
265  vtkSetClampMacro(AttributeEncoding,int,VTK_ENCODING_NONE,VTK_ENCODING_UNKNOWN);
266  vtkGetMacro(AttributeEncoding, int);
268 
270 
273  void PrintXML(ostream& os, vtkIndent indent);
274  void PrintXML(const char* fname);
276 
278 
286  vtkGetMacro(CharacterDataWidth,int);
287  vtkSetMacro(CharacterDataWidth,int);
289 
290 protected:
292  ~vtkXMLDataElement() VTK_OVERRIDE;
293 
294  // The name of the element from the XML file.
295  char* Name;
296  // The value of the "id" attribute, if any was given.
297  char* Id;
298 
299  int CharacterDataWidth;
300 
301  // Data inside of the tag's open and close. ie <X> character data </X>
302  char* CharacterData; // Null terminated buffer.
303  size_t CharacterDataBlockSize; // Allocation size if buffer needs expand
304  size_t CharacterDataBufferSize; // Allocated size.
305  size_t EndOfCharacterData; // Number of bytes used.
306 
307  // Tags that have specialized character data handlers
308  // can set this flag to improve performance. The default is unset.
309  int IgnoreCharacterData;
310 
311  // Get/Set the stream position of the elements inline data.
312  vtkGetMacro(InlineDataPosition,vtkTypeInt64);
313  vtkSetMacro(InlineDataPosition,vtkTypeInt64);
314  // The offset into the XML stream where the inline data begins.
315  vtkTypeInt64 InlineDataPosition;
316  // The offset into the XML stream where the element begins.
317  vtkTypeInt64 XMLByteIndex;
318 
319  // The raw property name/value pairs read from the XML attributes.
320  char** AttributeNames;
321  char** AttributeValues;
322  int NumberOfAttributes;
323  int AttributesSize;
324  int AttributeEncoding;
325 
326  // The set of nested elements.
327  int NumberOfNestedElements;
328  int NestedElementsSize;
329  vtkXMLDataElement** NestedElements;
330  // The parent of this element.
332 
333  // Internal utility methods.
334  vtkXMLDataElement* LookupElementInScope(const char* id);
335  vtkXMLDataElement* LookupElementUpScope(const char* id);
336  static int IsSpace(char c);
337  void PrintCharacterData(ostream &os,vtkIndent indent);
338  static void PrintWithEscapedData(ostream& os, const char* data);
339 
340  friend class vtkXMLDataParser;
341  friend class vtkXMLMaterialParser;
342 
343 private:
344  vtkXMLDataElement(const vtkXMLDataElement&) VTK_DELETE_FUNCTION;
345  void operator=(const vtkXMLDataElement&) VTK_DELETE_FUNCTION;
346 };
347 
348 //----------------------------------------------------------------------------
349 inline
350 void vtkXMLDataElement::AddCharacterData(const char* data, size_t length)
351 {
352  if (this->IgnoreCharacterData){ return; }
353  // This is the index where we start to put the new data at.
354  size_t eod=this->EndOfCharacterData-1;
355  // Check if the new data will write off the end. If it does
356  // resize the character data buffer.
357  this->EndOfCharacterData+=length;
358  if (this->EndOfCharacterData>=this->CharacterDataBufferSize)
359  {
360  while(this->EndOfCharacterData>=this->CharacterDataBufferSize)
361  {
362  this->CharacterDataBufferSize+=this->CharacterDataBlockSize;
363  }
364  this->CharacterData
365  = static_cast<char *>(realloc(this->CharacterData,this->CharacterDataBufferSize));
366  }
367  // put the new data at the end of the buffer, and null terminate.
368  char *pCD=this->CharacterData+eod;
369  memmove(pCD,data,length);
370  pCD[length]='\0';
371  return;
372 }
373 
374 #endif
abstract base class for most VTK objects
Definition: vtkObject.h:59
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
Represents an XML element and those nested inside.
void DeepCopy(vtkPistonReference *self, vtkPistonReference *other)
#define VTK_ENCODING_UNKNOWN
a simple class to control print indentation
Definition: vtkIndent.h:39
#define VTK_ENCODING_NONE
vtkGetStringMacro(ExtensionsString)
Returns a string listing all available extensions.
vtkSetMacro(IgnoreDriverBugs, bool)
When set known driver bugs are ignored during driver feature detection.
Used by vtkXMLReader to parse VTK XML files.
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on...