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
create(DAE & dae)20 domGeometry::create(DAE& dae)
21 {
22 domGeometryRef ref = new domGeometry(dae);
23 return ref;
24 }
25
26
27 daeMetaElement *
registerElement(DAE & dae)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