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#ifndef __domGlsl_setarray_type_h__
10#define __domGlsl_setarray_type_h__
11
12#include <dae/daeDocument.h>
13#include <dom/domTypes.h>
14#include <dom/domElements.h>
15
16#include <dom/domGlsl_param_type.h>
17#include <dom/domGlsl_setarray_type.h>
18class DAE;
19
20/**
21 * The glsl_newarray_type is used to creates a parameter of a one-dimensional
22 * array type.
23 */
24class domGlsl_setarray_type_complexType
25{
26protected:  // Attribute
27/**
28 *  The length attribute specifies the length of the array.
29 */
30	xsPositiveInteger attrLength;
31
32protected:  // Elements
33	domGlsl_param_type_Array elemGlsl_param_type_array;
34/**
35 * You may recursively nest glsl_newarray elements to create multidimensional
36 * arrays. @see domArray
37 */
38	domGlsl_setarray_type_Array elemArray_array;
39	/**
40	 * Used to preserve order in elements that do not specify strict sequencing of sub-elements.
41	 */
42	daeElementRefArray _contents;
43	/**
44	 * Used to preserve order in elements that have a complex content model.
45	 */
46	daeUIntArray       _contentsOrder;
47
48	/**
49	 * Used to store information needed for some content model objects.
50	 */
51	daeTArray< daeCharArray * > _CMData;
52
53
54public:	//Accessors and Mutators
55	/**
56	 * Gets the length attribute.
57	 * @return Returns a xsPositiveInteger of the length attribute.
58	 */
59	xsPositiveInteger getLength() const { return attrLength; }
60	/**
61	 * Sets the length attribute.
62	 * @param atLength The new value for the length attribute.
63	 */
64	void setLength( xsPositiveInteger atLength ) { attrLength = atLength; }
65
66	/**
67	 * Gets the glsl_param_type element array.
68	 * @return Returns a reference to the array of glsl_param_type elements.
69	 */
70	domGlsl_param_type_Array &getGlsl_param_type_array() { return elemGlsl_param_type_array; }
71	/**
72	 * Gets the glsl_param_type element array.
73	 * @return Returns a constant reference to the array of glsl_param_type elements.
74	 */
75	const domGlsl_param_type_Array &getGlsl_param_type_array() const { return elemGlsl_param_type_array; }
76	/**
77	 * Gets the array element array.
78	 * @return Returns a reference to the array of array elements.
79	 */
80	domGlsl_setarray_type_Array &getArray_array() { return elemArray_array; }
81	/**
82	 * Gets the array element array.
83	 * @return Returns a constant reference to the array of array elements.
84	 */
85	const domGlsl_setarray_type_Array &getArray_array() const { return elemArray_array; }
86	/**
87	 * Gets the _contents array.
88	 * @return Returns a reference to the _contents element array.
89	 */
90	daeElementRefArray &getContents() { return _contents; }
91	/**
92	 * Gets the _contents array.
93	 * @return Returns a constant reference to the _contents element array.
94	 */
95	const daeElementRefArray &getContents() const { return _contents; }
96
97protected:
98	/**
99	 * Constructor
100	 */
101	domGlsl_setarray_type_complexType(DAE& dae, daeElement* elt) : attrLength(), elemGlsl_param_type_array(), elemArray_array() {}
102	/**
103	 * Destructor
104	 */
105	virtual ~domGlsl_setarray_type_complexType() { daeElement::deleteCMDataArray(_CMData); }
106	/**
107	 * Overloaded assignment operator
108	 */
109	virtual domGlsl_setarray_type_complexType &operator=( const domGlsl_setarray_type_complexType &cpy ) { (void)cpy; return *this; }
110};
111
112/**
113 * An element of type domGlsl_setarray_type_complexType.
114 */
115class domGlsl_setarray_type : public daeElement, public domGlsl_setarray_type_complexType
116{
117public:
118	virtual COLLADA_TYPE::TypeEnum getElementType() const { return COLLADA_TYPE::GLSL_SETARRAY_TYPE; }
119	static daeInt ID() { return 104; }
120	virtual daeInt typeID() const { return ID(); }
121
122public:	//Accessors and Mutators
123	/**
124	 * Gets the length attribute.
125	 * @return Returns a xsPositiveInteger of the length attribute.
126	 */
127	xsPositiveInteger getLength() const { return attrLength; }
128	/**
129	 * Sets the length attribute.
130	 * @param atLength The new value for the length attribute.
131	 */
132	void setLength( xsPositiveInteger atLength ) { attrLength = atLength; _validAttributeArray[0] = true; }
133
134protected:
135	/**
136	 * Constructor
137	 */
138	domGlsl_setarray_type(DAE& dae) : daeElement(dae), domGlsl_setarray_type_complexType(dae, this) {}
139	/**
140	 * Destructor
141	 */
142	virtual ~domGlsl_setarray_type() {}
143	/**
144	 * Overloaded assignment operator
145	 */
146	virtual domGlsl_setarray_type &operator=( const domGlsl_setarray_type &cpy ) { (void)cpy; return *this; }
147
148public: // STATIC METHODS
149	/**
150	 * Creates an instance of this class and returns a daeElementRef referencing it.
151	 * @return a daeElementRef referencing an instance of this object.
152	 */
153	static DLLSPEC daeElementRef create(DAE& dae);
154	/**
155	 * Creates a daeMetaElement object that describes this element in the meta object reflection framework.
156	 * If a daeMetaElement already exists it will return that instead of creating a new one.
157	 * @return A daeMetaElement describing this COLLADA element.
158	 */
159	static DLLSPEC daeMetaElement* registerElement(DAE& dae);
160};
161
162
163#endif
164