added limited support for COLLADA_DOM. Will need to add jam/msvcgen build support.
This commit is contained in:
315
Extras/COLLADA_DOM/include/dae/daeIDRef.h
Normal file
315
Extras/COLLADA_DOM/include/dae/daeIDRef.h
Normal file
@@ -0,0 +1,315 @@
|
||||
/*
|
||||
* 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 __DAE_IDREF_H__
|
||||
#define __DAE_IDREF_H__
|
||||
|
||||
#include <dae/daeTypes.h>
|
||||
#include <dae/daeElement.h>
|
||||
|
||||
/**
|
||||
* The @c daeIDRef is a simple class designed to aid in the parsing and resolution of
|
||||
* ID references inside of COLLADA elements.
|
||||
* A @c daeIDRef is created for every IDREF data type in the COLLADA schema.
|
||||
* It also has the capability to attempt to resolve this reference
|
||||
* into a @c daeElement. If a @c daeIDRef is stored within a @c daeElement it fills
|
||||
* in its container field to point to the containing element.
|
||||
*
|
||||
* The main API is the @c daeIDRef::resolveElement() will use a @c daeIDRefResolver
|
||||
* to search for the @c daeElement inside of a @c daeDatabase.
|
||||
*
|
||||
*/
|
||||
class daeIDRef
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* An enum describing the status of the ID resolution process.
|
||||
*/
|
||||
enum ResolveState{
|
||||
/** No ID specified */
|
||||
id_empty,
|
||||
/** ID specified but not resolved */
|
||||
id_loaded,
|
||||
/** ID resolution pending */
|
||||
id_pending,
|
||||
/** ID resolved correctly */
|
||||
id_success,
|
||||
/** Resolution failed because ID was not found */
|
||||
id_failed_id_not_found,
|
||||
/** Resolution failed because ID was invalid */
|
||||
id_failed_invalid_id,
|
||||
/** Resoltion failed due to invalid reference */
|
||||
id_failed_invalid_reference,
|
||||
/** Resolution failed due to an external error */
|
||||
id_failed_externalization
|
||||
};
|
||||
|
||||
private:
|
||||
/** Id used to refer to another element */
|
||||
daeString id;
|
||||
|
||||
/** Reference to the actual element the ID refers to */
|
||||
daeElementRef element;
|
||||
|
||||
/** Element that owns this ID (if any) */
|
||||
daeElement* container;
|
||||
|
||||
/** Current state of this id's resolution */
|
||||
ResolveState state;
|
||||
|
||||
public:
|
||||
/**
|
||||
* Gets the element that this URI resolves to in memory.
|
||||
* @return Returns a ref to the element.
|
||||
*/
|
||||
inline daeElementRef getElement(){return(element);};
|
||||
|
||||
/**
|
||||
* Gets the element that this URI resolves to in memory.
|
||||
* @return Returns a ref to the element.
|
||||
*/
|
||||
inline daeElementConstRef getElement() const {return(element);};
|
||||
|
||||
/**
|
||||
* Sets the element that this URI resolves to in memory.
|
||||
* @param newref A ref to the element.
|
||||
*/
|
||||
inline void setElement(daeElementRef newref){element=newref;};
|
||||
|
||||
/**
|
||||
* Gets the resolve state of the URI.
|
||||
* @return Returns the current state.
|
||||
* @note This will be removed when daeURI starts managing its state internally.
|
||||
*/
|
||||
inline ResolveState getState() const {return(state);};
|
||||
|
||||
/**
|
||||
* Sets the resolve state of the URI.
|
||||
* @param newState The new state.
|
||||
* @note This will be removed when daeURI starts managing its state internally.
|
||||
*/
|
||||
inline void setState(ResolveState newState){state=newState;};
|
||||
|
||||
/**
|
||||
* Gets a pointer to the @c daeElement that contains this URI.
|
||||
* @return Returns the pointer to the containing daeElmement.
|
||||
*/
|
||||
|
||||
inline daeElement* getContainer() const {return(container);};
|
||||
/**
|
||||
* Sets the pointer to the @c daeElement that contains this URI.
|
||||
* @param element Pointer to the containing @c daeElmement.
|
||||
*/
|
||||
inline void setContainer(daeElement* element){container=element;};
|
||||
|
||||
public:
|
||||
/**
|
||||
* Simple Constructor
|
||||
*/
|
||||
daeIDRef();
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
~daeIDRef();
|
||||
|
||||
/**
|
||||
* Constructs an id reference via a string, using @c setID(); loads the status.
|
||||
* @param id ID to construct a reference for, passed to @c setID() automatically.
|
||||
*/
|
||||
daeIDRef(daeString id);
|
||||
|
||||
/**
|
||||
* Constructs a new id reference by copying an existing one.
|
||||
* @param constructFromIDRef @c daeIDRef to copy into this one.
|
||||
*/
|
||||
daeIDRef(daeIDRef& constructFromIDRef);
|
||||
|
||||
/**
|
||||
* Copies <tt><i>ID</i></tt> into the <tt><i>id </i></tt> data member.
|
||||
* After the call to @c setID(), the <tt><i>state</i></tt> is set to @c id_loaded
|
||||
* @param ID String to use to configure this @c daeIDRef.
|
||||
*/
|
||||
void setID(daeString ID);
|
||||
|
||||
/**
|
||||
* Gets the ID string
|
||||
* @return Returns the full ID string from <tt><i>id.</i></tt>
|
||||
*/
|
||||
daeString getID() const;
|
||||
|
||||
/**
|
||||
* Uses the @c daeIDRefResolver static API to try to resolve this ID
|
||||
* into a @c daeElement reference.
|
||||
* This function can effectively force a load of a file, perform
|
||||
* a database query, et cetera based on the @c daeIDRefResolver plugins
|
||||
* implemented.
|
||||
*/
|
||||
void resolveElement( daeString typeNameHint = NULL );
|
||||
|
||||
/**
|
||||
* Configures the <tt><i>id</i></tt> string of this @c daeIDRef based on the element set its <tt><i>element</i></tt> data member.
|
||||
* Uses @c daeElement::getID() to get the element's ID information to configure
|
||||
* the <tt><i>id</i></tt> string.
|
||||
*/
|
||||
void resolveID();
|
||||
|
||||
/**
|
||||
* Sets the <tt><i>state</i></tt> of this @c daeIDRef to @c id_pending, as it is awaiting a call to
|
||||
* @c resolveElement().
|
||||
*/
|
||||
void validate();
|
||||
|
||||
/**
|
||||
* Copies <tt><i>from</i></tt> into <tt><i>this.</i></tt>
|
||||
* The function does a simple copy, and not "base validation".
|
||||
* @param from @c daeIDRef to copy from.
|
||||
*/
|
||||
void copyFrom(daeIDRef& from);
|
||||
|
||||
/**
|
||||
* Outputs all components of this @c daeIDRef to stderr.
|
||||
*/
|
||||
void print();
|
||||
|
||||
/**
|
||||
* Resets this @c daeIDRef; frees all string references
|
||||
* and returns <tt><i>state</i></tt> to @c empty.
|
||||
*/
|
||||
void reset();
|
||||
|
||||
/**
|
||||
* Initializes the @c daeIDREf, setting <tt><i>id, element,</i></tt> and <tt><i>container</i></tt> to NULL.
|
||||
*/
|
||||
void initialize();
|
||||
};
|
||||
|
||||
class daeIDRefResolver;
|
||||
typedef daeTArray<daeIDRefResolver*> daeIDRefResolverPtrArray;
|
||||
|
||||
/**
|
||||
* The @c daeIDRefResolver class is the plugin point for @c daeIDRef resolution.
|
||||
* This class is an abstract base class that defines an interface for
|
||||
* resolving @c daeIDRefs.
|
||||
* All instances of @c daeIDRefResolvers are tracked centrally.
|
||||
* Every @c daeIDRef is passed through this list of @c aeIDRefResolvers for resolution.
|
||||
* The list is ordered on a first come, first serve basis, and resolution
|
||||
* terminates after any resolver instance is able to resolve the ID.
|
||||
*/
|
||||
class daeIDRefResolver
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Constructor; base constructor appends @c this to <tt><i>_KnownResolvers</i></tt> list.
|
||||
*/
|
||||
daeIDRefResolver();
|
||||
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
virtual ~daeIDRefResolver();
|
||||
|
||||
protected:
|
||||
static daeIDRefResolverPtrArray _KnownResolvers;
|
||||
|
||||
public:
|
||||
/**
|
||||
* Iterates through known resolvers
|
||||
* calling @c resolveElement().
|
||||
* @param id @c daeIDRef to resolve.
|
||||
*/
|
||||
static void attemptResolveElement(daeIDRef &id, daeString typeNameHint = NULL );
|
||||
|
||||
/**
|
||||
* attemptResolveID iterates through known resolvers
|
||||
* calling resolveID().
|
||||
* @param id @c daeIDRef to resolve.
|
||||
*/
|
||||
static void attemptResolveID(daeIDRef &id);
|
||||
|
||||
public: // Abstract Interface
|
||||
/**
|
||||
* Provides an abstract interface to convert a @c daeIDRef into a @c daeElement.
|
||||
* @param IDRef @c daeIDRef to resolve.
|
||||
* @return Returns true if the @c daeIDRefResolver successfully resolved the IDRef,
|
||||
* returns false otherwise.
|
||||
*/
|
||||
virtual daeBool resolveElement(daeIDRef& IDRef, daeString typeNameHint = NULL ) = 0;
|
||||
/**
|
||||
* Provides an abstract interface to convert a @c daeElement into a @c daeIDRef.
|
||||
* @param IDRef @c daeIDRef to resolve.
|
||||
* @return Returns true if the @c daeIDRefResolver successfully resolved the element
|
||||
* into a @c daeIDRef, returns false otherwise.
|
||||
*/
|
||||
virtual daeBool resolveID(daeIDRef& IDRef) = 0;
|
||||
|
||||
/**
|
||||
* Gets the name of this resolver.
|
||||
* @return Returns the string name.
|
||||
*/
|
||||
virtual daeString getName() = 0;
|
||||
|
||||
};
|
||||
|
||||
class daeDatabase;
|
||||
|
||||
/**
|
||||
* The @c daeDefaultIDRefResolver resolves a @c daeIDRef by checking with a database.
|
||||
* It is a concrete implementation for @c daeIDRefResolver.
|
||||
*/
|
||||
class daeDefaultIDRefResolver : public daeIDRefResolver
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Constructor
|
||||
* @param database @c daeDatabase for this implementation.
|
||||
*/
|
||||
daeDefaultIDRefResolver(daeDatabase* database);
|
||||
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
~daeDefaultIDRefResolver();
|
||||
|
||||
protected:
|
||||
daeDatabase* _database;
|
||||
|
||||
public: // Abstract Interface
|
||||
/*
|
||||
* Implements base class abstract routine from @c daeIDRefResolver.
|
||||
*/
|
||||
virtual daeBool resolveElement(daeIDRef& id, daeString typeNameHint = NULL );
|
||||
|
||||
/*
|
||||
* Implements base class abstract routine from @c daeIDRefResolver.
|
||||
*/
|
||||
virtual daeBool resolveID(daeIDRef& id);
|
||||
|
||||
/*
|
||||
* Implements base class abstract routine from @c daeIDRefResolver.
|
||||
*/
|
||||
virtual daeString getName();
|
||||
};
|
||||
|
||||
#endif //__DAE_IDREF_H__
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user