e601dc68bebd9e4b0617e1d56eb4e2e3c6690c5b
[blender-staging.git] / source / blender / makesrna / RNA_access.h
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19  *
20  * Contributor(s): Blender Foundation (2008).
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24
25 #ifndef RNA_ACCESS
26 #define RNA_ACCESS
27
28 #include "RNA_types.h"
29
30 struct bContext;
31 struct ID;
32 struct Main;
33
34 /* Types */
35
36 extern BlenderRNA BLENDER_RNA;
37
38 extern StructRNA RNA_Action;
39 extern StructRNA RNA_ActionChannel;
40 extern StructRNA RNA_ActionGroup;
41 extern StructRNA RNA_Actuator;
42 extern StructRNA RNA_ActuatorSensor;
43 extern StructRNA RNA_AlwaysSensor;
44 extern StructRNA RNA_AndController;
45 extern StructRNA RNA_Area;
46 extern StructRNA RNA_AreaLamp;
47 extern StructRNA RNA_Armature;
48 extern StructRNA RNA_ArmatureModifier;
49 extern StructRNA RNA_ArrayModifier;
50 extern StructRNA RNA_BevelModifier;
51 extern StructRNA RNA_BezierCurvePoint;
52 extern StructRNA RNA_BlenderRNA;
53 extern StructRNA RNA_Bone;
54 extern StructRNA RNA_BooleanModifier;
55 extern StructRNA RNA_BooleanProperty;
56 extern StructRNA RNA_Brush;
57 extern StructRNA RNA_BuildModifier;
58 extern StructRNA RNA_Camera;
59 extern StructRNA RNA_CastModifier;
60 extern StructRNA RNA_ClothCollisionSettings;
61 extern StructRNA RNA_ClothModifier;
62 extern StructRNA RNA_ClothSettings;
63 extern StructRNA RNA_CollectionProperty;
64 extern StructRNA RNA_CollisionModifier;
65 extern StructRNA RNA_CollisionSensor;
66 extern StructRNA RNA_CollisionSettings;
67 extern StructRNA RNA_ColorRamp;
68 extern StructRNA RNA_ColorRampElement;
69 extern StructRNA RNA_ColorSequence;
70 extern StructRNA RNA_Constraint;
71 extern StructRNA RNA_ControlFluidSettings;
72 extern StructRNA RNA_Controller;
73 extern StructRNA RNA_Curve;
74 extern StructRNA RNA_CurveMap;
75 extern StructRNA RNA_CurveMapPoint;
76 extern StructRNA RNA_CurveMapping;
77 extern StructRNA RNA_CurveModifier;
78 extern StructRNA RNA_CurvePoint;
79 extern StructRNA RNA_DecimateModifier;
80 extern StructRNA RNA_DelaySensor;
81 extern StructRNA RNA_DisplaceModifier;
82 extern StructRNA RNA_DomainFluidSettings;
83 extern StructRNA RNA_EdgeSplitModifier;
84 extern StructRNA RNA_EffectSequence;
85 extern StructRNA RNA_EnumProperty;
86 extern StructRNA RNA_EnumPropertyItem;
87 extern StructRNA RNA_EnvironmentMap;
88 extern StructRNA RNA_ExplodeModifier;
89 extern StructRNA RNA_ExpressionController;
90 extern StructRNA RNA_FieldSettings;
91 extern StructRNA RNA_FloatProperty;
92 extern StructRNA RNA_FluidFluidSettings;
93 extern StructRNA RNA_FluidSettings;
94 extern StructRNA RNA_FluidSimulationModifier;
95 extern StructRNA RNA_GameBooleanProperty;
96 extern StructRNA RNA_GameFloatProperty;
97 extern StructRNA RNA_GameIntProperty;
98 extern StructRNA RNA_GameObjectSettings;
99 extern StructRNA RNA_GameProperty;
100 extern StructRNA RNA_GameSoftBodySettings;
101 extern StructRNA RNA_GameStringProperty;
102 extern StructRNA RNA_GameTimerProperty;
103 extern StructRNA RNA_GlowSequence;
104 extern StructRNA RNA_Group;
105 extern StructRNA RNA_HemiLamp;
106 extern StructRNA RNA_HookModifier;
107 extern StructRNA RNA_ID;
108 extern StructRNA RNA_IDProperty;
109 extern StructRNA RNA_IDPropertyGroup;
110 extern StructRNA RNA_Image;
111 extern StructRNA RNA_ImageSequence;
112 extern StructRNA RNA_ImageUser;
113 extern StructRNA RNA_InflowFluidSettings;
114 extern StructRNA RNA_IntProperty;
115 extern StructRNA RNA_Ipo;
116 extern StructRNA RNA_IpoCurve;
117 extern StructRNA RNA_IpoDriver;
118 extern StructRNA RNA_JoystickSensor;
119 extern StructRNA RNA_Key;
120 extern StructRNA RNA_KeyboardSensor;
121 extern StructRNA RNA_Lamp;
122 extern StructRNA RNA_LampSkySettings;
123 extern StructRNA RNA_LampTextureSlot;
124 extern StructRNA RNA_Lattice;
125 extern StructRNA RNA_LatticeModifier;
126 extern StructRNA RNA_LatticePoint;
127 extern StructRNA RNA_Library;
128 extern StructRNA RNA_LocalLamp;
129 extern StructRNA RNA_Main;
130 extern StructRNA RNA_MaskModifier;
131 extern StructRNA RNA_Material;
132 extern StructRNA RNA_MaterialHalo;
133 extern StructRNA RNA_MaterialRaytraceMirror;
134 extern StructRNA RNA_MaterialRaytraceTransparency;
135 extern StructRNA RNA_MaterialStrand;
136 extern StructRNA RNA_MaterialSubsurfaceScattering;
137 extern StructRNA RNA_MaterialTextureSlot;
138 extern StructRNA RNA_Mesh;
139 extern StructRNA RNA_MeshColor;
140 extern StructRNA RNA_MeshColorLayer;
141 extern StructRNA RNA_MeshDeformModifier;
142 extern StructRNA RNA_MeshEdge;
143 extern StructRNA RNA_MeshFace;
144 extern StructRNA RNA_MeshFloatProperty;
145 extern StructRNA RNA_MeshFloatPropertyLayer;
146 extern StructRNA RNA_MeshIntProperty;
147 extern StructRNA RNA_MeshIntPropertyLayer;
148 extern StructRNA RNA_MeshMultires;
149 extern StructRNA RNA_MeshSticky;
150 extern StructRNA RNA_MeshStringProperty;
151 extern StructRNA RNA_MeshStringPropertyLayer;
152 extern StructRNA RNA_MeshTextureFace;
153 extern StructRNA RNA_MeshTextureFaceLayer;
154 extern StructRNA RNA_MeshVertex;
155 extern StructRNA RNA_MessageSensor;
156 extern StructRNA RNA_MetaBall;
157 extern StructRNA RNA_MetaElement;
158 extern StructRNA RNA_MetaSequence;
159 extern StructRNA RNA_MirrorModifier;
160 extern StructRNA RNA_Modifier;
161 extern StructRNA RNA_MouseSensor;
162 extern StructRNA RNA_MovieSequence;
163 extern StructRNA RNA_MultiresModifier;
164 extern StructRNA RNA_NandController;
165 extern StructRNA RNA_NearSensor;
166 extern StructRNA RNA_Node;
167 extern StructRNA RNA_NodeTree;
168 extern StructRNA RNA_NorController;
169 extern StructRNA RNA_Object;
170 extern StructRNA RNA_ObstacleFluidSettings;
171 extern StructRNA RNA_Operator;
172 extern StructRNA RNA_OperatorMousePath;
173 extern StructRNA RNA_OperatorProperties;
174 extern StructRNA RNA_OperatorStrokeElement;
175 extern StructRNA RNA_OrController;
176 extern StructRNA RNA_OutflowFluidSettings;
177 extern StructRNA RNA_PackedFile;
178 extern StructRNA RNA_Panel;
179 extern StructRNA RNA_ParticleFluidSettings;
180 extern StructRNA RNA_ParticleInstanceModifier;
181 extern StructRNA RNA_ParticleSettings;
182 extern StructRNA RNA_ParticleSystem;
183 extern StructRNA RNA_ParticleSystemModifier;
184 extern StructRNA RNA_PluginSequence;
185 extern StructRNA RNA_PointCache;
186 extern StructRNA RNA_PointerProperty;
187 extern StructRNA RNA_Pose;
188 extern StructRNA RNA_PoseChannel;
189 extern StructRNA RNA_Property;
190 extern StructRNA RNA_PropertySensor;
191 extern StructRNA RNA_PythonController;
192 extern StructRNA RNA_RadarSensor;
193 extern StructRNA RNA_Radiosity;
194 extern StructRNA RNA_RandomSensor;
195 extern StructRNA RNA_RaySensor;
196 extern StructRNA RNA_Region;
197 extern StructRNA RNA_Scene;
198 extern StructRNA RNA_SceneSequence;
199 extern StructRNA RNA_Screen;
200 extern StructRNA RNA_ScriptLink;
201 extern StructRNA RNA_SculptData;
202 extern StructRNA RNA_Sensor;
203 extern StructRNA RNA_Sequence;
204 extern StructRNA RNA_SequenceColorBalance;
205 extern StructRNA RNA_SequenceCrop;
206 extern StructRNA RNA_SequenceEditor;
207 extern StructRNA RNA_SequenceElement;
208 extern StructRNA RNA_SequenceProxy;
209 extern StructRNA RNA_SequenceTransform;
210 extern StructRNA RNA_ShapeKey;
211 extern StructRNA RNA_ShapeKeyBezierPoint;
212 extern StructRNA RNA_ShapeKeyCurvePoint;
213 extern StructRNA RNA_ShapeKeyPoint;
214 extern StructRNA RNA_ShrinkwrapModifier;
215 extern StructRNA RNA_SimpleDeformModifier;
216 extern StructRNA RNA_SmoothModifier;
217 extern StructRNA RNA_SoftBodySettings;
218 extern StructRNA RNA_SoftbodyModifier;
219 extern StructRNA RNA_Sound;
220 extern StructRNA RNA_SoundSequence;
221 extern StructRNA RNA_Space;
222 extern StructRNA RNA_SpaceImageEditor;
223 extern StructRNA RNA_SpaceUVEditor;
224 extern StructRNA RNA_SpeedControlSequence;
225 extern StructRNA RNA_SpotLamp;
226 extern StructRNA RNA_StringProperty;
227 extern StructRNA RNA_Struct;
228 extern StructRNA RNA_SubsurfModifier;
229 extern StructRNA RNA_SunLamp;
230 extern StructRNA RNA_Text;
231 extern StructRNA RNA_TextBox;
232 extern StructRNA RNA_TextCharacterFormat;
233 extern StructRNA RNA_TextLine;
234 extern StructRNA RNA_TextMarker;
235 extern StructRNA RNA_Texture;
236 extern StructRNA RNA_TextureSlot;
237 extern StructRNA RNA_Theme;
238 extern StructRNA RNA_ThemeActionEditor;
239 extern StructRNA RNA_ThemeAudioWindow;
240 extern StructRNA RNA_ThemeBoneColorSet;
241 extern StructRNA RNA_ThemeButtonsWindow;
242 extern StructRNA RNA_ThemeFileBrowser;
243 extern StructRNA RNA_ThemeImageEditor;
244 extern StructRNA RNA_ThemeIpoEditor;
245 extern StructRNA RNA_ThemeNLAEditor;
246 extern StructRNA RNA_ThemeNodeEditor;
247 extern StructRNA RNA_ThemeOutliner;
248 extern StructRNA RNA_ThemeSequenceEditor;
249 extern StructRNA RNA_ThemeTextEditor;
250 extern StructRNA RNA_ThemeTimeline;
251 extern StructRNA RNA_ThemeUserInterface;
252 extern StructRNA RNA_ThemeUserPreferences;
253 extern StructRNA RNA_ThemeView3D;
254 extern StructRNA RNA_TouchSensor;
255 extern StructRNA RNA_TransformSequence;
256 extern StructRNA RNA_UVProjectModifier;
257 extern StructRNA RNA_UnknownType;
258 extern StructRNA RNA_UserPreferences;
259 extern StructRNA RNA_UserSolidLight;
260 extern StructRNA RNA_VectorFont;
261 extern StructRNA RNA_VertexGroup;
262 extern StructRNA RNA_VertexGroupElement;
263 extern StructRNA RNA_WaveModifier;
264 extern StructRNA RNA_WindowManager;
265 extern StructRNA RNA_WipeSequence;
266 extern StructRNA RNA_World;
267 extern StructRNA RNA_WorldAmbientOcclusion;
268 extern StructRNA RNA_WorldMistSettings;
269 extern StructRNA RNA_WorldStarsSettings;
270 extern StructRNA RNA_WorldTextureSlot;
271 extern StructRNA RNA_XnorController;
272 extern StructRNA RNA_XorController;
273
274 /* Pointer
275  *
276  * These functions will fill in RNA pointers, this can be done in three ways:
277  * - a pointer Main is created by just passing the data pointer
278  * - a pointer to a datablock can be created with the type and id data pointer
279  * - a pointer to data contained in a datablock can be created with the id type
280  *   and id data pointer, and the data type and pointer to the struct itself.
281  *
282  * There is also a way to get a pointer with the information about all structs.
283  */
284
285 void RNA_main_pointer_create(struct Main *main, PointerRNA *r_ptr);
286 void RNA_id_pointer_create(struct ID *id, PointerRNA *r_ptr);
287 void RNA_pointer_create(struct ID *id, StructRNA *type, void *data, PointerRNA *r_ptr);
288
289 void RNA_blender_rna_pointer_create(PointerRNA *r_ptr);
290
291 /* Structs */
292
293 const char *RNA_struct_identifier(PointerRNA *ptr);
294 const char *RNA_struct_ui_name(PointerRNA *ptr);
295 const char *RNA_struct_ui_description(PointerRNA *ptr);
296
297 PropertyRNA *RNA_struct_name_property(PointerRNA *ptr);
298 PropertyRNA *RNA_struct_iterator_property(PointerRNA *ptr);
299
300 int RNA_struct_is_ID(PointerRNA *ptr);
301
302 PropertyRNA *RNA_struct_find_property(PointerRNA *ptr, const char *identifier);
303 const struct ListBase *RNA_struct_defined_properties(StructRNA *srna);
304
305 /* Properties
306  *
307  * Access to struct properties. All this works with RNA pointers rather than
308  * direct pointers to the data. */
309
310 /* Property Information */
311
312 const char *RNA_property_identifier(PointerRNA *ptr, PropertyRNA *prop);
313 PropertyType RNA_property_type(PointerRNA *ptr, PropertyRNA *prop);
314 PropertySubType RNA_property_subtype(PointerRNA *ptr, PropertyRNA *prop);
315
316 int RNA_property_array_length(PointerRNA *ptr, PropertyRNA *prop);
317
318 void RNA_property_int_range(PointerRNA *ptr, PropertyRNA *prop, int *hardmin, int *hardmax);
319 void RNA_property_int_ui_range(PointerRNA *ptr, PropertyRNA *prop, int *softmin, int *softmax, int *step);
320
321 void RNA_property_float_range(PointerRNA *ptr, PropertyRNA *prop, float *hardmin, float *hardmax);
322 void RNA_property_float_ui_range(PointerRNA *ptr, PropertyRNA *prop, float *softmin, float *softmax, float *step, float *precision);
323
324 int RNA_property_string_maxlength(PointerRNA *ptr, PropertyRNA *prop);
325
326 void RNA_property_enum_items(PointerRNA *ptr, PropertyRNA *prop, const EnumPropertyItem **item, int *totitem);
327 int RNA_property_enum_value(PointerRNA *ptr, PropertyRNA *prop, const char *identifier, int *value);
328 int RNA_property_enum_identifier(PointerRNA *ptr, PropertyRNA *prop, const int value, const char **identifier);
329
330
331 const char *RNA_property_ui_name(PointerRNA *ptr, PropertyRNA *prop);
332 const char *RNA_property_ui_description(PointerRNA *ptr, PropertyRNA *prop);
333
334 int RNA_property_editable(PointerRNA *ptr, PropertyRNA *prop);
335 int RNA_property_evaluated(PointerRNA *ptr, PropertyRNA *prop);
336
337 void RNA_property_update(struct bContext *C, PointerRNA *ptr, PropertyRNA *prop);
338
339 /* Property Data */
340
341 int RNA_property_boolean_get(PointerRNA *ptr, PropertyRNA *prop);
342 void RNA_property_boolean_set(PointerRNA *ptr, PropertyRNA *prop, int value);
343 int RNA_property_boolean_get_array(PointerRNA *ptr, PropertyRNA *prop, int index);
344 void RNA_property_boolean_set_array(PointerRNA *ptr, PropertyRNA *prop, int index, int value);
345
346 int RNA_property_int_get(PointerRNA *ptr, PropertyRNA *prop);
347 void RNA_property_int_set(PointerRNA *ptr, PropertyRNA *prop, int value);
348 int RNA_property_int_get_array(PointerRNA *ptr, PropertyRNA *prop, int index);
349 void RNA_property_int_set_array(PointerRNA *ptr, PropertyRNA *prop, int index, int value);
350
351 float RNA_property_float_get(PointerRNA *ptr, PropertyRNA *prop);
352 void RNA_property_float_set(PointerRNA *ptr, PropertyRNA *prop, float value);
353 float RNA_property_float_get_array(PointerRNA *ptr, PropertyRNA *prop, int index);
354 void RNA_property_float_set_array(PointerRNA *ptr, PropertyRNA *prop, int index, float value);
355
356 void RNA_property_string_get(PointerRNA *ptr, PropertyRNA *prop, char *value);
357 char *RNA_property_string_get_alloc(PointerRNA *ptr, PropertyRNA *prop, char *fixedbuf, int fixedlen);
358 int RNA_property_string_length(PointerRNA *ptr, PropertyRNA *prop);
359 void RNA_property_string_set(PointerRNA *ptr, PropertyRNA *prop, const char *value);
360
361 int RNA_property_enum_get(PointerRNA *ptr, PropertyRNA *prop);
362 void RNA_property_enum_set(PointerRNA *ptr, PropertyRNA *prop, int value);
363
364 void RNA_property_pointer_get(PointerRNA *ptr, PropertyRNA *prop, PointerRNA *r_ptr);
365 void RNA_property_pointer_set(PointerRNA *ptr, PropertyRNA *prop, PointerRNA *ptr_value);
366
367 void RNA_property_collection_begin(PointerRNA *ptr, PropertyRNA *prop, CollectionPropertyIterator *iter);
368 void RNA_property_collection_next(CollectionPropertyIterator *iter);
369 void RNA_property_collection_end(CollectionPropertyIterator *iter);
370 int RNA_property_collection_length(PointerRNA *ptr, PropertyRNA *prop);
371 int RNA_property_collection_lookup_int(PointerRNA *ptr, PropertyRNA *prop, int key, PointerRNA *r_ptr);
372 int RNA_property_collection_lookup_string(PointerRNA *ptr, PropertyRNA *prop, const char *key, PointerRNA *r_ptr);
373
374 /* to create ID property groups */
375 void RNA_property_pointer_add(PointerRNA *ptr, PropertyRNA *prop);
376 void RNA_property_collection_add(PointerRNA *ptr, PropertyRNA *prop, PointerRNA *r_ptr);
377 void RNA_property_collection_clear(PointerRNA *ptr, PropertyRNA *prop);
378
379 /* Path
380  *
381  * Experimental method to refer to structs and properties with a string,
382  * using a syntax like: scenes[0].objects["Cube"].data.verts[7].co
383  *
384  * This provides a way to refer to RNA data while being detached from any
385  * particular pointers, which is useful in a number of applications, like
386  * UI code or Actions, though efficiency is a concern. */
387
388 char *RNA_path_append(const char *path, PointerRNA *ptr, PropertyRNA *prop,
389         int intkey, const char *strkey);
390 char *RNA_path_back(const char *path);
391
392 int RNA_path_resolve(PointerRNA *ptr, const char *path,
393         PointerRNA *r_ptr, PropertyRNA **r_prop);
394
395 #if 0
396 /* Dependency
397  *
398  * Experimental code that will generate callbacks for each dependency
399  * between ID types. This may end up being useful for UI
400  * and evaluation code that needs to know such dependencies for correct
401  * redraws and re-evaluations. */
402
403 typedef void (*PropDependencyCallback)(void *udata, PointerRNA *from, PointerRNA *to);
404 void RNA_test_dependencies_cb(void *udata, PointerRNA *from, PointerRNA *to);
405
406 void RNA_generate_dependencies(PointerRNA *mainptr, void *udata, PropDependencyCallback cb);
407 #endif
408
409 /* Quick name based property access
410  *
411  * These are just an easier way to access property values without having to
412  * call RNA_struct_find_property. The names have to exist as RNA properties
413  * for the type in the pointer, if they do not exist an error will be printed.
414  *
415  * There is no support for pointers and collections here yet, these can be 
416  * added when ID properties support them. */
417
418 int RNA_boolean_get(PointerRNA *ptr, const char *name);
419 void RNA_boolean_set(PointerRNA *ptr, const char *name, int value);
420 void RNA_boolean_get_array(PointerRNA *ptr, const char *name, int *values);
421 void RNA_boolean_set_array(PointerRNA *ptr, const char *name, const int *values);
422
423 int RNA_int_get(PointerRNA *ptr, const char *name);
424 void RNA_int_set(PointerRNA *ptr, const char *name, int value);
425 void RNA_int_get_array(PointerRNA *ptr, const char *name, int *values);
426 void RNA_int_set_array(PointerRNA *ptr, const char *name, const int *values);
427
428 float RNA_float_get(PointerRNA *ptr, const char *name);
429 void RNA_float_set(PointerRNA *ptr, const char *name, float value);
430 void RNA_float_get_array(PointerRNA *ptr, const char *name, float *values);
431 void RNA_float_set_array(PointerRNA *ptr, const char *name, const float *values);
432
433 int RNA_enum_get(PointerRNA *ptr, const char *name);
434 void RNA_enum_set(PointerRNA *ptr, const char *name, int value);
435 int RNA_enum_is_equal(PointerRNA *ptr, const char *name, const char *enumname);
436
437 void RNA_string_get(PointerRNA *ptr, const char *name, char *value);
438 char *RNA_string_get_alloc(PointerRNA *ptr, const char *name, char *fixedbuf, int fixedlen);
439 int RNA_string_length(PointerRNA *ptr, const char *name);
440 void RNA_string_set(PointerRNA *ptr, const char *name, const char *value);
441
442 void RNA_pointer_get(PointerRNA *ptr, const char *name, PointerRNA *r_value);
443 void RNA_pointer_add(PointerRNA *ptr, const char *name);
444
445 void RNA_collection_begin(PointerRNA *ptr, const char *name, CollectionPropertyIterator *iter);
446 int RNA_collection_length(PointerRNA *ptr, const char *name);
447 void RNA_collection_add(PointerRNA *ptr, const char *name, PointerRNA *r_value);
448 void RNA_collection_clear(PointerRNA *ptr, const char *name);
449
450 #define RNA_BEGIN(sptr, itemptr, propname) \
451         { \
452                 CollectionPropertyIterator rna_macro_iter; \
453                 for(RNA_collection_begin(sptr, propname, &rna_macro_iter); rna_macro_iter.valid; RNA_property_collection_next(&rna_macro_iter)) { \
454                         PointerRNA itemptr= rna_macro_iter.ptr;
455
456 #define RNA_END \
457                 } \
458                 RNA_property_collection_end(&rna_macro_iter); \
459         }
460
461 /* check if the idproperty exists, for operators */
462 int RNA_property_is_set(PointerRNA *ptr, const char *name);
463
464 /* python compatible string representation of this property, (must be freed!) */
465 char *RNA_property_as_string(PointerRNA *ptr, PropertyRNA *prop);
466
467 #endif /* RNA_ACCESS */
468
469
470