/usr/include/InsightToolkit/IO/itkXMLFile.h is in libinsighttoolkit3-dev 3.20.1+git20120521-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkXMLFile.h
Language: C++
Date: $Date$
Version: $1.0$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/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 notices for more information.
=========================================================================*/
#ifndef __itkXMLFile_h
#define __itkXMLFile_h
#include "itkLightProcessObject.h"
#include "expat.h"
#include <fstream>
namespace itk
{
/** \class XMLReaderBase
* XMLReaderBase encapsulates the expat library (Insight/Utilities/expat
* and defines the methods needed in a derived class to receive the
* contents of an XML file in a structured manner. It's 'impure virtual'
* in that some functions that are generic to opening and parsing a file
* are implemented here.
*/
class
XMLReaderBase : public LightProcessObject
{
public:
typedef XMLReaderBase Self;
/** Set the filename to write */
itkSetStringMacro(Filename);
/** Get the filename to write */
itkGetStringMacro(Filename);
/** determine whether a file can be opened and read */
virtual int CanReadFile(const char* name) = 0;
/** do the actual parsing of the input file */
virtual void GenerateOutputInformation();
/** Callback function -- called from XML parser with start-of-element
* information.
*/
virtual void StartElement(const char * name,const char **atts) = 0;
/** Callback function -- called from XML parser when ending tag
* encountered
*/
virtual void EndElement(const char *name) = 0;
/** Callback function -- called from XML parser with the character data
* for an XML element
*/
virtual void CharacterDataHandler(const char *inData, int inLength) = 0;
protected:
XMLReaderBase() {};
virtual ~XMLReaderBase() {};
/** Instantiates and invokes the XML parser for the file named by
* m_Filename. The parser will throw an exception in the case of XML
* syntax errors, missing filenames, unreadable input file, etc.
*/
void parse(void);
std::string m_Filename;
private:
XMLReaderBase(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
};
/** \class XMLReader -- template base class for an XMLReader
* It's purpose really is just to define the simple interface for
* extracting the object resulting from reading the XML File.
* Since it doesn't define any of the pure virtual methods in XMLReaderBase,
* It can't be instantiated by itself
*/
template <class T> class
XMLReader : public XMLReaderBase
{
public:
typedef XMLReader Self;
/** Set the output object. Doesn't make sense for a client of the XMLReader,
* but could be used in derived class to assign pointer to result object.
*/
void SetOutputObject(T *obj) { m_OutputObject = obj; }
/** Get the output object, after an XML File has been successfully parsed.
*/
T *GetOutputObject(void) { return m_OutputObject; }
protected:
XMLReader() {};
virtual ~XMLReader() {};
T *m_OutputObject;
private:
XMLReader(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
};
/** \class XMLWriterBase
*
* 'Impure virtual' base class for XML File writing.
* Defines the interface for an XML file writer and provides
* a few utility functions for writing XML files. A derived
* class needs to implement writing the file completely by
* implementing WriteFile.
*/
template <class T>
class XMLWriterBase : public LightProcessObject
{
public:
typedef XMLWriterBase Self;
/** Constructor
* Sets object pointer to zero.
*/
XMLWriterBase()
{
m_InputObject = 0;
}
/** Set the filename to write */
itkSetStringMacro(Filename);
/** Get the filename to write */
itkGetStringMacro(Filename);
/** Return non-zero if the filename given is writeable. */
virtual int CanWriteFile(const char* name) = 0;
/** Give a pointer to the object to be written out to an XML file. */
void SetObject(T *toWrite) { m_InputObject = toWrite; }
/** Write the XML file, based on the Input Object */
virtual int WriteFile() = 0;
/** Write out a start element tag */
void WriteStartElement(const char *const tag,std::ofstream &file)
{
file << '<' << tag << '>';
}
/** Write an end element tag */
void WriteEndElement(const char *const tag,std::ofstream &file)
{
file << '<' << '/' << tag << '>';
}
/** Write character data inside a tag. */
void WriteCharacterData(const char *const data,std::ofstream &file)
{
file << data;
}
/** Write a start element tag */
void WriteStartElement(std::string &tag,std::ofstream &file)
{
WriteStartElement(tag.c_str(),file);
}
/** Write an end element tag */
void WriteEndElement(std::string &tag,std::ofstream &file)
{
WriteEndElement(tag.c_str(),file);
}
/** Write character data inside a tag. */
void WriteCharacterData(std::string &data,std::ofstream &file)
{
WriteCharacterData(data.c_str(),file);
}
protected:
T *m_InputObject; // object to write out to an XML file
std::string m_Filename; // name of file to write.
private:
XMLWriterBase(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
};
}
#endif
|