/usr/include/collada-dom2.4/modules/daeLIBXMLPlugin.h is in libcollada-dom2.4-dp-dev 2.4.4+ds1-2build3.
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 | /*
* Copyright 2006 Sony Computer Entertainment Inc.
*
* Licensed under the MIT Open Source License, for details please see license.txt or the website
* http://www.opensource.org/licenses/mit-license.php
*
*/
#ifndef __DAE_LIBXMLPLUGIN__
#define __DAE_LIBXMLPLUGIN__
#include <vector>
#include <dae/daeElement.h>
#include <dae/daeURI.h>
#include <dae/daeIOPluginCommon.h>
struct _xmlTextReader;
struct _xmlTextWriter;
class DAE;
/**
* The @c daeLIBXMLPlugin class derives from @c daeIOPluginCommon and implements an XML
* input/output backend using libxml2 as a parser. When using this plugin, DAE::load() expects
* an rfc 2396 compliant URI, any URI supported by libxml2 should be properly
* handled including ones with network schemes and authority. If the URI contains a fragment it will be ignored
* and the entire referenced document will be loaded. DAE::saveAs will only
* handle a filename path at present (ie: no scheme or authority).
*/
class DLLSPEC daeLIBXMLPlugin : public daeIOPluginCommon
{
public:
// Constructor / destructor
/**
* Constructor.
*/
daeLIBXMLPlugin(DAE& dae);
/**
* Destructor.
*/
virtual ~daeLIBXMLPlugin();
// Operations
virtual daeInt write(const daeURI& name, daeDocument *document, daeBool replace);
/**
* setOption allows you to set options for this IOPlugin. Which options a plugin supports is
* dependent on the plugin itself. There is currently no list of options that plugins are
* suggested to implement. daeLibXML2Plugin supports only one option, "saveRawBinary". Set to
* "true" to save float_array data as a .raw binary file. The daeRawResolver will convert the
* data back into COLLADA domFloat_array elements upon load.
* @param option The option to set.
* @param value The value to set the option.
* @return Returns DAE_OK upon success.
*/
virtual daeInt setOption( daeString option, daeString value );
/**
* getOption retrieves the value of an option from this IOPlugin. Which options a plugin supports is
* dependent on the plugin itself.
* @param option The option to get.
* @return Returns the string value of the option or NULL if option is not valid.
*/
virtual daeString getOption( daeString option );
private:
DAE& dae;
_xmlTextWriter *writer;
FILE *rawFile;
unsigned long rawByteCount;
daeURI rawRelPath;
bool saveRawFile;
virtual daeElementRef readFromFile(const daeURI& uri);
virtual daeElementRef readFromMemory(daeString buffer, const daeURI& baseUri);
daeElementRef read(_xmlTextReader* reader);
daeElementRef readElement(_xmlTextReader* reader,
daeElement* parentElement,
/* out */ int& readRetVal);
void writeElement( daeElement* element );
void writeAttribute( daeMetaAttribute* attr, daeElement* element);
void writeValue(daeElement* element);
void writeRawSource( daeElement* src );
};
#endif //__DAE_LIBXMLPLUGIN__
|