added limited support for COLLADA_DOM. Will need to add jam/msvcgen build support.
This commit is contained in:
135
Extras/COLLADA_DOM/include/dae/domAny.h
Normal file
135
Extras/COLLADA_DOM/include/dae/domAny.h
Normal file
@@ -0,0 +1,135 @@
|
||||
/*
|
||||
* Copyright 2006 Sony Computer Entertainment Inc.
|
||||
*
|
||||
* Licensed under the SCEA Shared Source License, Version 1.0 (the "License"); you may not use this
|
||||
* file except in compliance with the License. You may obtain a copy of the License at:
|
||||
* http://research.scea.com/scea_shared_source_license.html
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software distributed under the License
|
||||
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
* implied. See the License for the specific language governing permissions and limitations under the
|
||||
* License.
|
||||
*/
|
||||
#ifndef __domAny_h__
|
||||
#define __domAny_h__
|
||||
|
||||
#include <dae/daeElement.h>
|
||||
#include <dae/daeMetaElement.h>
|
||||
#include <dae/daeArray.h>
|
||||
#include <dae/daeURI.h>
|
||||
#include <dae/daeIDRef.h>
|
||||
|
||||
#define MAX_ATTRIBUTES 32
|
||||
|
||||
/**
|
||||
* The domAny class allows for weakly typed xml elements. This class is used anywhere in the
|
||||
* COLLADA schema where an xs:any element appears. The content and type information for a domAny
|
||||
* object is generated at runtime.
|
||||
*/
|
||||
class domAny : public daeElement
|
||||
{
|
||||
protected: // Attribute
|
||||
|
||||
/**
|
||||
* The array of daeStrings to hold attribute data for this element.
|
||||
*/
|
||||
daeString attrs[MAX_ATTRIBUTES];
|
||||
/**
|
||||
* The domString value of the text data of this element.
|
||||
*/
|
||||
daeString _value;
|
||||
/**
|
||||
* Used to preserve order in elements that do not specify strict sequencing of sub-elements.
|
||||
*/
|
||||
daeElementRefArray _contents;
|
||||
|
||||
public:
|
||||
/**
|
||||
* Gets the _contents array.
|
||||
* @return Returns a reference to the _contents element array.
|
||||
*/
|
||||
daeElementRefArray &getContents() { return _contents; }
|
||||
/**
|
||||
* Gets the _contents array.
|
||||
* @return Returns a constant reference to the _contents element array.
|
||||
*/
|
||||
const daeElementRefArray &getContents() const { return _contents; }
|
||||
|
||||
/**
|
||||
* Gets the number of attributes this element has.
|
||||
* @return Returns the number of attributes on this element.
|
||||
*/
|
||||
daeUInt getAttributeCount() const { return (daeUInt)_meta->getMetaAttributes().getCount(); }
|
||||
/**
|
||||
* Gets an attribute's name.
|
||||
* @param index The index into the attribute list.
|
||||
* @return Returns the attribute's name.
|
||||
*/
|
||||
daeString getAttributeName( daeUInt index ) const { return _meta->getMetaAttributes()[index]->getName(); }
|
||||
/**
|
||||
* Gets an attribute's value.
|
||||
* @param index The index into the attribute list.
|
||||
* @return Returns the attribute's value as a string.
|
||||
*/
|
||||
daeString getAttributeValue( daeUInt index ) const { return attrs[ index ]; }
|
||||
/**
|
||||
* Gets the value of this element.
|
||||
* @return Returns a daeString of the value.
|
||||
*/
|
||||
daeString getValue() const { return _value; }
|
||||
/**
|
||||
* Sets the _value of this element.
|
||||
* @param val The new value for this element.
|
||||
*/
|
||||
void setValue( daeString val ) { _value = val; }
|
||||
|
||||
protected:
|
||||
/**
|
||||
* Constructor
|
||||
*/
|
||||
domAny() : _value() {}
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
virtual ~domAny() {}
|
||||
/**
|
||||
* Copy Constructor
|
||||
*/
|
||||
domAny( const domAny &cpy ) : daeElement() { (void)cpy; }
|
||||
/**
|
||||
* Overloaded assignment operator
|
||||
*/
|
||||
virtual domAny &operator=( const domAny &cpy ) { (void)cpy; return *this; }
|
||||
|
||||
public: //METHODS
|
||||
/**
|
||||
* Override of the Base class method. Creates and registers an attribute field with its meta
|
||||
* and assigns its value as the <tt><i> attrValue </i></tt> String.
|
||||
* @param attrName Attribute to set.
|
||||
* @param attrValue String-based value to apply to the attribute.
|
||||
* @return Returns true if the attribute was created and the value was set, false otherwise.
|
||||
*/
|
||||
virtual daeBool setAttribute(daeString attrName, daeString attrValue);
|
||||
|
||||
public: // STATIC METHODS
|
||||
/**
|
||||
* Creates an instance of this class and returns a daeElementRef referencing it.
|
||||
* @param bytes The size allocated for this instance.
|
||||
* @return a daeElementRef referencing an instance of this object.
|
||||
*/
|
||||
static daeElementRef create(daeInt bytes);
|
||||
/**
|
||||
* Creates a daeMetaElement object that describes this element in the meta object reflection framework.
|
||||
* @return A daeMetaElement describing this COLLADA element.
|
||||
* @remarks Unlike other dom* elements, domAny will always create a new daeMetaElement when this
|
||||
* function is called.
|
||||
*/
|
||||
static daeMetaElement* registerElement();
|
||||
|
||||
};
|
||||
|
||||
typedef daeSmartRef<domAny> domAnyRef;
|
||||
typedef daeTArray<domAnyRef> domAny_Array;
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user