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/domMesh.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 domMesh::create(DAE& dae)
     21 {
     22 	domMeshRef ref = new domMesh(dae);
     23 	return ref;
     24 }
     25 
     26 
     27 daeMetaElement *
     28 domMesh::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( "mesh" );
     36 	meta->registerClass(domMesh::create);
     37 
     38 	daeMetaCMPolicy *cm = NULL;
     39 	daeMetaElementAttribute *mea = NULL;
     40 	cm = new daeMetaSequence( meta, cm, 0, 1, 1 );
     41 
     42 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, -1 );
     43 	mea->setName( "source" );
     44 	mea->setOffset( daeOffsetOf(domMesh,elemSource_array) );
     45 	mea->setElementType( domSource::registerElement(dae) );
     46 	cm->appendChild( mea );
     47 
     48 	mea = new daeMetaElementAttribute( meta, cm, 1, 1, 1 );
     49 	mea->setName( "vertices" );
     50 	mea->setOffset( daeOffsetOf(domMesh,elemVertices) );
     51 	mea->setElementType( domVertices::registerElement(dae) );
     52 	cm->appendChild( mea );
     53 
     54 	cm = new daeMetaChoice( meta, cm, 0, 2, 0, -1 );
     55 
     56 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     57 	mea->setName( "lines" );
     58 	mea->setOffset( daeOffsetOf(domMesh,elemLines_array) );
     59 	mea->setElementType( domLines::registerElement(dae) );
     60 	cm->appendChild( mea );
     61 
     62 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     63 	mea->setName( "linestrips" );
     64 	mea->setOffset( daeOffsetOf(domMesh,elemLinestrips_array) );
     65 	mea->setElementType( domLinestrips::registerElement(dae) );
     66 	cm->appendChild( mea );
     67 
     68 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     69 	mea->setName( "polygons" );
     70 	mea->setOffset( daeOffsetOf(domMesh,elemPolygons_array) );
     71 	mea->setElementType( domPolygons::registerElement(dae) );
     72 	cm->appendChild( mea );
     73 
     74 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     75 	mea->setName( "polylist" );
     76 	mea->setOffset( daeOffsetOf(domMesh,elemPolylist_array) );
     77 	mea->setElementType( domPolylist::registerElement(dae) );
     78 	cm->appendChild( mea );
     79 
     80 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     81 	mea->setName( "triangles" );
     82 	mea->setOffset( daeOffsetOf(domMesh,elemTriangles_array) );
     83 	mea->setElementType( domTriangles::registerElement(dae) );
     84 	cm->appendChild( mea );
     85 
     86 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     87 	mea->setName( "trifans" );
     88 	mea->setOffset( daeOffsetOf(domMesh,elemTrifans_array) );
     89 	mea->setElementType( domTrifans::registerElement(dae) );
     90 	cm->appendChild( mea );
     91 
     92 	mea = new daeMetaElementArrayAttribute( meta, cm, 0, 1, 1 );
     93 	mea->setName( "tristrips" );
     94 	mea->setOffset( daeOffsetOf(domMesh,elemTristrips_array) );
     95 	mea->setElementType( domTristrips::registerElement(dae) );
     96 	cm->appendChild( mea );
     97 
     98 	cm->setMaxOrdinal( 0 );
     99 	cm->getParent()->appendChild( cm );
    100 	cm = cm->getParent();
    101 
    102 	mea = new daeMetaElementArrayAttribute( meta, cm, 3003, 0, -1 );
    103 	mea->setName( "extra" );
    104 	mea->setOffset( daeOffsetOf(domMesh,elemExtra_array) );
    105 	mea->setElementType( domExtra::registerElement(dae) );
    106 	cm->appendChild( mea );
    107 
    108 	cm->setMaxOrdinal( 3003 );
    109 	meta->setCMRoot( cm );
    110 	// Ordered list of sub-elements
    111 	meta->addContents(daeOffsetOf(domMesh,_contents));
    112 	meta->addContentsOrder(daeOffsetOf(domMesh,_contentsOrder));
    113 
    114 	meta->addCMDataArray(daeOffsetOf(domMesh,_CMData), 1);
    115 	meta->setElementSize(sizeof(domMesh));
    116 	meta->validate();
    117 
    118 	return meta;
    119 }
    120 
    121