Home | History | Annotate | Download | only in dom
      1 /*
      2 * Copyright 2006 Sony Computer Entertainment Inc.
      3 *
      4 * Licensed under the MIT Open Source License, for details please see license.txt or the website
      5 * http://www.opensource.org/licenses/mit-license.php
      6 *
      7 */
      8 
      9 #include <dae.h>
     10 #include <dae/daeDom.h>
     11 #include <dom/domGeometry.h>
     12 #include <dae/daeMetaCMPolicy.h>
     13 #include <dae/daeMetaSequence.h>
     14 #include <dae/daeMetaChoice.h>
     15 #include <dae/daeMetaGroup.h>
     16 #include <dae/daeMetaAny.h>
     17 #include <dae/daeMetaElementAttribute.h>
     18 
     19 daeElementRef
     20 domGeometry::create(DAE& dae)
     21 {
     22 	domGeometryRef ref = new domGeometry(dae);
     23 	return ref;
     24 }
     25 
     26 
     27 daeMetaElement *
     28 domGeometry::registerElement(DAE& dae)
     29 {
     30 	daeMetaElement* meta = dae.getMeta(ID());
     31 	if ( meta != NULL ) return meta;
     32 
     33 	meta = new daeMetaElement(dae);
     34 	dae.setMeta(ID(), *meta);
     35 	meta->setName( "geometry" );
     36 	meta->registerClass(domGeometry::create);
     37 
     38 	daeMetaCMPolicy *cm = NULL;
     39 	daeMetaElementAttribute *mea = NULL;
     40 	cm = new daeMetaSequence( meta, cm, 0, 1, 1 );
     41 
     42 	mea = new daeMetaElementAttribute( meta, cm, 0, 0, 1 );
     43 	mea->setName( "asset" );
     44 	mea->setOffset( daeOffsetOf(domGeometry,elemAsset) );
     45 	mea->setElementType( domAsset::registerElement(dae) );
     46 	cm->appendChild( mea );
     47 
     48 	cm = new daeMetaChoice( meta, cm, 0, 1, 1, 1 );
     49 
     50 	mea = new daeMetaElementAttribute( meta, cm, 0, 1, 1 );
     51 	mea->setName( "convex_mesh" );
     52 	mea->setOffset( daeOffsetOf(domGeometry,elemConvex_mesh) );
     53 	mea->setElementType( domConvex_mesh::registerElement(dae) );
     54 	cm->appendChild( mea );
     55 
     56 	mea = new daeMetaElementAttribute( meta, cm, 0, 1, 1 );
     57 	mea->setName( "mesh" );
     58 	mea->setOffset( daeOffsetOf(domGeometry,elemMesh) );
     59 	mea->setElementType( domMesh::registerElement(dae) );
     60 	cm->appendChild( mea );
     61 
     62 	mea = new daeMetaElementAttribute( meta, cm, 0, 1, 1 );
     63 	mea->setName( "spline" );
     64 	mea->setOffset( daeOffsetOf(domGeometry,elemSpline) );
     65 	mea->setElementType( domSpline::registerElement(dae) );
     66 	cm->appendChild( mea );
     67 
     68 	cm->setMaxOrdinal( 0 );
     69 	cm->getParent()->appendChild( cm );
     70 	cm = cm->getParent();
     71 
     72 	mea = new daeMetaElementArrayAttribute( meta, cm, 2, 0, -1 );
     73 	mea->setName( "extra" );
     74 	mea->setOffset( daeOffsetOf(domGeometry,elemExtra_array) );
     75 	mea->setElementType( domExtra::registerElement(dae) );
     76 	cm->appendChild( mea );
     77 
     78 	cm->setMaxOrdinal( 2 );
     79 	meta->setCMRoot( cm );
     80 	// Ordered list of sub-elements
     81 	meta->addContents(daeOffsetOf(domGeometry,_contents));
     82 	meta->addContentsOrder(daeOffsetOf(domGeometry,_contentsOrder));
     83 
     84 	meta->addCMDataArray(daeOffsetOf(domGeometry,_CMData), 1);
     85 	//	Add attribute: id
     86 	{
     87 		daeMetaAttribute *ma = new daeMetaAttribute;
     88 		ma->setName( "id" );
     89 		ma->setType( dae.getAtomicTypes().get("xsID"));
     90 		ma->setOffset( daeOffsetOf( domGeometry , attrId ));
     91 		ma->setContainer( meta );
     92 
     93 		meta->appendAttribute(ma);
     94 	}
     95 
     96 	//	Add attribute: name
     97 	{
     98 		daeMetaAttribute *ma = new daeMetaAttribute;
     99 		ma->setName( "name" );
    100 		ma->setType( dae.getAtomicTypes().get("xsNCName"));
    101 		ma->setOffset( daeOffsetOf( domGeometry , attrName ));
    102 		ma->setContainer( meta );
    103 
    104 		meta->appendAttribute(ma);
    105 	}
    106 
    107 	meta->setElementSize(sizeof(domGeometry));
    108 	meta->validate();
    109 
    110 	return meta;
    111 }
    112 
    113