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