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/domInstance_physics_model.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 domInstance_physics_model::create(DAE& dae) 21 { 22 domInstance_physics_modelRef ref = new domInstance_physics_model(dae); 23 return ref; 24 } 25 26 27 daeMetaElement * 28 domInstance_physics_model::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( "instance_physics_model" ); 36 meta->registerClass(domInstance_physics_model::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, 0, -1 ); 43 mea->setName( "instance_force_field" ); 44 mea->setOffset( daeOffsetOf(domInstance_physics_model,elemInstance_force_field_array) ); 45 mea->setElementType( domInstance_force_field::registerElement(dae) ); 46 cm->appendChild( mea ); 47 48 mea = new daeMetaElementArrayAttribute( meta, cm, 1, 0, -1 ); 49 mea->setName( "instance_rigid_body" ); 50 mea->setOffset( daeOffsetOf(domInstance_physics_model,elemInstance_rigid_body_array) ); 51 mea->setElementType( domInstance_rigid_body::registerElement(dae) ); 52 cm->appendChild( mea ); 53 54 mea = new daeMetaElementArrayAttribute( meta, cm, 2, 0, -1 ); 55 mea->setName( "instance_rigid_constraint" ); 56 mea->setOffset( daeOffsetOf(domInstance_physics_model,elemInstance_rigid_constraint_array) ); 57 mea->setElementType( domInstance_rigid_constraint::registerElement(dae) ); 58 cm->appendChild( mea ); 59 60 mea = new daeMetaElementArrayAttribute( meta, cm, 3, 0, -1 ); 61 mea->setName( "extra" ); 62 mea->setOffset( daeOffsetOf(domInstance_physics_model,elemExtra_array) ); 63 mea->setElementType( domExtra::registerElement(dae) ); 64 cm->appendChild( mea ); 65 66 cm->setMaxOrdinal( 3 ); 67 meta->setCMRoot( cm ); 68 69 // Add attribute: url 70 { 71 daeMetaAttribute *ma = new daeMetaAttribute; 72 ma->setName( "url" ); 73 ma->setType( dae.getAtomicTypes().get("xsAnyURI")); 74 ma->setOffset( daeOffsetOf( domInstance_physics_model , attrUrl )); 75 ma->setContainer( meta ); 76 ma->setIsRequired( true ); 77 78 meta->appendAttribute(ma); 79 } 80 81 // Add attribute: sid 82 { 83 daeMetaAttribute *ma = new daeMetaAttribute; 84 ma->setName( "sid" ); 85 ma->setType( dae.getAtomicTypes().get("xsNCName")); 86 ma->setOffset( daeOffsetOf( domInstance_physics_model , attrSid )); 87 ma->setContainer( meta ); 88 89 meta->appendAttribute(ma); 90 } 91 92 // Add attribute: name 93 { 94 daeMetaAttribute *ma = new daeMetaAttribute; 95 ma->setName( "name" ); 96 ma->setType( dae.getAtomicTypes().get("xsNCName")); 97 ma->setOffset( daeOffsetOf( domInstance_physics_model , attrName )); 98 ma->setContainer( meta ); 99 100 meta->appendAttribute(ma); 101 } 102 103 // Add attribute: parent 104 { 105 daeMetaAttribute *ma = new daeMetaAttribute; 106 ma->setName( "parent" ); 107 ma->setType( dae.getAtomicTypes().get("xsAnyURI")); 108 ma->setOffset( daeOffsetOf( domInstance_physics_model , attrParent )); 109 ma->setContainer( meta ); 110 111 meta->appendAttribute(ma); 112 } 113 114 meta->setElementSize(sizeof(domInstance_physics_model)); 115 meta->validate(); 116 117 return meta; 118 } 119 120