Files
bullet3/Extras/COLLADA_DOM/src/1.4/dom/domPolygons.cpp
ejcoumans a0f320764b Upgraded to latest COLLADA-DOM 1.2.0, see http://sourceforge.net/project/showfiles.php?group_id=157838
November 13, 2006
Re-applied the 'INF' fix for constraint limits.
2006-12-19 02:33:05 +00:00

207 lines
5.5 KiB
C++

/*
* 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.
*/
#include <dae/daeDom.h>
#include <dom/domPolygons.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
domPolygons::create(daeInt bytes)
{
domPolygonsRef ref = new(bytes) domPolygons;
return ref;
}
daeMetaElement *
domPolygons::registerElement()
{
if ( _Meta != NULL ) return _Meta;
_Meta = new daeMetaElement;
_Meta->setName( "polygons" );
_Meta->registerClass(domPolygons::create, &_Meta);
daeMetaCMPolicy *cm = NULL;
daeMetaElementAttribute *mea = NULL;
cm = new daeMetaSequence( _Meta, cm, 0, 1, 1 );
mea = new daeMetaElementArrayAttribute( _Meta, cm, 0, 0, -1 );
mea->setName( "input" );
mea->setOffset( daeOffsetOf(domPolygons,elemInput_array) );
mea->setElementType( domInputLocalOffset::registerElement() );
cm->appendChild( mea );
cm = new daeMetaChoice( _Meta, cm, 1, 0, -1 );
mea = new daeMetaElementArrayAttribute( _Meta, cm, 0, 1, 1 );
mea->setName( "p" );
mea->setOffset( daeOffsetOf(domPolygons,elemP_array) );
mea->setElementType( domP::registerElement() );
cm->appendChild( mea );
mea = new daeMetaElementArrayAttribute( _Meta, cm, 0, 1, 1 );
mea->setName( "ph" );
mea->setOffset( daeOffsetOf(domPolygons,elemPh_array) );
mea->setElementType( domPolygons::domPh::registerElement() );
cm->appendChild( mea );
cm->setMaxOrdinal( 0 );
cm->getParent()->appendChild( cm );
cm = cm->getParent();
mea = new daeMetaElementArrayAttribute( _Meta, cm, 3002, 0, -1 );
mea->setName( "extra" );
mea->setOffset( daeOffsetOf(domPolygons,elemExtra_array) );
mea->setElementType( domExtra::registerElement() );
cm->appendChild( mea );
cm->setMaxOrdinal( 3002 );
_Meta->setCMRoot( cm );
// Ordered list of sub-elements
_Meta->addContents(daeOffsetOf(domPolygons,_contents));
_Meta->addContentsOrder(daeOffsetOf(domPolygons,_contentsOrder));
// Add attribute: name
{
daeMetaAttribute *ma = new daeMetaAttribute;
ma->setName( "name" );
ma->setType( daeAtomicType::get("xsNCName"));
ma->setOffset( daeOffsetOf( domPolygons , attrName ));
ma->setContainer( _Meta );
_Meta->appendAttribute(ma);
}
// Add attribute: count
{
daeMetaAttribute *ma = new daeMetaAttribute;
ma->setName( "count" );
ma->setType( daeAtomicType::get("Uint"));
ma->setOffset( daeOffsetOf( domPolygons , attrCount ));
ma->setContainer( _Meta );
ma->setIsRequired( true );
_Meta->appendAttribute(ma);
}
// Add attribute: material
{
daeMetaAttribute *ma = new daeMetaAttribute;
ma->setName( "material" );
ma->setType( daeAtomicType::get("xsNCName"));
ma->setOffset( daeOffsetOf( domPolygons , attrMaterial ));
ma->setContainer( _Meta );
_Meta->appendAttribute(ma);
}
_Meta->setElementSize(sizeof(domPolygons));
_Meta->validate();
return _Meta;
}
daeElementRef
domPolygons::domPh::create(daeInt bytes)
{
domPolygons::domPhRef ref = new(bytes) domPolygons::domPh;
return ref;
}
daeMetaElement *
domPolygons::domPh::registerElement()
{
if ( _Meta != NULL ) return _Meta;
_Meta = new daeMetaElement;
_Meta->setName( "ph" );
_Meta->registerClass(domPolygons::domPh::create, &_Meta);
_Meta->setIsInnerClass( true );
daeMetaCMPolicy *cm = NULL;
daeMetaElementAttribute *mea = NULL;
cm = new daeMetaSequence( _Meta, cm, 0, 1, 1 );
mea = new daeMetaElementAttribute( _Meta, cm, 0, 1, 1 );
mea->setName( "p" );
mea->setOffset( daeOffsetOf(domPolygons::domPh,elemP) );
mea->setElementType( domP::registerElement() );
cm->appendChild( mea );
mea = new daeMetaElementArrayAttribute( _Meta, cm, 1, 1, -1 );
mea->setName( "h" );
mea->setOffset( daeOffsetOf(domPolygons::domPh,elemH_array) );
mea->setElementType( domPolygons::domPh::domH::registerElement() );
cm->appendChild( mea );
cm->setMaxOrdinal( 1 );
_Meta->setCMRoot( cm );
_Meta->setElementSize(sizeof(domPolygons::domPh));
_Meta->validate();
return _Meta;
}
daeElementRef
domPolygons::domPh::domH::create(daeInt bytes)
{
domPolygons::domPh::domHRef ref = new(bytes) domPolygons::domPh::domH;
return ref;
}
daeMetaElement *
domPolygons::domPh::domH::registerElement()
{
if ( _Meta != NULL ) return _Meta;
_Meta = new daeMetaElement;
_Meta->setName( "h" );
_Meta->registerClass(domPolygons::domPh::domH::create, &_Meta);
_Meta->setIsInnerClass( true );
// Add attribute: _value
{
daeMetaAttribute *ma = new daeMetaArrayAttribute;
ma->setName( "_value" );
ma->setType( daeAtomicType::get("ListOfUInts"));
ma->setOffset( daeOffsetOf( domPolygons::domPh::domH , _value ));
ma->setContainer( _Meta );
_Meta->appendAttribute(ma);
}
_Meta->setElementSize(sizeof(domPolygons::domPh::domH));
_Meta->validate();
return _Meta;
}
daeMetaElement * domPolygons::_Meta = NULL;
daeMetaElement * domPolygons::domPh::_Meta = NULL;
daeMetaElement * domPolygons::domPh::domH::_Meta = NULL;