blob: 28bb66fee991ffae3ca7320f42a805ee755688fa [file] [log] [blame]
/*
* 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
*
*/
#include <dae.h>
#include <dae/daeDom.h>
#include <dom/domCapsule.h>
#include <dae/daeMetaCMPolicy.h>
#include <dae/daeMetaSequence.h>
#include <dae/daeMetaChoice.h>
#include <dae/daeMetaGroup.h>
#include <dae/daeMetaAny.h>
#include <dae/daeMetaElementAttribute.h>
daeElementRef
domCapsule::create(DAE& dae)
{
domCapsuleRef ref = new domCapsule(dae);
return ref;
}
daeMetaElement *
domCapsule::registerElement(DAE& dae)
{
daeMetaElement* meta = dae.getMeta(ID());
if ( meta != NULL ) return meta;
meta = new daeMetaElement(dae);
dae.setMeta(ID(), *meta);
meta->setName( "capsule" );
meta->registerClass(domCapsule::create);
daeMetaCMPolicy *cm = NULL;
daeMetaElementAttribute *mea = NULL;
cm = new daeMetaSequence( meta, cm, 0, 1, 1 );
mea = new daeMetaElementAttribute( meta, cm, 0, 1, 1 );
mea->setName( "height" );
mea->setOffset( daeOffsetOf(domCapsule,elemHeight) );
mea->setElementType( domCapsule::domHeight::registerElement(dae) );
cm->appendChild( mea );
mea = new daeMetaElementAttribute( meta, cm, 1, 1, 1 );
mea->setName( "radius" );
mea->setOffset( daeOffsetOf(domCapsule,elemRadius) );
mea->setElementType( domCapsule::domRadius::registerElement(dae) );
cm->appendChild( mea );
mea = new daeMetaElementArrayAttribute( meta, cm, 2, 0, -1 );
mea->setName( "extra" );
mea->setOffset( daeOffsetOf(domCapsule,elemExtra_array) );
mea->setElementType( domExtra::registerElement(dae) );
cm->appendChild( mea );
cm->setMaxOrdinal( 2 );
meta->setCMRoot( cm );
meta->setElementSize(sizeof(domCapsule));
meta->validate();
return meta;
}
daeElementRef
domCapsule::domHeight::create(DAE& dae)
{
domCapsule::domHeightRef ref = new domCapsule::domHeight(dae);
return ref;
}
daeMetaElement *
domCapsule::domHeight::registerElement(DAE& dae)
{
daeMetaElement* meta = dae.getMeta(ID());
if ( meta != NULL ) return meta;
meta = new daeMetaElement(dae);
dae.setMeta(ID(), *meta);
meta->setName( "height" );
meta->registerClass(domCapsule::domHeight::create);
meta->setIsInnerClass( true );
// Add attribute: _value
{
daeMetaAttribute *ma = new daeMetaAttribute;
ma->setName( "_value" );
ma->setType( dae.getAtomicTypes().get("Float"));
ma->setOffset( daeOffsetOf( domCapsule::domHeight , _value ));
ma->setContainer( meta );
meta->appendAttribute(ma);
}
meta->setElementSize(sizeof(domCapsule::domHeight));
meta->validate();
return meta;
}
daeElementRef
domCapsule::domRadius::create(DAE& dae)
{
domCapsule::domRadiusRef ref = new domCapsule::domRadius(dae);
return ref;
}
daeMetaElement *
domCapsule::domRadius::registerElement(DAE& dae)
{
daeMetaElement* meta = dae.getMeta(ID());
if ( meta != NULL ) return meta;
meta = new daeMetaElement(dae);
dae.setMeta(ID(), *meta);
meta->setName( "radius" );
meta->registerClass(domCapsule::domRadius::create);
meta->setIsInnerClass( true );
// Add attribute: _value
{
daeMetaAttribute *ma = new daeMetaArrayAttribute;
ma->setName( "_value" );
ma->setType( dae.getAtomicTypes().get("Float2"));
ma->setOffset( daeOffsetOf( domCapsule::domRadius , _value ));
ma->setContainer( meta );
meta->appendAttribute(ma);
}
meta->setElementSize(sizeof(domCapsule::domRadius));
meta->validate();
return meta;
}