Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/makesrna/intern/rna_object.c')
-rw-r--r--source/blender/makesrna/intern/rna_object.c4266
1 files changed, 2241 insertions, 2025 deletions
diff --git a/source/blender/makesrna/intern/rna_object.c b/source/blender/makesrna/intern/rna_object.c
index c8feff4c0e8..b36e6490e5f 100644
--- a/source/blender/makesrna/intern/rna_object.c
+++ b/source/blender/makesrna/intern/rna_object.c
@@ -61,2721 +61,2937 @@
#include "WM_types.h"
const EnumPropertyItem rna_enum_object_mode_items[] = {
- {OB_MODE_OBJECT, "OBJECT", ICON_OBJECT_DATAMODE, "Object Mode", ""},
- {OB_MODE_EDIT, "EDIT", ICON_EDITMODE_HLT, "Edit Mode", ""},
- {OB_MODE_POSE, "POSE", ICON_POSE_HLT, "Pose Mode", ""},
- {OB_MODE_SCULPT, "SCULPT", ICON_SCULPTMODE_HLT, "Sculpt Mode", ""},
- {OB_MODE_VERTEX_PAINT, "VERTEX_PAINT", ICON_VPAINT_HLT, "Vertex Paint", ""},
- {OB_MODE_WEIGHT_PAINT, "WEIGHT_PAINT", ICON_WPAINT_HLT, "Weight Paint", ""},
- {OB_MODE_TEXTURE_PAINT, "TEXTURE_PAINT", ICON_TPAINT_HLT, "Texture Paint", ""},
- {OB_MODE_PARTICLE_EDIT, "PARTICLE_EDIT", ICON_PARTICLEMODE, "Particle Edit", ""},
- {OB_MODE_EDIT_GPENCIL, "EDIT_GPENCIL", ICON_EDITMODE_HLT, "Edit Mode", "Edit Grease Pencil Strokes"},
- {OB_MODE_SCULPT_GPENCIL, "SCULPT_GPENCIL", ICON_SCULPTMODE_HLT, "Sculpt Mode", "Sculpt Grease Pencil Strokes"},
- {OB_MODE_PAINT_GPENCIL, "PAINT_GPENCIL", ICON_GREASEPENCIL, "Draw", "Paint Grease Pencil Strokes"},
- {OB_MODE_WEIGHT_GPENCIL, "WEIGHT_GPENCIL", ICON_WPAINT_HLT, "Weight Paint", "Grease Pencil Weight Paint Strokes" },
- {0, NULL, 0, NULL, NULL},
+ {OB_MODE_OBJECT, "OBJECT", ICON_OBJECT_DATAMODE, "Object Mode", ""},
+ {OB_MODE_EDIT, "EDIT", ICON_EDITMODE_HLT, "Edit Mode", ""},
+ {OB_MODE_POSE, "POSE", ICON_POSE_HLT, "Pose Mode", ""},
+ {OB_MODE_SCULPT, "SCULPT", ICON_SCULPTMODE_HLT, "Sculpt Mode", ""},
+ {OB_MODE_VERTEX_PAINT, "VERTEX_PAINT", ICON_VPAINT_HLT, "Vertex Paint", ""},
+ {OB_MODE_WEIGHT_PAINT, "WEIGHT_PAINT", ICON_WPAINT_HLT, "Weight Paint", ""},
+ {OB_MODE_TEXTURE_PAINT, "TEXTURE_PAINT", ICON_TPAINT_HLT, "Texture Paint", ""},
+ {OB_MODE_PARTICLE_EDIT, "PARTICLE_EDIT", ICON_PARTICLEMODE, "Particle Edit", ""},
+ {OB_MODE_EDIT_GPENCIL,
+ "EDIT_GPENCIL",
+ ICON_EDITMODE_HLT,
+ "Edit Mode",
+ "Edit Grease Pencil Strokes"},
+ {OB_MODE_SCULPT_GPENCIL,
+ "SCULPT_GPENCIL",
+ ICON_SCULPTMODE_HLT,
+ "Sculpt Mode",
+ "Sculpt Grease Pencil Strokes"},
+ {OB_MODE_PAINT_GPENCIL,
+ "PAINT_GPENCIL",
+ ICON_GREASEPENCIL,
+ "Draw",
+ "Paint Grease Pencil Strokes"},
+ {OB_MODE_WEIGHT_GPENCIL,
+ "WEIGHT_GPENCIL",
+ ICON_WPAINT_HLT,
+ "Weight Paint",
+ "Grease Pencil Weight Paint Strokes"},
+ {0, NULL, 0, NULL, NULL},
};
/* Same as above, but with names that distinguish grease pencil. */
const EnumPropertyItem rna_enum_workspace_object_mode_items[] = {
- {OB_MODE_OBJECT, "OBJECT", ICON_OBJECT_DATAMODE, "Object Mode", ""},
- {OB_MODE_EDIT, "EDIT", ICON_EDITMODE_HLT, "Edit Mode", ""},
- {OB_MODE_POSE, "POSE", ICON_POSE_HLT, "Pose Mode", ""},
- {OB_MODE_SCULPT, "SCULPT", ICON_SCULPTMODE_HLT, "Sculpt Mode", ""},
- {OB_MODE_VERTEX_PAINT, "VERTEX_PAINT", ICON_VPAINT_HLT, "Vertex Paint", ""},
- {OB_MODE_WEIGHT_PAINT, "WEIGHT_PAINT", ICON_WPAINT_HLT, "Weight Paint", ""},
- {OB_MODE_TEXTURE_PAINT, "TEXTURE_PAINT", ICON_TPAINT_HLT, "Texture Paint", ""},
- {OB_MODE_PARTICLE_EDIT, "PARTICLE_EDIT", ICON_PARTICLEMODE, "Particle Edit", ""},
- {OB_MODE_EDIT_GPENCIL, "EDIT_GPENCIL", ICON_EDITMODE_HLT, "Grease Pencil Edit Mode", "Edit Grease Pencil Strokes"},
- {OB_MODE_SCULPT_GPENCIL, "SCULPT_GPENCIL", ICON_SCULPTMODE_HLT, "Grease Pencil Sculpt Mode", "Sculpt Grease Pencil Strokes"},
- {OB_MODE_PAINT_GPENCIL, "PAINT_GPENCIL", ICON_GREASEPENCIL, "Grease Pencil Draw", "Paint Grease Pencil Strokes"},
- {OB_MODE_WEIGHT_GPENCIL, "WEIGHT_GPENCIL", ICON_WPAINT_HLT, "Grease Pencil Weight Paint", "Grease Pencil Weight Paint Strokes" },
- {0, NULL, 0, NULL, NULL},
+ {OB_MODE_OBJECT, "OBJECT", ICON_OBJECT_DATAMODE, "Object Mode", ""},
+ {OB_MODE_EDIT, "EDIT", ICON_EDITMODE_HLT, "Edit Mode", ""},
+ {OB_MODE_POSE, "POSE", ICON_POSE_HLT, "Pose Mode", ""},
+ {OB_MODE_SCULPT, "SCULPT", ICON_SCULPTMODE_HLT, "Sculpt Mode", ""},
+ {OB_MODE_VERTEX_PAINT, "VERTEX_PAINT", ICON_VPAINT_HLT, "Vertex Paint", ""},
+ {OB_MODE_WEIGHT_PAINT, "WEIGHT_PAINT", ICON_WPAINT_HLT, "Weight Paint", ""},
+ {OB_MODE_TEXTURE_PAINT, "TEXTURE_PAINT", ICON_TPAINT_HLT, "Texture Paint", ""},
+ {OB_MODE_PARTICLE_EDIT, "PARTICLE_EDIT", ICON_PARTICLEMODE, "Particle Edit", ""},
+ {OB_MODE_EDIT_GPENCIL,
+ "EDIT_GPENCIL",
+ ICON_EDITMODE_HLT,
+ "Grease Pencil Edit Mode",
+ "Edit Grease Pencil Strokes"},
+ {OB_MODE_SCULPT_GPENCIL,
+ "SCULPT_GPENCIL",
+ ICON_SCULPTMODE_HLT,
+ "Grease Pencil Sculpt Mode",
+ "Sculpt Grease Pencil Strokes"},
+ {OB_MODE_PAINT_GPENCIL,
+ "PAINT_GPENCIL",
+ ICON_GREASEPENCIL,
+ "Grease Pencil Draw",
+ "Paint Grease Pencil Strokes"},
+ {OB_MODE_WEIGHT_GPENCIL,
+ "WEIGHT_GPENCIL",
+ ICON_WPAINT_HLT,
+ "Grease Pencil Weight Paint",
+ "Grease Pencil Weight Paint Strokes"},
+ {0, NULL, 0, NULL, NULL},
};
const EnumPropertyItem rna_enum_object_empty_drawtype_items[] = {
- {OB_PLAINAXES, "PLAIN_AXES", ICON_EMPTY_AXIS, "Plain Axes", ""},
- {OB_ARROWS, "ARROWS", ICON_EMPTY_ARROWS, "Arrows", ""},
- {OB_SINGLE_ARROW, "SINGLE_ARROW", ICON_EMPTY_SINGLE_ARROW, "Single Arrow", ""},
- {OB_CIRCLE, "CIRCLE", ICON_MESH_CIRCLE, "Circle", ""},
- {OB_CUBE, "CUBE", ICON_CUBE, "Cube", ""},
- {OB_EMPTY_SPHERE, "SPHERE", ICON_SPHERE, "Sphere", ""},
- {OB_EMPTY_CONE, "CONE", ICON_CONE, "Cone", ""},
- {OB_EMPTY_IMAGE, "IMAGE", ICON_FILE_IMAGE, "Image", ""},
- {0, NULL, 0, NULL, NULL},
+ {OB_PLAINAXES, "PLAIN_AXES", ICON_EMPTY_AXIS, "Plain Axes", ""},
+ {OB_ARROWS, "ARROWS", ICON_EMPTY_ARROWS, "Arrows", ""},
+ {OB_SINGLE_ARROW, "SINGLE_ARROW", ICON_EMPTY_SINGLE_ARROW, "Single Arrow", ""},
+ {OB_CIRCLE, "CIRCLE", ICON_MESH_CIRCLE, "Circle", ""},
+ {OB_CUBE, "CUBE", ICON_CUBE, "Cube", ""},
+ {OB_EMPTY_SPHERE, "SPHERE", ICON_SPHERE, "Sphere", ""},
+ {OB_EMPTY_CONE, "CONE", ICON_CONE, "Cone", ""},
+ {OB_EMPTY_IMAGE, "IMAGE", ICON_FILE_IMAGE, "Image", ""},
+ {0, NULL, 0, NULL, NULL},
};
static const EnumPropertyItem rna_enum_object_empty_image_depth_items[] = {
- {OB_EMPTY_IMAGE_DEPTH_DEFAULT, "DEFAULT", 0, "Default", ""},
- {OB_EMPTY_IMAGE_DEPTH_FRONT, "FRONT", 0, "Front", ""},
- {OB_EMPTY_IMAGE_DEPTH_BACK, "BACK", 0, "Back", ""},
- {0, NULL, 0, NULL, NULL},
+ {OB_EMPTY_IMAGE_DEPTH_DEFAULT, "DEFAULT", 0, "Default", ""},
+ {OB_EMPTY_IMAGE_DEPTH_FRONT, "FRONT", 0, "Front", ""},
+ {OB_EMPTY_IMAGE_DEPTH_BACK, "BACK", 0, "Back", ""},
+ {0, NULL, 0, NULL, NULL},
};
const EnumPropertyItem rna_enum_object_gpencil_type_items[] = {
- {GP_EMPTY, "EMPTY", ICON_EMPTY_AXIS, "Blank", "Create an empty grease pencil object"},
- {GP_STROKE, "STROKE", ICON_STROKE, "Stroke", "Create a simple stroke with basic colors"},
- {GP_MONKEY, "MONKEY", ICON_MONKEY, "Monkey", "Construct a Suzanne grease pencil object"},
- {0, NULL, 0, NULL, NULL }
-};
+ {GP_EMPTY, "EMPTY", ICON_EMPTY_AXIS, "Blank", "Create an empty grease pencil object"},
+ {GP_STROKE, "STROKE", ICON_STROKE, "Stroke", "Create a simple stroke with basic colors"},
+ {GP_MONKEY, "MONKEY", ICON_MONKEY, "Monkey", "Construct a Suzanne grease pencil object"},
+ {0, NULL, 0, NULL, NULL}};
static const EnumPropertyItem parent_type_items[] = {
- {PAROBJECT, "OBJECT", 0, "Object", "The object is parented to an object"},
- {PARSKEL, "ARMATURE", 0, "Armature", ""},
- {PARSKEL, "LATTICE", 0, "Lattice", "The object is parented to a lattice"}, /* PARSKEL reuse will give issues */
- {PARVERT1, "VERTEX", 0, "Vertex", "The object is parented to a vertex"},
- {PARVERT3, "VERTEX_3", 0, "3 Vertices", ""},
- {PARBONE, "BONE", 0, "Bone", "The object is parented to a bone"},
- {0, NULL, 0, NULL, NULL},
+ {PAROBJECT, "OBJECT", 0, "Object", "The object is parented to an object"},
+ {PARSKEL, "ARMATURE", 0, "Armature", ""},
+ {PARSKEL,
+ "LATTICE",
+ 0,
+ "Lattice",
+ "The object is parented to a lattice"}, /* PARSKEL reuse will give issues */
+ {PARVERT1, "VERTEX", 0, "Vertex", "The object is parented to a vertex"},
+ {PARVERT3, "VERTEX_3", 0, "3 Vertices", ""},
+ {PARBONE, "BONE", 0, "Bone", "The object is parented to a bone"},
+ {0, NULL, 0, NULL, NULL},
};
#define INSTANCE_ITEMS_SHARED \
- {0, "NONE", 0, "None", ""}, \
- {OB_DUPLIVERTS, "VERTS", 0, "Verts", "Instantiate child objects on all vertices"}, \
- {OB_DUPLIFACES, "FACES", 0, "Faces", "Instantiate child objects on all faces"}
+ {0, "NONE", 0, "None", ""}, \
+ {OB_DUPLIVERTS, "VERTS", 0, "Verts", "Instantiate child objects on all vertices"}, \
+ { \
+ OB_DUPLIFACES, "FACES", 0, "Faces", "Instantiate child objects on all faces" \
+ }
#define INSTANCE_ITEM_COLLECTION \
- {OB_DUPLICOLLECTION, "COLLECTION", 0, "Collection", "Enable collection instancing"}
+ { \
+ OB_DUPLICOLLECTION, "COLLECTION", 0, "Collection", "Enable collection instancing" \
+ }
static const EnumPropertyItem instance_items[] = {
- INSTANCE_ITEMS_SHARED,
- INSTANCE_ITEM_COLLECTION,
- {0, NULL, 0, NULL, NULL},
+ INSTANCE_ITEMS_SHARED,
+ INSTANCE_ITEM_COLLECTION,
+ {0, NULL, 0, NULL, NULL},
};
#ifdef RNA_RUNTIME
static EnumPropertyItem instance_items_nogroup[] = {
- INSTANCE_ITEMS_SHARED,
- {0, NULL, 0, NULL, NULL},
+ INSTANCE_ITEMS_SHARED,
+ {0, NULL, 0, NULL, NULL},
};
#endif
#undef INSTANCE_ITEMS_SHARED
#undef INSTANCE_ITEM_COLLECTION
const EnumPropertyItem rna_enum_metaelem_type_items[] = {
- {MB_BALL, "BALL", ICON_META_BALL, "Ball", ""},
- {MB_TUBE, "CAPSULE", ICON_META_CAPSULE, "Capsule", ""},
- {MB_PLANE, "PLANE", ICON_META_PLANE, "Plane", ""},
- {MB_ELIPSOID, "ELLIPSOID", ICON_META_ELLIPSOID, "Ellipsoid", ""}, /* NOTE: typo at original definition! */
- {MB_CUBE, "CUBE", ICON_META_CUBE, "Cube", ""},
- {0, NULL, 0, NULL, NULL},
+ {MB_BALL, "BALL", ICON_META_BALL, "Ball", ""},
+ {MB_TUBE, "CAPSULE", ICON_META_CAPSULE, "Capsule", ""},
+ {MB_PLANE, "PLANE", ICON_META_PLANE, "Plane", ""},
+ {MB_ELIPSOID,
+ "ELLIPSOID",
+ ICON_META_ELLIPSOID,
+ "Ellipsoid",
+ ""}, /* NOTE: typo at original definition! */
+ {MB_CUBE, "CUBE", ICON_META_CUBE, "Cube", ""},
+ {0, NULL, 0, NULL, NULL},
};
/* used for 2 enums */
-#define OBTYPE_CU_CURVE {OB_CURVE, "CURVE", 0, "Curve", ""}
-#define OBTYPE_CU_SURF {OB_SURF, "SURFACE", 0, "Surface", ""}
-#define OBTYPE_CU_FONT {OB_FONT, "FONT", 0, "Font", ""}
+#define OBTYPE_CU_CURVE \
+ { \
+ OB_CURVE, "CURVE", 0, "Curve", "" \
+ }
+#define OBTYPE_CU_SURF \
+ { \
+ OB_SURF, "SURFACE", 0, "Surface", "" \
+ }
+#define OBTYPE_CU_FONT \
+ { \
+ OB_FONT, "FONT", 0, "Font", "" \
+ }
const EnumPropertyItem rna_enum_object_type_items[] = {
- {OB_MESH, "MESH", 0, "Mesh", ""},
- OBTYPE_CU_CURVE,
- OBTYPE_CU_SURF,
- {OB_MBALL, "META", 0, "Meta", ""},
- OBTYPE_CU_FONT,
- {0, "", 0, NULL, NULL},
- {OB_ARMATURE, "ARMATURE", 0, "Armature", ""},
- {OB_LATTICE, "LATTICE", 0, "Lattice", ""},
- {OB_EMPTY, "EMPTY", 0, "Empty", ""},
- {OB_GPENCIL, "GPENCIL", 0, "GPencil", ""},
- {0, "", 0, NULL, NULL},
- {OB_CAMERA, "CAMERA", 0, "Camera", ""},
- {OB_LAMP, "LIGHT", 0, "Light", ""},
- {OB_SPEAKER, "SPEAKER", 0, "Speaker", ""},
- {OB_LIGHTPROBE, "LIGHT_PROBE", 0, "Probe", ""},
- {0, NULL, 0, NULL, NULL},
+ {OB_MESH, "MESH", 0, "Mesh", ""},
+ OBTYPE_CU_CURVE,
+ OBTYPE_CU_SURF,
+ {OB_MBALL, "META", 0, "Meta", ""},
+ OBTYPE_CU_FONT,
+ {0, "", 0, NULL, NULL},
+ {OB_ARMATURE, "ARMATURE", 0, "Armature", ""},
+ {OB_LATTICE, "LATTICE", 0, "Lattice", ""},
+ {OB_EMPTY, "EMPTY", 0, "Empty", ""},
+ {OB_GPENCIL, "GPENCIL", 0, "GPencil", ""},
+ {0, "", 0, NULL, NULL},
+ {OB_CAMERA, "CAMERA", 0, "Camera", ""},
+ {OB_LAMP, "LIGHT", 0, "Light", ""},
+ {OB_SPEAKER, "SPEAKER", 0, "Speaker", ""},
+ {OB_LIGHTPROBE, "LIGHT_PROBE", 0, "Probe", ""},
+ {0, NULL, 0, NULL, NULL},
};
const EnumPropertyItem rna_enum_object_type_curve_items[] = {
- OBTYPE_CU_CURVE,
- OBTYPE_CU_SURF,
- OBTYPE_CU_FONT,
- {0, NULL, 0, NULL, NULL},
+ OBTYPE_CU_CURVE,
+ OBTYPE_CU_SURF,
+ OBTYPE_CU_FONT,
+ {0, NULL, 0, NULL, NULL},
};
const EnumPropertyItem rna_enum_object_rotation_mode_items[] = {
- {ROT_MODE_QUAT, "QUATERNION", 0, "Quaternion (WXYZ)", "No Gimbal Lock"},
- {ROT_MODE_XYZ, "XYZ", 0, "XYZ Euler", "XYZ Rotation Order - prone to Gimbal Lock (default)"},
- {ROT_MODE_XZY, "XZY", 0, "XZY Euler", "XZY Rotation Order - prone to Gimbal Lock"},
- {ROT_MODE_YXZ, "YXZ", 0, "YXZ Euler", "YXZ Rotation Order - prone to Gimbal Lock"},
- {ROT_MODE_YZX, "YZX", 0, "YZX Euler", "YZX Rotation Order - prone to Gimbal Lock"},
- {ROT_MODE_ZXY, "ZXY", 0, "ZXY Euler", "ZXY Rotation Order - prone to Gimbal Lock"},
- {ROT_MODE_ZYX, "ZYX", 0, "ZYX Euler", "ZYX Rotation Order - prone to Gimbal Lock"},
- {ROT_MODE_AXISANGLE, "AXIS_ANGLE", 0, "Axis Angle",
- "Axis Angle (W+XYZ), defines a rotation around some axis defined by 3D-Vector"},
- {0, NULL, 0, NULL, NULL},
+ {ROT_MODE_QUAT, "QUATERNION", 0, "Quaternion (WXYZ)", "No Gimbal Lock"},
+ {ROT_MODE_XYZ, "XYZ", 0, "XYZ Euler", "XYZ Rotation Order - prone to Gimbal Lock (default)"},
+ {ROT_MODE_XZY, "XZY", 0, "XZY Euler", "XZY Rotation Order - prone to Gimbal Lock"},
+ {ROT_MODE_YXZ, "YXZ", 0, "YXZ Euler", "YXZ Rotation Order - prone to Gimbal Lock"},
+ {ROT_MODE_YZX, "YZX", 0, "YZX Euler", "YZX Rotation Order - prone to Gimbal Lock"},
+ {ROT_MODE_ZXY, "ZXY", 0, "ZXY Euler", "ZXY Rotation Order - prone to Gimbal Lock"},
+ {ROT_MODE_ZYX, "ZYX", 0, "ZYX Euler", "ZYX Rotation Order - prone to Gimbal Lock"},
+ {ROT_MODE_AXISANGLE,
+ "AXIS_ANGLE",
+ 0,
+ "Axis Angle",
+ "Axis Angle (W+XYZ), defines a rotation around some axis defined by 3D-Vector"},
+ {0, NULL, 0, NULL, NULL},
};
const EnumPropertyItem rna_enum_object_axis_items[] = {
- {OB_POSX, "POS_X", 0, "+X", ""},
- {OB_POSY, "POS_Y", 0, "+Y", ""},
- {OB_POSZ, "POS_Z", 0, "+Z", ""},
- {OB_NEGX, "NEG_X", 0, "-X", ""},
- {OB_NEGY, "NEG_Y", 0, "-Y", ""},
- {OB_NEGZ, "NEG_Z", 0, "-Z", ""},
- {0, NULL, 0, NULL, NULL},
+ {OB_POSX, "POS_X", 0, "+X", ""},
+ {OB_POSY, "POS_Y", 0, "+Y", ""},
+ {OB_POSZ, "POS_Z", 0, "+Z", ""},
+ {OB_NEGX, "NEG_X", 0, "-X", ""},
+ {OB_NEGY, "NEG_Y", 0, "-Y", ""},
+ {OB_NEGZ, "NEG_Z", 0, "-Z", ""},
+ {0, NULL, 0, NULL, NULL},
};
#ifdef RNA_RUNTIME
-#include "BLI_math.h"
-
-#include "DNA_key_types.h"
-#include "DNA_constraint_types.h"
-#include "DNA_gpencil_types.h"
-#include "DNA_ID.h"
-#include "DNA_lattice_types.h"
-#include "DNA_node_types.h"
-
-#include "BKE_armature.h"
-#include "BKE_brush.h"
-#include "BKE_constraint.h"
-#include "BKE_context.h"
-#include "BKE_curve.h"
-#include "BKE_effect.h"
-#include "BKE_global.h"
-#include "BKE_key.h"
-#include "BKE_object.h"
-#include "BKE_material.h"
-#include "BKE_mesh.h"
-#include "BKE_modifier.h"
-#include "BKE_particle.h"
-#include "BKE_scene.h"
-#include "BKE_deform.h"
-
-#include "DEG_depsgraph.h"
-#include "DEG_depsgraph_build.h"
-
-#include "ED_object.h"
-#include "ED_particle.h"
-#include "ED_curve.h"
-#include "ED_lattice.h"
+# include "BLI_math.h"
+
+# include "DNA_key_types.h"
+# include "DNA_constraint_types.h"
+# include "DNA_gpencil_types.h"
+# include "DNA_ID.h"
+# include "DNA_lattice_types.h"
+# include "DNA_node_types.h"
+
+# include "BKE_armature.h"
+# include "BKE_brush.h"
+# include "BKE_constraint.h"
+# include "BKE_context.h"
+# include "BKE_curve.h"
+# include "BKE_effect.h"
+# include "BKE_global.h"
+# include "BKE_key.h"
+# include "BKE_object.h"
+# include "BKE_material.h"
+# include "BKE_mesh.h"
+# include "BKE_modifier.h"
+# include "BKE_particle.h"
+# include "BKE_scene.h"
+# include "BKE_deform.h"
+
+# include "DEG_depsgraph.h"
+# include "DEG_depsgraph_build.h"
+
+# include "ED_object.h"
+# include "ED_particle.h"
+# include "ED_curve.h"
+# include "ED_lattice.h"
static void rna_Object_internal_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
{
- DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
+ DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
}
-static void rna_Object_internal_update_draw(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
+static void rna_Object_internal_update_draw(Main *UNUSED(bmain),
+ Scene *UNUSED(scene),
+ PointerRNA *ptr)
{
- DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ptr->id.data);
+ DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ptr->id.data);
}
static void rna_Object_matrix_world_update(Main *bmain, Scene *scene, PointerRNA *ptr)
{
- /* don't use compat so we get predictable rotation */
- BKE_object_apply_mat4(ptr->id.data, ((Object *)ptr->id.data)->obmat, false, true);
- rna_Object_internal_update(bmain, scene, ptr);
+ /* don't use compat so we get predictable rotation */
+ BKE_object_apply_mat4(ptr->id.data, ((Object *)ptr->id.data)->obmat, false, true);
+ rna_Object_internal_update(bmain, scene, ptr);
}
static void rna_Object_hide_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
{
- Object *ob = ptr->id.data;
- BKE_main_collection_sync_remap(bmain);
- DEG_id_tag_update(&ob->id, ID_RECALC_COPY_ON_WRITE);
- DEG_relations_tag_update(bmain);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, &ob->id);
+ Object *ob = ptr->id.data;
+ BKE_main_collection_sync_remap(bmain);
+ DEG_id_tag_update(&ob->id, ID_RECALC_COPY_ON_WRITE);
+ DEG_relations_tag_update(bmain);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, &ob->id);
}
static void rna_MaterialIndex_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- if (ob && ob->type == OB_GPENCIL) {
- /* notifying material property in topbar */
- WM_main_add_notifier(NC_SPACE | ND_SPACE_VIEW3D, NULL);
- }
+ Object *ob = (Object *)ptr->id.data;
+ if (ob && ob->type == OB_GPENCIL) {
+ /* notifying material property in topbar */
+ WM_main_add_notifier(NC_SPACE | ND_SPACE_VIEW3D, NULL);
+ }
}
-
static void rna_Object_matrix_local_get(PointerRNA *ptr, float values[16])
{
- Object *ob = ptr->id.data;
- BKE_object_matrix_local_get(ob, (float(*)[4])values);
+ Object *ob = ptr->id.data;
+ BKE_object_matrix_local_get(ob, (float(*)[4])values);
}
static void rna_Object_matrix_local_set(PointerRNA *ptr, const float values[16])
{
- Object *ob = ptr->id.data;
- float local_mat[4][4];
+ Object *ob = ptr->id.data;
+ float local_mat[4][4];
- /* localspace matrix is truly relative to the parent, but parameters stored in object are
- * relative to parentinv matrix. Undo the parent inverse part before applying it as local matrix. */
- if (ob->parent) {
- float invmat[4][4];
- invert_m4_m4(invmat, ob->parentinv);
- mul_m4_m4m4(local_mat, invmat, (float(*)[4])values);
- }
- else {
- copy_m4_m4(local_mat, (float(*)[4])values);
- }
+ /* localspace matrix is truly relative to the parent, but parameters stored in object are
+ * relative to parentinv matrix. Undo the parent inverse part before applying it as local matrix. */
+ if (ob->parent) {
+ float invmat[4][4];
+ invert_m4_m4(invmat, ob->parentinv);
+ mul_m4_m4m4(local_mat, invmat, (float(*)[4])values);
+ }
+ else {
+ copy_m4_m4(local_mat, (float(*)[4])values);
+ }
- /* don't use compat so we get predictable rotation, and do not use parenting either, because it's a local matrix! */
- BKE_object_apply_mat4(ob, local_mat, false, false);
+ /* don't use compat so we get predictable rotation, and do not use parenting either, because it's a local matrix! */
+ BKE_object_apply_mat4(ob, local_mat, false, false);
}
static void rna_Object_matrix_basis_get(PointerRNA *ptr, float values[16])
{
- Object *ob = ptr->id.data;
- BKE_object_to_mat4(ob, (float(*)[4])values);
+ Object *ob = ptr->id.data;
+ BKE_object_to_mat4(ob, (float(*)[4])values);
}
static void rna_Object_matrix_basis_set(PointerRNA *ptr, const float values[16])
{
- Object *ob = ptr->id.data;
- BKE_object_apply_mat4(ob, (float(*)[4])values, false, false);
+ Object *ob = ptr->id.data;
+ BKE_object_apply_mat4(ob, (float(*)[4])values, false, false);
}
void rna_Object_internal_update_data(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
{
- DEG_id_tag_update(ptr->id.data, ID_RECALC_GEOMETRY);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ptr->id.data);
+ DEG_id_tag_update(ptr->id.data, ID_RECALC_GEOMETRY);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ptr->id.data);
}
static void rna_Object_active_shape_update(bContext *C, PointerRNA *ptr)
{
- Object *ob = ptr->id.data;
- Main *bmain = CTX_data_main(C);
- Scene *scene = CTX_data_scene(C);
-
- if (CTX_data_edit_object(C) == ob) {
- /* exit/enter editmode to get new shape */
- switch (ob->type) {
- case OB_MESH:
- EDBM_mesh_load(bmain, ob);
- EDBM_mesh_make(ob, scene->toolsettings->selectmode, true);
-
- DEG_id_tag_update(ob->data, 0);
-
- EDBM_mesh_normals_update(((Mesh *)ob->data)->edit_mesh);
- BKE_editmesh_tessface_calc(((Mesh *)ob->data)->edit_mesh);
- break;
- case OB_CURVE:
- case OB_SURF:
- ED_curve_editnurb_load(bmain, ob);
- ED_curve_editnurb_make(ob);
- break;
- case OB_LATTICE:
- BKE_editlattice_load(ob);
- BKE_editlattice_make(ob);
- break;
- }
- }
-
- rna_Object_internal_update_data(bmain, scene, ptr);
+ Object *ob = ptr->id.data;
+ Main *bmain = CTX_data_main(C);
+ Scene *scene = CTX_data_scene(C);
+
+ if (CTX_data_edit_object(C) == ob) {
+ /* exit/enter editmode to get new shape */
+ switch (ob->type) {
+ case OB_MESH:
+ EDBM_mesh_load(bmain, ob);
+ EDBM_mesh_make(ob, scene->toolsettings->selectmode, true);
+
+ DEG_id_tag_update(ob->data, 0);
+
+ EDBM_mesh_normals_update(((Mesh *)ob->data)->edit_mesh);
+ BKE_editmesh_tessface_calc(((Mesh *)ob->data)->edit_mesh);
+ break;
+ case OB_CURVE:
+ case OB_SURF:
+ ED_curve_editnurb_load(bmain, ob);
+ ED_curve_editnurb_make(ob);
+ break;
+ case OB_LATTICE:
+ BKE_editlattice_load(ob);
+ BKE_editlattice_make(ob);
+ break;
+ }
+ }
+
+ rna_Object_internal_update_data(bmain, scene, ptr);
}
static void rna_Object_dependency_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
{
- DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
- DEG_relations_tag_update(bmain);
- WM_main_add_notifier(NC_OBJECT | ND_PARENT, ptr->id.data);
+ DEG_id_tag_update(ptr->id.data, ID_RECALC_TRANSFORM);
+ DEG_relations_tag_update(bmain);
+ WM_main_add_notifier(NC_OBJECT | ND_PARENT, ptr->id.data);
}
static void rna_Object_data_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->data;
- ID *id = value.data;
-
- if (ob->mode & OB_MODE_EDIT) {
- return;
- }
-
- /* assigning NULL only for empties */
- if ((id == NULL) && (ob->type != OB_EMPTY)) {
- return;
- }
-
- BLI_assert(BKE_id_is_in_global_main(&ob->id));
- BLI_assert(BKE_id_is_in_global_main(id));
-
- if (ob->type == OB_EMPTY) {
- if (ob->data) {
- id_us_min((ID *)ob->data);
- ob->data = NULL;
- }
-
- if (!id || GS(id->name) == ID_IM) {
- id_us_plus(id);
- ob->data = id;
- }
- }
- else if (ob->type == OB_MESH) {
- BKE_mesh_assign_object(G_MAIN, ob, (Mesh *)id);
- }
- else {
- if (ob->data) {
- id_us_min((ID *)ob->data);
- }
-
- /* no need to type-check here ID. this is done in the _typef() function */
- BLI_assert(OB_DATA_SUPPORT_ID(GS(id->name)));
- id_us_plus(id);
-
- ob->data = id;
- test_object_materials(G_MAIN, ob, id);
-
- if (GS(id->name) == ID_CU) {
- BKE_curve_type_test(ob);
- }
- else if (ob->type == OB_ARMATURE) {
- BKE_pose_rebuild(G_MAIN, ob, ob->data, true);
- }
- }
+ Object *ob = (Object *)ptr->data;
+ ID *id = value.data;
+
+ if (ob->mode & OB_MODE_EDIT) {
+ return;
+ }
+
+ /* assigning NULL only for empties */
+ if ((id == NULL) && (ob->type != OB_EMPTY)) {
+ return;
+ }
+
+ BLI_assert(BKE_id_is_in_global_main(&ob->id));
+ BLI_assert(BKE_id_is_in_global_main(id));
+
+ if (ob->type == OB_EMPTY) {
+ if (ob->data) {
+ id_us_min((ID *)ob->data);
+ ob->data = NULL;
+ }
+
+ if (!id || GS(id->name) == ID_IM) {
+ id_us_plus(id);
+ ob->data = id;
+ }
+ }
+ else if (ob->type == OB_MESH) {
+ BKE_mesh_assign_object(G_MAIN, ob, (Mesh *)id);
+ }
+ else {
+ if (ob->data) {
+ id_us_min((ID *)ob->data);
+ }
+
+ /* no need to type-check here ID. this is done in the _typef() function */
+ BLI_assert(OB_DATA_SUPPORT_ID(GS(id->name)));
+ id_us_plus(id);
+
+ ob->data = id;
+ test_object_materials(G_MAIN, ob, id);
+
+ if (GS(id->name) == ID_CU) {
+ BKE_curve_type_test(ob);
+ }
+ else if (ob->type == OB_ARMATURE) {
+ BKE_pose_rebuild(G_MAIN, ob, ob->data, true);
+ }
+ }
}
static StructRNA *rna_Object_data_typef(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->data;
-
- /* keep in sync with OB_DATA_SUPPORT_ID() macro */
- switch (ob->type) {
- case OB_EMPTY: return &RNA_Image;
- case OB_MESH: return &RNA_Mesh;
- case OB_CURVE: return &RNA_Curve;
- case OB_SURF: return &RNA_Curve;
- case OB_FONT: return &RNA_Curve;
- case OB_MBALL: return &RNA_MetaBall;
- case OB_LAMP: return &RNA_Light;
- case OB_CAMERA: return &RNA_Camera;
- case OB_LATTICE: return &RNA_Lattice;
- case OB_ARMATURE: return &RNA_Armature;
- case OB_SPEAKER: return &RNA_Speaker;
- case OB_LIGHTPROBE: return &RNA_LightProbe;
- case OB_GPENCIL: return &RNA_GreasePencil;
- default: return &RNA_ID;
- }
+ Object *ob = (Object *)ptr->data;
+
+ /* keep in sync with OB_DATA_SUPPORT_ID() macro */
+ switch (ob->type) {
+ case OB_EMPTY:
+ return &RNA_Image;
+ case OB_MESH:
+ return &RNA_Mesh;
+ case OB_CURVE:
+ return &RNA_Curve;
+ case OB_SURF:
+ return &RNA_Curve;
+ case OB_FONT:
+ return &RNA_Curve;
+ case OB_MBALL:
+ return &RNA_MetaBall;
+ case OB_LAMP:
+ return &RNA_Light;
+ case OB_CAMERA:
+ return &RNA_Camera;
+ case OB_LATTICE:
+ return &RNA_Lattice;
+ case OB_ARMATURE:
+ return &RNA_Armature;
+ case OB_SPEAKER:
+ return &RNA_Speaker;
+ case OB_LIGHTPROBE:
+ return &RNA_LightProbe;
+ case OB_GPENCIL:
+ return &RNA_GreasePencil;
+ default:
+ return &RNA_ID;
+ }
}
static bool rna_Object_data_poll(PointerRNA *ptr, const PointerRNA value)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- if (ob->type == OB_GPENCIL) {
- /* GP Object - Don't allow using "Annotation" GP datablocks here */
- bGPdata *gpd = value.data;
- return (gpd->flag & GP_DATA_ANNOTATIONS) == 0;
- }
+ if (ob->type == OB_GPENCIL) {
+ /* GP Object - Don't allow using "Annotation" GP datablocks here */
+ bGPdata *gpd = value.data;
+ return (gpd->flag & GP_DATA_ANNOTATIONS) == 0;
+ }
- return true;
+ return true;
}
static void rna_Object_parent_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->data;
- Object *par = (Object *)value.data;
+ Object *ob = (Object *)ptr->data;
+ Object *par = (Object *)value.data;
- {
- ED_object_parent(ob, par, ob->partype, ob->parsubstr);
- }
+ {
+ ED_object_parent(ob, par, ob->partype, ob->parsubstr);
+ }
}
static void rna_Object_parent_type_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- ED_object_parent(ob, ob->parent, value, ob->parsubstr);
+ ED_object_parent(ob, ob->parent, value, ob->parsubstr);
}
-static const EnumPropertyItem *rna_Object_parent_type_itemf(
- bContext *UNUSED(C), PointerRNA *ptr,
- PropertyRNA *UNUSED(prop), bool *r_free)
+static const EnumPropertyItem *rna_Object_parent_type_itemf(bContext *UNUSED(C),
+ PointerRNA *ptr,
+ PropertyRNA *UNUSED(prop),
+ bool *r_free)
{
- Object *ob = (Object *)ptr->data;
- EnumPropertyItem *item = NULL;
- int totitem = 0;
+ Object *ob = (Object *)ptr->data;
+ EnumPropertyItem *item = NULL;
+ int totitem = 0;
- RNA_enum_items_add_value(&item, &totitem, parent_type_items, PAROBJECT);
+ RNA_enum_items_add_value(&item, &totitem, parent_type_items, PAROBJECT);
- if (ob->parent) {
- Object *par = ob->parent;
+ if (ob->parent) {
+ Object *par = ob->parent;
- if (par->type == OB_LATTICE) {
- /* special hack: prevents this overriding others */
- RNA_enum_items_add_value(&item, &totitem, &parent_type_items[2], PARSKEL);
- }
- else if (par->type == OB_ARMATURE) {
- /* special hack: prevents this being overridden */
- RNA_enum_items_add_value(&item, &totitem, &parent_type_items[1], PARSKEL);
- RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARBONE);
- }
+ if (par->type == OB_LATTICE) {
+ /* special hack: prevents this overriding others */
+ RNA_enum_items_add_value(&item, &totitem, &parent_type_items[2], PARSKEL);
+ }
+ else if (par->type == OB_ARMATURE) {
+ /* special hack: prevents this being overridden */
+ RNA_enum_items_add_value(&item, &totitem, &parent_type_items[1], PARSKEL);
+ RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARBONE);
+ }
- if (OB_TYPE_SUPPORT_PARVERT(par->type)) {
- RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT1);
- RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT3);
- }
- }
+ if (OB_TYPE_SUPPORT_PARVERT(par->type)) {
+ RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT1);
+ RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT3);
+ }
+ }
- RNA_enum_item_end(&item, &totitem);
- *r_free = true;
+ RNA_enum_item_end(&item, &totitem);
+ *r_free = true;
- return item;
+ return item;
}
static void rna_Object_empty_display_type_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- BKE_object_empty_draw_type_set(ob, value);
+ BKE_object_empty_draw_type_set(ob, value);
}
static void rna_Object_parent_bone_set(PointerRNA *ptr, const char *value)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- ED_object_parent(ob, ob->parent, ob->partype, value);
+ ED_object_parent(ob, ob->parent, ob->partype, value);
}
-static const EnumPropertyItem *rna_Object_instance_type_itemf(
- bContext *UNUSED(C), PointerRNA *ptr,
- PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
+static const EnumPropertyItem *rna_Object_instance_type_itemf(bContext *UNUSED(C),
+ PointerRNA *ptr,
+ PropertyRNA *UNUSED(prop),
+ bool *UNUSED(r_free))
{
- Object *ob = (Object *)ptr->data;
- const EnumPropertyItem *item;
+ Object *ob = (Object *)ptr->data;
+ const EnumPropertyItem *item;
- if (ob->type == OB_EMPTY) {
- item = instance_items;
- }
- else {
- item = instance_items_nogroup;
- }
+ if (ob->type == OB_EMPTY) {
+ item = instance_items;
+ }
+ else {
+ item = instance_items_nogroup;
+ }
- return item;
+ return item;
}
static void rna_Object_dup_collection_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->data;
- Collection *grp = (Collection *)value.data;
-
- /* must not let this be set if the object belongs in this group already,
- * thus causing a cycle/infinite-recursion leading to crashes on load [#25298]
- */
- if (BKE_collection_has_object_recursive(grp, ob) == 0) {
- if (ob->type == OB_EMPTY) {
- id_us_min(&ob->instance_collection->id);
- ob->instance_collection = grp;
- id_us_plus(&ob->instance_collection->id);
- }
- else {
- BKE_report(NULL, RPT_ERROR,
- "Only empty objects support group instances");
- }
- }
- else {
- BKE_report(NULL, RPT_ERROR,
- "Cannot set instance-collection as object belongs in group being instanced, thus causing a cycle");
- }
+ Object *ob = (Object *)ptr->data;
+ Collection *grp = (Collection *)value.data;
+
+ /* must not let this be set if the object belongs in this group already,
+ * thus causing a cycle/infinite-recursion leading to crashes on load [#25298]
+ */
+ if (BKE_collection_has_object_recursive(grp, ob) == 0) {
+ if (ob->type == OB_EMPTY) {
+ id_us_min(&ob->instance_collection->id);
+ ob->instance_collection = grp;
+ id_us_plus(&ob->instance_collection->id);
+ }
+ else {
+ BKE_report(NULL, RPT_ERROR, "Only empty objects support group instances");
+ }
+ }
+ else {
+ BKE_report(NULL,
+ RPT_ERROR,
+ "Cannot set instance-collection as object belongs in group being instanced, thus "
+ "causing a cycle");
+ }
}
static void rna_VertexGroup_name_set(PointerRNA *ptr, const char *value)
{
- Object *ob = (Object *)ptr->id.data;
- bDeformGroup *dg = (bDeformGroup *)ptr->data;
- BLI_strncpy_utf8(dg->name, value, sizeof(dg->name));
- defgroup_unique_name(dg, ob);
+ Object *ob = (Object *)ptr->id.data;
+ bDeformGroup *dg = (bDeformGroup *)ptr->data;
+ BLI_strncpy_utf8(dg->name, value, sizeof(dg->name));
+ defgroup_unique_name(dg, ob);
}
static int rna_VertexGroup_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- return BLI_findindex(&ob->defbase, ptr->data);
+ return BLI_findindex(&ob->defbase, ptr->data);
}
static PointerRNA rna_Object_active_vertex_group_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return rna_pointer_inherit_refine(ptr, &RNA_VertexGroup, BLI_findlink(&ob->defbase, ob->actdef - 1));
+ Object *ob = (Object *)ptr->id.data;
+ return rna_pointer_inherit_refine(
+ ptr, &RNA_VertexGroup, BLI_findlink(&ob->defbase, ob->actdef - 1));
}
static int rna_Object_active_vertex_group_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return ob->actdef - 1;
+ Object *ob = (Object *)ptr->id.data;
+ return ob->actdef - 1;
}
static void rna_Object_active_vertex_group_index_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
- ob->actdef = value + 1;
+ Object *ob = (Object *)ptr->id.data;
+ ob->actdef = value + 1;
}
-static void rna_Object_active_vertex_group_index_range(PointerRNA *ptr, int *min, int *max,
- int *UNUSED(softmin), int *UNUSED(softmax))
+static void rna_Object_active_vertex_group_index_range(
+ PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- *min = 0;
- *max = max_ii(0, BLI_listbase_count(&ob->defbase) - 1);
+ *min = 0;
+ *max = max_ii(0, BLI_listbase_count(&ob->defbase) - 1);
}
void rna_object_vgroup_name_index_get(PointerRNA *ptr, char *value, int index)
{
- Object *ob = (Object *)ptr->id.data;
- bDeformGroup *dg;
+ Object *ob = (Object *)ptr->id.data;
+ bDeformGroup *dg;
- dg = BLI_findlink(&ob->defbase, index - 1);
+ dg = BLI_findlink(&ob->defbase, index - 1);
- if (dg) BLI_strncpy(value, dg->name, sizeof(dg->name));
- else value[0] = '\0';
+ if (dg)
+ BLI_strncpy(value, dg->name, sizeof(dg->name));
+ else
+ value[0] = '\0';
}
int rna_object_vgroup_name_index_length(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->id.data;
- bDeformGroup *dg;
+ Object *ob = (Object *)ptr->id.data;
+ bDeformGroup *dg;
- dg = BLI_findlink(&ob->defbase, index - 1);
- return (dg) ? strlen(dg->name) : 0;
+ dg = BLI_findlink(&ob->defbase, index - 1);
+ return (dg) ? strlen(dg->name) : 0;
}
void rna_object_vgroup_name_index_set(PointerRNA *ptr, const char *value, short *index)
{
- Object *ob = (Object *)ptr->id.data;
- *index = defgroup_name_index(ob, value) + 1;
+ Object *ob = (Object *)ptr->id.data;
+ *index = defgroup_name_index(ob, value) + 1;
}
void rna_object_vgroup_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
{
- Object *ob = (Object *)ptr->id.data;
- bDeformGroup *dg = defgroup_find_name(ob, value);
- if (dg) {
- BLI_strncpy(result, value, maxlen); /* no need for BLI_strncpy_utf8, since this matches an existing group */
- return;
- }
+ Object *ob = (Object *)ptr->id.data;
+ bDeformGroup *dg = defgroup_find_name(ob, value);
+ if (dg) {
+ BLI_strncpy(result,
+ value,
+ maxlen); /* no need for BLI_strncpy_utf8, since this matches an existing group */
+ return;
+ }
- result[0] = '\0';
+ result[0] = '\0';
}
static void rna_FaceMap_name_set(PointerRNA *ptr, const char *value)
{
- Object *ob = (Object *)ptr->id.data;
- bFaceMap *fmap = (bFaceMap *)ptr->data;
- BLI_strncpy_utf8(fmap->name, value, sizeof(fmap->name));
- BKE_object_facemap_unique_name(ob, fmap);
+ Object *ob = (Object *)ptr->id.data;
+ bFaceMap *fmap = (bFaceMap *)ptr->data;
+ BLI_strncpy_utf8(fmap->name, value, sizeof(fmap->name));
+ BKE_object_facemap_unique_name(ob, fmap);
}
static int rna_FaceMap_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- return BLI_findindex(&ob->fmaps, ptr->data);
+ return BLI_findindex(&ob->fmaps, ptr->data);
}
static PointerRNA rna_Object_active_face_map_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return rna_pointer_inherit_refine(ptr, &RNA_FaceMap, BLI_findlink(&ob->fmaps, ob->actfmap - 1));
+ Object *ob = (Object *)ptr->id.data;
+ return rna_pointer_inherit_refine(ptr, &RNA_FaceMap, BLI_findlink(&ob->fmaps, ob->actfmap - 1));
}
static int rna_Object_active_face_map_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return ob->actfmap - 1;
+ Object *ob = (Object *)ptr->id.data;
+ return ob->actfmap - 1;
}
static void rna_Object_active_face_map_index_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
- ob->actfmap = value + 1;
+ Object *ob = (Object *)ptr->id.data;
+ ob->actfmap = value + 1;
}
-static void rna_Object_active_face_map_index_range(PointerRNA *ptr, int *min, int *max,
- int *UNUSED(softmin), int *UNUSED(softmax))
+static void rna_Object_active_face_map_index_range(
+ PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- *min = 0;
- *max = max_ii(0, BLI_listbase_count(&ob->fmaps) - 1);
+ *min = 0;
+ *max = max_ii(0, BLI_listbase_count(&ob->fmaps) - 1);
}
void rna_object_BKE_object_facemap_name_index_get(PointerRNA *ptr, char *value, int index)
{
- Object *ob = (Object *)ptr->id.data;
- bFaceMap *fmap;
+ Object *ob = (Object *)ptr->id.data;
+ bFaceMap *fmap;
- fmap = BLI_findlink(&ob->fmaps, index - 1);
+ fmap = BLI_findlink(&ob->fmaps, index - 1);
- if (fmap) BLI_strncpy(value, fmap->name, sizeof(fmap->name));
- else value[0] = '\0';
+ if (fmap)
+ BLI_strncpy(value, fmap->name, sizeof(fmap->name));
+ else
+ value[0] = '\0';
}
int rna_object_BKE_object_facemap_name_index_length(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->id.data;
- bFaceMap *fmap;
+ Object *ob = (Object *)ptr->id.data;
+ bFaceMap *fmap;
- fmap = BLI_findlink(&ob->fmaps, index - 1);
- return (fmap) ? strlen(fmap->name) : 0;
+ fmap = BLI_findlink(&ob->fmaps, index - 1);
+ return (fmap) ? strlen(fmap->name) : 0;
}
void rna_object_BKE_object_facemap_name_index_set(PointerRNA *ptr, const char *value, short *index)
{
- Object *ob = (Object *)ptr->id.data;
- *index = BKE_object_facemap_name_index(ob, value) + 1;
+ Object *ob = (Object *)ptr->id.data;
+ *index = BKE_object_facemap_name_index(ob, value) + 1;
}
void rna_object_fmap_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
{
- Object *ob = (Object *)ptr->id.data;
- bFaceMap *fmap = BKE_object_facemap_find_name(ob, value);
- if (fmap) {
- BLI_strncpy(result, value, maxlen); /* no need for BLI_strncpy_utf8, since this matches an existing group */
- return;
- }
+ Object *ob = (Object *)ptr->id.data;
+ bFaceMap *fmap = BKE_object_facemap_find_name(ob, value);
+ if (fmap) {
+ BLI_strncpy(result,
+ value,
+ maxlen); /* no need for BLI_strncpy_utf8, since this matches an existing group */
+ return;
+ }
- result[0] = '\0';
+ result[0] = '\0';
}
-
void rna_object_uvlayer_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
{
- Object *ob = (Object *)ptr->id.data;
- Mesh *me;
- CustomDataLayer *layer;
- int a;
+ Object *ob = (Object *)ptr->id.data;
+ Mesh *me;
+ CustomDataLayer *layer;
+ int a;
- if (ob->type == OB_MESH && ob->data) {
- me = (Mesh *)ob->data;
+ if (ob->type == OB_MESH && ob->data) {
+ me = (Mesh *)ob->data;
- for (a = 0; a < me->ldata.totlayer; a++) {
- layer = &me->ldata.layers[a];
+ for (a = 0; a < me->ldata.totlayer; a++) {
+ layer = &me->ldata.layers[a];
- if (layer->type == CD_MLOOPUV && STREQ(layer->name, value)) {
- BLI_strncpy(result, value, maxlen);
- return;
- }
- }
- }
+ if (layer->type == CD_MLOOPUV && STREQ(layer->name, value)) {
+ BLI_strncpy(result, value, maxlen);
+ return;
+ }
+ }
+ }
- result[0] = '\0';
+ result[0] = '\0';
}
void rna_object_vcollayer_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
{
- Object *ob = (Object *)ptr->id.data;
- Mesh *me;
- CustomDataLayer *layer;
- int a;
+ Object *ob = (Object *)ptr->id.data;
+ Mesh *me;
+ CustomDataLayer *layer;
+ int a;
- if (ob->type == OB_MESH && ob->data) {
- me = (Mesh *)ob->data;
+ if (ob->type == OB_MESH && ob->data) {
+ me = (Mesh *)ob->data;
- for (a = 0; a < me->fdata.totlayer; a++) {
- layer = &me->fdata.layers[a];
+ for (a = 0; a < me->fdata.totlayer; a++) {
+ layer = &me->fdata.layers[a];
- if (layer->type == CD_MCOL && STREQ(layer->name, value)) {
- BLI_strncpy(result, value, maxlen);
- return;
- }
- }
- }
+ if (layer->type == CD_MCOL && STREQ(layer->name, value)) {
+ BLI_strncpy(result, value, maxlen);
+ return;
+ }
+ }
+ }
- result[0] = '\0';
+ result[0] = '\0';
}
static int rna_Object_active_material_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return MAX2(ob->actcol - 1, 0);
+ Object *ob = (Object *)ptr->id.data;
+ return MAX2(ob->actcol - 1, 0);
}
static void rna_Object_active_material_index_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
- ob->actcol = value + 1;
+ Object *ob = (Object *)ptr->id.data;
+ ob->actcol = value + 1;
- if (ob->type == OB_MESH) {
- Mesh *me = ob->data;
+ if (ob->type == OB_MESH) {
+ Mesh *me = ob->data;
- if (me->edit_mesh)
- me->edit_mesh->mat_nr = value;
- }
+ if (me->edit_mesh)
+ me->edit_mesh->mat_nr = value;
+ }
}
-static void rna_Object_active_material_index_range(PointerRNA *ptr, int *min, int *max,
- int *UNUSED(softmin), int *UNUSED(softmax))
+static void rna_Object_active_material_index_range(
+ PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
{
- Object *ob = (Object *)ptr->id.data;
- *min = 0;
- *max = max_ii(ob->totcol - 1, 0);
+ Object *ob = (Object *)ptr->id.data;
+ *min = 0;
+ *max = max_ii(ob->totcol - 1, 0);
}
/* returns active base material */
static PointerRNA rna_Object_active_material_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- Material *ma;
+ Object *ob = (Object *)ptr->id.data;
+ Material *ma;
- ma = (ob->totcol) ? give_current_material(ob, ob->actcol) : NULL;
- return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
+ ma = (ob->totcol) ? give_current_material(ob, ob->actcol) : NULL;
+ return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
}
static void rna_Object_active_material_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- DEG_id_tag_update(value.data, 0);
- BLI_assert(BKE_id_is_in_global_main(&ob->id));
- BLI_assert(BKE_id_is_in_global_main(value.data));
- assign_material(G_MAIN, ob, value.data, ob->actcol, BKE_MAT_ASSIGN_EXISTING);
+ DEG_id_tag_update(value.data, 0);
+ BLI_assert(BKE_id_is_in_global_main(&ob->id));
+ BLI_assert(BKE_id_is_in_global_main(value.data));
+ assign_material(G_MAIN, ob, value.data, ob->actcol, BKE_MAT_ASSIGN_EXISTING);
- if (ob && ob->type == OB_GPENCIL) {
- /* notifying material property in topbar */
- WM_main_add_notifier(NC_SPACE | ND_SPACE_VIEW3D, NULL);
- }
+ if (ob && ob->type == OB_GPENCIL) {
+ /* notifying material property in topbar */
+ WM_main_add_notifier(NC_SPACE | ND_SPACE_VIEW3D, NULL);
+ }
}
static int rna_Object_active_material_editable(PointerRNA *ptr, const char **UNUSED(r_info))
{
- Object *ob = (Object *)ptr->id.data;
- bool is_editable;
+ Object *ob = (Object *)ptr->id.data;
+ bool is_editable;
- if ((ob->matbits == NULL) || (ob->actcol == 0) || ob->matbits[ob->actcol - 1]) {
- is_editable = !ID_IS_LINKED(ob);
- }
- else {
- is_editable = ob->data ? !ID_IS_LINKED(ob->data) : false;
- }
+ if ((ob->matbits == NULL) || (ob->actcol == 0) || ob->matbits[ob->actcol - 1]) {
+ is_editable = !ID_IS_LINKED(ob);
+ }
+ else {
+ is_editable = ob->data ? !ID_IS_LINKED(ob->data) : false;
+ }
- return is_editable ? PROP_EDITABLE : 0;
+ return is_editable ? PROP_EDITABLE : 0;
}
-
-static void rna_Object_active_particle_system_index_range(PointerRNA *ptr, int *min, int *max,
- int *UNUSED(softmin), int *UNUSED(softmax))
+static void rna_Object_active_particle_system_index_range(
+ PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
{
- Object *ob = (Object *)ptr->id.data;
- *min = 0;
- *max = max_ii(0, BLI_listbase_count(&ob->particlesystem) - 1);
+ Object *ob = (Object *)ptr->id.data;
+ *min = 0;
+ *max = max_ii(0, BLI_listbase_count(&ob->particlesystem) - 1);
}
static int rna_Object_active_particle_system_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- return psys_get_current_num(ob);
+ Object *ob = (Object *)ptr->id.data;
+ return psys_get_current_num(ob);
}
static void rna_Object_active_particle_system_index_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
- psys_set_current_num(ob, value);
+ Object *ob = (Object *)ptr->id.data;
+ psys_set_current_num(ob, value);
}
static void rna_Object_particle_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *ptr)
{
- /* TODO: Disabled for now, because bContext is not available. */
-#if 0
- Object *ob = (Object *)ptr->id.data;
- PE_current_changed(NULL, scene, ob);
-#else
- (void) scene;
- (void) ptr;
-#endif
+ /* TODO: Disabled for now, because bContext is not available. */
+# if 0
+ Object *ob = (Object *)ptr->id.data;
+ PE_current_changed(NULL, scene, ob);
+# else
+ (void)scene;
+ (void)ptr;
+# endif
}
/* rotation - axis-angle */
static void rna_Object_rotation_axis_angle_get(PointerRNA *ptr, float *value)
{
- Object *ob = ptr->data;
+ Object *ob = ptr->data;
- /* for now, assume that rotation mode is axis-angle */
- value[0] = ob->rotAngle;
- copy_v3_v3(&value[1], ob->rotAxis);
+ /* for now, assume that rotation mode is axis-angle */
+ value[0] = ob->rotAngle;
+ copy_v3_v3(&value[1], ob->rotAxis);
}
/* rotation - axis-angle */
static void rna_Object_rotation_axis_angle_set(PointerRNA *ptr, const float *value)
{
- Object *ob = ptr->data;
+ Object *ob = ptr->data;
- /* for now, assume that rotation mode is axis-angle */
- ob->rotAngle = value[0];
- copy_v3_v3(ob->rotAxis, &value[1]);
+ /* for now, assume that rotation mode is axis-angle */
+ ob->rotAngle = value[0];
+ copy_v3_v3(ob->rotAxis, &value[1]);
- /* TODO: validate axis? */
+ /* TODO: validate axis? */
}
static void rna_Object_rotation_mode_set(PointerRNA *ptr, int value)
{
- Object *ob = ptr->data;
+ Object *ob = ptr->data;
- /* use API Method for conversions... */
- BKE_rotMode_change_values(ob->quat, ob->rot, ob->rotAxis, &ob->rotAngle, ob->rotmode, (short)value);
+ /* use API Method for conversions... */
+ BKE_rotMode_change_values(
+ ob->quat, ob->rot, ob->rotAxis, &ob->rotAngle, ob->rotmode, (short)value);
- /* finally, set the new rotation type */
- ob->rotmode = value;
+ /* finally, set the new rotation type */
+ ob->rotmode = value;
}
static void rna_Object_dimensions_get(PointerRNA *ptr, float *value)
{
- Object *ob = ptr->data;
- BKE_object_dimensions_get(ob, value);
+ Object *ob = ptr->data;
+ BKE_object_dimensions_get(ob, value);
}
static void rna_Object_dimensions_set(PointerRNA *ptr, const float *value)
{
- Object *ob = ptr->data;
- BKE_object_dimensions_set(ob, value, 0);
+ Object *ob = ptr->data;
+ BKE_object_dimensions_set(ob, value, 0);
}
static int rna_Object_location_editable(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- /* only if the axis in question is locked, not editable... */
- if ((index == 0) && (ob->protectflag & OB_LOCK_LOCX))
- return 0;
- else if ((index == 1) && (ob->protectflag & OB_LOCK_LOCY))
- return 0;
- else if ((index == 2) && (ob->protectflag & OB_LOCK_LOCZ))
- return 0;
- else
- return PROP_EDITABLE;
+ /* only if the axis in question is locked, not editable... */
+ if ((index == 0) && (ob->protectflag & OB_LOCK_LOCX))
+ return 0;
+ else if ((index == 1) && (ob->protectflag & OB_LOCK_LOCY))
+ return 0;
+ else if ((index == 2) && (ob->protectflag & OB_LOCK_LOCZ))
+ return 0;
+ else
+ return PROP_EDITABLE;
}
static int rna_Object_scale_editable(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- /* only if the axis in question is locked, not editable... */
- if ((index == 0) && (ob->protectflag & OB_LOCK_SCALEX))
- return 0;
- else if ((index == 1) && (ob->protectflag & OB_LOCK_SCALEY))
- return 0;
- else if ((index == 2) && (ob->protectflag & OB_LOCK_SCALEZ))
- return 0;
- else
- return PROP_EDITABLE;
+ /* only if the axis in question is locked, not editable... */
+ if ((index == 0) && (ob->protectflag & OB_LOCK_SCALEX))
+ return 0;
+ else if ((index == 1) && (ob->protectflag & OB_LOCK_SCALEY))
+ return 0;
+ else if ((index == 2) && (ob->protectflag & OB_LOCK_SCALEZ))
+ return 0;
+ else
+ return PROP_EDITABLE;
}
static int rna_Object_rotation_euler_editable(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- /* only if the axis in question is locked, not editable... */
- if ((index == 0) && (ob->protectflag & OB_LOCK_ROTX))
- return 0;
- else if ((index == 1) && (ob->protectflag & OB_LOCK_ROTY))
- return 0;
- else if ((index == 2) && (ob->protectflag & OB_LOCK_ROTZ))
- return 0;
- else
- return PROP_EDITABLE;
+ /* only if the axis in question is locked, not editable... */
+ if ((index == 0) && (ob->protectflag & OB_LOCK_ROTX))
+ return 0;
+ else if ((index == 1) && (ob->protectflag & OB_LOCK_ROTY))
+ return 0;
+ else if ((index == 2) && (ob->protectflag & OB_LOCK_ROTZ))
+ return 0;
+ else
+ return PROP_EDITABLE;
}
static int rna_Object_rotation_4d_editable(PointerRNA *ptr, int index)
{
- Object *ob = (Object *)ptr->data;
+ Object *ob = (Object *)ptr->data;
- /* only consider locks if locking components individually... */
- if (ob->protectflag & OB_LOCK_ROT4D) {
- /* only if the axis in question is locked, not editable... */
- if ((index == 0) && (ob->protectflag & OB_LOCK_ROTW))
- return 0;
- else if ((index == 1) && (ob->protectflag & OB_LOCK_ROTX))
- return 0;
- else if ((index == 2) && (ob->protectflag & OB_LOCK_ROTY))
- return 0;
- else if ((index == 3) && (ob->protectflag & OB_LOCK_ROTZ))
- return 0;
- }
+ /* only consider locks if locking components individually... */
+ if (ob->protectflag & OB_LOCK_ROT4D) {
+ /* only if the axis in question is locked, not editable... */
+ if ((index == 0) && (ob->protectflag & OB_LOCK_ROTW))
+ return 0;
+ else if ((index == 1) && (ob->protectflag & OB_LOCK_ROTX))
+ return 0;
+ else if ((index == 2) && (ob->protectflag & OB_LOCK_ROTY))
+ return 0;
+ else if ((index == 3) && (ob->protectflag & OB_LOCK_ROTZ))
+ return 0;
+ }
- return PROP_EDITABLE;
+ return PROP_EDITABLE;
}
static int rna_MaterialSlot_material_editable(PointerRNA *ptr, const char **UNUSED(r_info))
{
- Object *ob = (Object *)ptr->id.data;
- const int index = (Material **)ptr->data - ob->mat;
- bool is_editable;
+ Object *ob = (Object *)ptr->id.data;
+ const int index = (Material **)ptr->data - ob->mat;
+ bool is_editable;
- if ((ob->matbits == NULL) || ob->matbits[index]) {
- is_editable = !ID_IS_LINKED(ob);
- }
- else {
- is_editable = ob->data ? !ID_IS_LINKED(ob->data) : false;
- }
+ if ((ob->matbits == NULL) || ob->matbits[index]) {
+ is_editable = !ID_IS_LINKED(ob);
+ }
+ else {
+ is_editable = ob->data ? !ID_IS_LINKED(ob->data) : false;
+ }
- return is_editable ? PROP_EDITABLE : 0;
+ return is_editable ? PROP_EDITABLE : 0;
}
static PointerRNA rna_MaterialSlot_material_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- Material *ma;
- const int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ Material *ma;
+ const int index = (Material **)ptr->data - ob->mat;
- ma = give_current_material(ob, index + 1);
- return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
+ ma = give_current_material(ob, index + 1);
+ return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
}
static void rna_MaterialSlot_material_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->id.data;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ int index = (Material **)ptr->data - ob->mat;
- BLI_assert(BKE_id_is_in_global_main(&ob->id));
- BLI_assert(BKE_id_is_in_global_main(value.data));
- assign_material(G_MAIN, ob, value.data, index + 1, BKE_MAT_ASSIGN_EXISTING);
+ BLI_assert(BKE_id_is_in_global_main(&ob->id));
+ BLI_assert(BKE_id_is_in_global_main(value.data));
+ assign_material(G_MAIN, ob, value.data, index + 1, BKE_MAT_ASSIGN_EXISTING);
}
static bool rna_MaterialSlot_material_poll(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->id.data;
- Material *ma = (Material *)value.data;
+ Object *ob = (Object *)ptr->id.data;
+ Material *ma = (Material *)value.data;
- if (ob->type == OB_GPENCIL) {
- /* GP Materials only */
- return (ma->gp_style != NULL);
- }
- else {
- /* Everything except GP materials */
- return (ma->gp_style == NULL);
- }
+ if (ob->type == OB_GPENCIL) {
+ /* GP Materials only */
+ return (ma->gp_style != NULL);
+ }
+ else {
+ /* Everything except GP materials */
+ return (ma->gp_style == NULL);
+ }
}
static int rna_MaterialSlot_link_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ int index = (Material **)ptr->data - ob->mat;
- return ob->matbits[index] != 0;
+ return ob->matbits[index] != 0;
}
static void rna_MaterialSlot_link_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ int index = (Material **)ptr->data - ob->mat;
- if (value) {
- ob->matbits[index] = 1;
- /* ob->colbits |= (1 << index); */ /* DEPRECATED */
- }
- else {
- ob->matbits[index] = 0;
- /* ob->colbits &= ~(1 << index); */ /* DEPRECATED */
- }
+ if (value) {
+ ob->matbits[index] = 1;
+ /* ob->colbits |= (1 << index); */ /* DEPRECATED */
+ }
+ else {
+ ob->matbits[index] = 0;
+ /* ob->colbits &= ~(1 << index); */ /* DEPRECATED */
+ }
}
static int rna_MaterialSlot_name_length(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- Material *ma;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ Material *ma;
+ int index = (Material **)ptr->data - ob->mat;
- ma = give_current_material(ob, index + 1);
+ ma = give_current_material(ob, index + 1);
- if (ma)
- return strlen(ma->id.name + 2);
+ if (ma)
+ return strlen(ma->id.name + 2);
- return 0;
+ return 0;
}
static void rna_MaterialSlot_name_get(PointerRNA *ptr, char *str)
{
- Object *ob = (Object *)ptr->id.data;
- Material *ma;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ Material *ma;
+ int index = (Material **)ptr->data - ob->mat;
- ma = give_current_material(ob, index + 1);
+ ma = give_current_material(ob, index + 1);
- if (ma)
- strcpy(str, ma->id.name + 2);
- else
- str[0] = '\0';
+ if (ma)
+ strcpy(str, ma->id.name + 2);
+ else
+ str[0] = '\0';
}
static void rna_MaterialSlot_update(Main *bmain, Scene *scene, PointerRNA *ptr)
{
- rna_Object_internal_update(bmain, scene, ptr);
+ rna_Object_internal_update(bmain, scene, ptr);
- WM_main_add_notifier(NC_OBJECT | ND_OB_SHADING, ptr->id.data);
- WM_main_add_notifier(NC_MATERIAL | ND_SHADING_LINKS, NULL);
- DEG_relations_tag_update(bmain);
+ WM_main_add_notifier(NC_OBJECT | ND_OB_SHADING, ptr->id.data);
+ WM_main_add_notifier(NC_MATERIAL | ND_SHADING_LINKS, NULL);
+ DEG_relations_tag_update(bmain);
}
static char *rna_MaterialSlot_path(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- int index = (Material **)ptr->data - ob->mat;
+ Object *ob = (Object *)ptr->id.data;
+ int index = (Material **)ptr->data - ob->mat;
- return BLI_sprintfN("material_slots[%d]", index);
+ return BLI_sprintfN("material_slots[%d]", index);
}
static PointerRNA rna_Object_display_get(PointerRNA *ptr)
{
- return rna_pointer_inherit_refine(ptr, &RNA_ObjectDisplay, ptr->data);
+ return rna_pointer_inherit_refine(ptr, &RNA_ObjectDisplay, ptr->data);
}
static char *rna_ObjectDisplay_path(PointerRNA *UNUSED(ptr))
{
- return BLI_strdup("display");
+ return BLI_strdup("display");
}
static PointerRNA rna_Object_active_particle_system_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- ParticleSystem *psys = psys_get_current(ob);
- return rna_pointer_inherit_refine(ptr, &RNA_ParticleSystem, psys);
+ Object *ob = (Object *)ptr->id.data;
+ ParticleSystem *psys = psys_get_current(ob);
+ return rna_pointer_inherit_refine(ptr, &RNA_ParticleSystem, psys);
}
-static void rna_Object_active_shape_key_index_range(PointerRNA *ptr, int *min, int *max,
- int *UNUSED(softmin), int *UNUSED(softmax))
+static void rna_Object_active_shape_key_index_range(
+ PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
{
- Object *ob = (Object *)ptr->id.data;
- Key *key = BKE_key_from_object(ob);
+ Object *ob = (Object *)ptr->id.data;
+ Key *key = BKE_key_from_object(ob);
- *min = 0;
- if (key) {
- *max = BLI_listbase_count(&key->block) - 1;
- if (*max < 0) *max = 0;
- }
- else {
- *max = 0;
- }
+ *min = 0;
+ if (key) {
+ *max = BLI_listbase_count(&key->block) - 1;
+ if (*max < 0)
+ *max = 0;
+ }
+ else {
+ *max = 0;
+ }
}
static int rna_Object_active_shape_key_index_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- return MAX2(ob->shapenr - 1, 0);
+ return MAX2(ob->shapenr - 1, 0);
}
static void rna_Object_active_shape_key_index_set(PointerRNA *ptr, int value)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- ob->shapenr = value + 1;
+ ob->shapenr = value + 1;
}
static PointerRNA rna_Object_active_shape_key_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- Key *key = BKE_key_from_object(ob);
- KeyBlock *kb;
- PointerRNA keyptr;
+ Object *ob = (Object *)ptr->id.data;
+ Key *key = BKE_key_from_object(ob);
+ KeyBlock *kb;
+ PointerRNA keyptr;
- if (key == NULL)
- return PointerRNA_NULL;
+ if (key == NULL)
+ return PointerRNA_NULL;
- kb = BLI_findlink(&key->block, ob->shapenr - 1);
- RNA_pointer_create((ID *)key, &RNA_ShapeKey, kb, &keyptr);
- return keyptr;
+ kb = BLI_findlink(&key->block, ob->shapenr - 1);
+ RNA_pointer_create((ID *)key, &RNA_ShapeKey, kb, &keyptr);
+ return keyptr;
}
static PointerRNA rna_Object_field_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- /* weak */
- if (!ob->pd)
- ob->pd = BKE_partdeflect_new(0);
+ /* weak */
+ if (!ob->pd)
+ ob->pd = BKE_partdeflect_new(0);
- return rna_pointer_inherit_refine(ptr, &RNA_FieldSettings, ob->pd);
+ return rna_pointer_inherit_refine(ptr, &RNA_FieldSettings, ob->pd);
}
static PointerRNA rna_Object_collision_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
+ Object *ob = (Object *)ptr->id.data;
- if (ob->type != OB_MESH)
- return PointerRNA_NULL;
+ if (ob->type != OB_MESH)
+ return PointerRNA_NULL;
- /* weak */
- if (!ob->pd)
- ob->pd = BKE_partdeflect_new(0);
+ /* weak */
+ if (!ob->pd)
+ ob->pd = BKE_partdeflect_new(0);
- return rna_pointer_inherit_refine(ptr, &RNA_CollisionSettings, ob->pd);
+ return rna_pointer_inherit_refine(ptr, &RNA_CollisionSettings, ob->pd);
}
static PointerRNA rna_Object_active_constraint_get(PointerRNA *ptr)
{
- Object *ob = (Object *)ptr->id.data;
- bConstraint *con = BKE_constraints_active_get(&ob->constraints);
- return rna_pointer_inherit_refine(ptr, &RNA_Constraint, con);
+ Object *ob = (Object *)ptr->id.data;
+ bConstraint *con = BKE_constraints_active_get(&ob->constraints);
+ return rna_pointer_inherit_refine(ptr, &RNA_Constraint, con);
}
static void rna_Object_active_constraint_set(PointerRNA *ptr, PointerRNA value)
{
- Object *ob = (Object *)ptr->id.data;
- BKE_constraints_active_set(&ob->constraints, (bConstraint *)value.data);
+ Object *ob = (Object *)ptr->id.data;
+ BKE_constraints_active_set(&ob->constraints, (bConstraint *)value.data);
}
static bConstraint *rna_Object_constraints_new(Object *object, Main *bmain, int type)
{
- bConstraint *new_con = BKE_constraint_add_for_object(object, NULL, type);
+ bConstraint *new_con = BKE_constraint_add_for_object(object, NULL, type);
- ED_object_constraint_tag_update(bmain, object, new_con);
- WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_ADDED, object);
+ ED_object_constraint_tag_update(bmain, object, new_con);
+ WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_ADDED, object);
- return new_con;
+ return new_con;
}
-static void rna_Object_constraints_remove(Object *object, Main *bmain, ReportList *reports, PointerRNA *con_ptr)
+static void rna_Object_constraints_remove(Object *object,
+ Main *bmain,
+ ReportList *reports,
+ PointerRNA *con_ptr)
{
- bConstraint *con = con_ptr->data;
- if (BLI_findindex(&object->constraints, con) == -1) {
- BKE_reportf(reports, RPT_ERROR, "Constraint '%s' not found in object '%s'", con->name, object->id.name + 2);
- return;
- }
+ bConstraint *con = con_ptr->data;
+ if (BLI_findindex(&object->constraints, con) == -1) {
+ BKE_reportf(reports,
+ RPT_ERROR,
+ "Constraint '%s' not found in object '%s'",
+ con->name,
+ object->id.name + 2);
+ return;
+ }
- BKE_constraint_remove(&object->constraints, con);
- RNA_POINTER_INVALIDATE(con_ptr);
+ BKE_constraint_remove(&object->constraints, con);
+ RNA_POINTER_INVALIDATE(con_ptr);
- ED_object_constraint_update(bmain, object);
- ED_object_constraint_set_active(object, NULL);
- WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_REMOVED, object);
+ ED_object_constraint_update(bmain, object);
+ ED_object_constraint_set_active(object, NULL);
+ WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_REMOVED, object);
}
static void rna_Object_constraints_clear(Object *object, Main *bmain)
{
- BKE_constraints_free(&object->constraints);
+ BKE_constraints_free(&object->constraints);
- ED_object_constraint_update(bmain, object);
- ED_object_constraint_set_active(object, NULL);
+ ED_object_constraint_update(bmain, object);
+ ED_object_constraint_set_active(object, NULL);
- WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_REMOVED, object);
+ WM_main_add_notifier(NC_OBJECT | ND_CONSTRAINT | NA_REMOVED, object);
}
-bool rna_Object_constraints_override_apply(
- Main *UNUSED(bmain),
- PointerRNA *ptr_dst, PointerRNA *ptr_src, PointerRNA *UNUSED(ptr_storage),
- PropertyRNA *UNUSED(prop_dst), PropertyRNA *UNUSED(prop_src), PropertyRNA *UNUSED(prop_storage),
- const int UNUSED(len_dst), const int UNUSED(len_src), const int UNUSED(len_storage),
- PointerRNA *UNUSED(ptr_item_dst), PointerRNA *UNUSED(ptr_item_src), PointerRNA *UNUSED(ptr_item_storage),
- IDOverrideStaticPropertyOperation *opop)
+bool rna_Object_constraints_override_apply(Main *UNUSED(bmain),
+ PointerRNA *ptr_dst,
+ PointerRNA *ptr_src,
+ PointerRNA *UNUSED(ptr_storage),
+ PropertyRNA *UNUSED(prop_dst),
+ PropertyRNA *UNUSED(prop_src),
+ PropertyRNA *UNUSED(prop_storage),
+ const int UNUSED(len_dst),
+ const int UNUSED(len_src),
+ const int UNUSED(len_storage),
+ PointerRNA *UNUSED(ptr_item_dst),
+ PointerRNA *UNUSED(ptr_item_src),
+ PointerRNA *UNUSED(ptr_item_storage),
+ IDOverrideStaticPropertyOperation *opop)
{
- BLI_assert(opop->operation == IDOVERRIDESTATIC_OP_INSERT_AFTER &&
- "Unsupported RNA override operation on constraints collection");
+ BLI_assert(opop->operation == IDOVERRIDESTATIC_OP_INSERT_AFTER &&
+ "Unsupported RNA override operation on constraints collection");
- Object *ob_dst = (Object *)ptr_dst->id.data;
- Object *ob_src = (Object *)ptr_src->id.data;
+ Object *ob_dst = (Object *)ptr_dst->id.data;
+ Object *ob_src = (Object *)ptr_src->id.data;
- /* Remember that insertion operations are defined and stored in correct order, which means that
- * even if we insert several items in a row, we alays insert first one, then second one, etc.
- * So we should always find 'anchor' constraint in both _src *and* _dst> */
- bConstraint *con_anchor = NULL;
- if (opop->subitem_local_name && opop->subitem_local_name[0]) {
- con_anchor = BLI_findstring(&ob_dst->constraints, opop->subitem_local_name, offsetof(bConstraint, name));
- }
- if (con_anchor == NULL && opop->subitem_local_index >= 0) {
- con_anchor = BLI_findlink(&ob_dst->constraints, opop->subitem_local_index);
- }
- /* Otherwise we just insert in first position. */
+ /* Remember that insertion operations are defined and stored in correct order, which means that
+ * even if we insert several items in a row, we alays insert first one, then second one, etc.
+ * So we should always find 'anchor' constraint in both _src *and* _dst> */
+ bConstraint *con_anchor = NULL;
+ if (opop->subitem_local_name && opop->subitem_local_name[0]) {
+ con_anchor = BLI_findstring(
+ &ob_dst->constraints, opop->subitem_local_name, offsetof(bConstraint, name));
+ }
+ if (con_anchor == NULL && opop->subitem_local_index >= 0) {
+ con_anchor = BLI_findlink(&ob_dst->constraints, opop->subitem_local_index);
+ }
+ /* Otherwise we just insert in first position. */
- bConstraint *con_src = NULL;
- if (opop->subitem_local_name && opop->subitem_local_name[0]) {
- con_src = BLI_findstring(&ob_src->constraints, opop->subitem_local_name, offsetof(bConstraint, name));
- }
- if (con_src == NULL && opop->subitem_local_index >= 0) {
- con_src = BLI_findlink(&ob_src->constraints, opop->subitem_local_index);
- }
- con_src = con_src ? con_src->next : ob_src->constraints.first;
+ bConstraint *con_src = NULL;
+ if (opop->subitem_local_name && opop->subitem_local_name[0]) {
+ con_src = BLI_findstring(
+ &ob_src->constraints, opop->subitem_local_name, offsetof(bConstraint, name));
+ }
+ if (con_src == NULL && opop->subitem_local_index >= 0) {
+ con_src = BLI_findlink(&ob_src->constraints, opop->subitem_local_index);
+ }
+ con_src = con_src ? con_src->next : ob_src->constraints.first;
- BLI_assert(con_src != NULL);
+ BLI_assert(con_src != NULL);
- bConstraint *con_dst = BKE_constraint_duplicate_ex(con_src, 0, true);
+ bConstraint *con_dst = BKE_constraint_duplicate_ex(con_src, 0, true);
- /* This handles NULL anchor as expected by adding at head of list. */
- BLI_insertlinkafter(&ob_dst->constraints, con_anchor, con_dst);
+ /* This handles NULL anchor as expected by adding at head of list. */
+ BLI_insertlinkafter(&ob_dst->constraints, con_anchor, con_dst);
- /* This should actually *not* be needed in typical cases. However, if overridden source was edited,
- * we *may* have some new conflicting names. */
- BKE_constraint_unique_name(con_dst, &ob_dst->constraints);
+ /* This should actually *not* be needed in typical cases. However, if overridden source was edited,
+ * we *may* have some new conflicting names. */
+ BKE_constraint_unique_name(con_dst, &ob_dst->constraints);
-// printf("%s: We inserted a constraint...\n", __func__);
- return true;
+ // printf("%s: We inserted a constraint...\n", __func__);
+ return true;
}
-static ModifierData *rna_Object_modifier_new(Object *object, bContext *C, ReportList *reports,
- const char *name, int type)
+static ModifierData *rna_Object_modifier_new(
+ Object *object, bContext *C, ReportList *reports, const char *name, int type)
{
- return ED_object_modifier_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
+ return ED_object_modifier_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
}
-static void rna_Object_modifier_remove(Object *object, bContext *C, ReportList *reports, PointerRNA *md_ptr)
+static void rna_Object_modifier_remove(Object *object,
+ bContext *C,
+ ReportList *reports,
+ PointerRNA *md_ptr)
{
- ModifierData *md = md_ptr->data;
- if (ED_object_modifier_remove(reports, CTX_data_main(C), object, md) == false) {
- /* error is already set */
- return;
- }
+ ModifierData *md = md_ptr->data;
+ if (ED_object_modifier_remove(reports, CTX_data_main(C), object, md) == false) {
+ /* error is already set */
+ return;
+ }
- RNA_POINTER_INVALIDATE(md_ptr);
+ RNA_POINTER_INVALIDATE(md_ptr);
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
}
static void rna_Object_modifier_clear(Object *object, bContext *C)
{
- ED_object_modifier_clear(CTX_data_main(C), object);
-
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
-}
-
-bool rna_Object_modifiers_override_apply(
- Main *UNUSED(bmain),
- PointerRNA *ptr_dst, PointerRNA *ptr_src, PointerRNA *UNUSED(ptr_storage),
- PropertyRNA *UNUSED(prop_dst), PropertyRNA *UNUSED(prop_src), PropertyRNA *UNUSED(prop_storage),
- const int UNUSED(len_dst), const int UNUSED(len_src), const int UNUSED(len_storage),
- PointerRNA *UNUSED(ptr_item_dst), PointerRNA *UNUSED(ptr_item_src), PointerRNA *UNUSED(ptr_item_storage),
- IDOverrideStaticPropertyOperation *opop)
-{
- BLI_assert(opop->operation == IDOVERRIDESTATIC_OP_INSERT_AFTER &&
- "Unsupported RNA override operation on modifiers collection");
-
- Object *ob_dst = (Object *)ptr_dst->id.data;
- Object *ob_src = (Object *)ptr_src->id.data;
-
- /* Remember that insertion operations are defined and stored in correct order, which means that
- * even if we insert several items in a row, we alays insert first one, then second one, etc.
- * So we should always find 'anchor' constraint in both _src *and* _dst> */
- ModifierData *mod_anchor = NULL;
- if (opop->subitem_local_name && opop->subitem_local_name[0]) {
- mod_anchor = BLI_findstring(&ob_dst->modifiers, opop->subitem_local_name, offsetof(ModifierData, name));
- }
- if (mod_anchor == NULL && opop->subitem_local_index >= 0) {
- mod_anchor = BLI_findlink(&ob_dst->modifiers, opop->subitem_local_index);
- }
- /* Otherwise we just insert in first position. */
-
- ModifierData *mod_src = NULL;
- if (opop->subitem_local_name && opop->subitem_local_name[0]) {
- mod_src = BLI_findstring(&ob_src->modifiers, opop->subitem_local_name, offsetof(ModifierData, name));
- }
- if (mod_src == NULL && opop->subitem_local_index >= 0) {
- mod_src = BLI_findlink(&ob_src->modifiers, opop->subitem_local_index);
- }
- mod_src = mod_src ? mod_src->next : ob_src->modifiers.first;
-
- BLI_assert(mod_src != NULL);
-
- ModifierData *mod_dst = modifier_new(mod_src->type);
- modifier_copyData(mod_src, mod_dst);
-
- /* This handles NULL anchor as expected by adding at head of list. */
- BLI_insertlinkafter(&ob_dst->modifiers, mod_anchor, mod_dst);
-
- /* This should actually *not* be needed in typical cases. However, if overridden source was edited,
- * we *may* have some new conflicting names. */
- modifier_unique_name(&ob_dst->modifiers, mod_dst);
-
-// printf("%s: We inserted a modifier...\n", __func__);
- return true;
+ ED_object_modifier_clear(CTX_data_main(C), object);
+
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+}
+
+bool rna_Object_modifiers_override_apply(Main *UNUSED(bmain),
+ PointerRNA *ptr_dst,
+ PointerRNA *ptr_src,
+ PointerRNA *UNUSED(ptr_storage),
+ PropertyRNA *UNUSED(prop_dst),
+ PropertyRNA *UNUSED(prop_src),
+ PropertyRNA *UNUSED(prop_storage),
+ const int UNUSED(len_dst),
+ const int UNUSED(len_src),
+ const int UNUSED(len_storage),
+ PointerRNA *UNUSED(ptr_item_dst),
+ PointerRNA *UNUSED(ptr_item_src),
+ PointerRNA *UNUSED(ptr_item_storage),
+ IDOverrideStaticPropertyOperation *opop)
+{
+ BLI_assert(opop->operation == IDOVERRIDESTATIC_OP_INSERT_AFTER &&
+ "Unsupported RNA override operation on modifiers collection");
+
+ Object *ob_dst = (Object *)ptr_dst->id.data;
+ Object *ob_src = (Object *)ptr_src->id.data;
+
+ /* Remember that insertion operations are defined and stored in correct order, which means that
+ * even if we insert several items in a row, we alays insert first one, then second one, etc.
+ * So we should always find 'anchor' constraint in both _src *and* _dst> */
+ ModifierData *mod_anchor = NULL;
+ if (opop->subitem_local_name && opop->subitem_local_name[0]) {
+ mod_anchor = BLI_findstring(
+ &ob_dst->modifiers, opop->subitem_local_name, offsetof(ModifierData, name));
+ }
+ if (mod_anchor == NULL && opop->subitem_local_index >= 0) {
+ mod_anchor = BLI_findlink(&ob_dst->modifiers, opop->subitem_local_index);
+ }
+ /* Otherwise we just insert in first position. */
+
+ ModifierData *mod_src = NULL;
+ if (opop->subitem_local_name && opop->subitem_local_name[0]) {
+ mod_src = BLI_findstring(
+ &ob_src->modifiers, opop->subitem_local_name, offsetof(ModifierData, name));
+ }
+ if (mod_src == NULL && opop->subitem_local_index >= 0) {
+ mod_src = BLI_findlink(&ob_src->modifiers, opop->subitem_local_index);
+ }
+ mod_src = mod_src ? mod_src->next : ob_src->modifiers.first;
+
+ BLI_assert(mod_src != NULL);
+
+ ModifierData *mod_dst = modifier_new(mod_src->type);
+ modifier_copyData(mod_src, mod_dst);
+
+ /* This handles NULL anchor as expected by adding at head of list. */
+ BLI_insertlinkafter(&ob_dst->modifiers, mod_anchor, mod_dst);
+
+ /* This should actually *not* be needed in typical cases. However, if overridden source was edited,
+ * we *may* have some new conflicting names. */
+ modifier_unique_name(&ob_dst->modifiers, mod_dst);
+
+ // printf("%s: We inserted a modifier...\n", __func__);
+ return true;
}
static GpencilModifierData *rna_Object_greasepencil_modifier_new(
- Object *object, bContext *C, ReportList *reports,
- const char *name, int type)
+ Object *object, bContext *C, ReportList *reports, const char *name, int type)
{
- return ED_object_gpencil_modifier_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
+ return ED_object_gpencil_modifier_add(
+ reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
}
-static void rna_Object_greasepencil_modifier_remove(
- Object *object, bContext *C, ReportList *reports, PointerRNA *gmd_ptr)
+static void rna_Object_greasepencil_modifier_remove(Object *object,
+ bContext *C,
+ ReportList *reports,
+ PointerRNA *gmd_ptr)
{
- GpencilModifierData *gmd = gmd_ptr->data;
- if (ED_object_gpencil_modifier_remove(reports, CTX_data_main(C), object, gmd) == false) {
- /* error is already set */
- return;
- }
+ GpencilModifierData *gmd = gmd_ptr->data;
+ if (ED_object_gpencil_modifier_remove(reports, CTX_data_main(C), object, gmd) == false) {
+ /* error is already set */
+ return;
+ }
- RNA_POINTER_INVALIDATE(gmd_ptr);
+ RNA_POINTER_INVALIDATE(gmd_ptr);
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
}
static void rna_Object_greasepencil_modifier_clear(Object *object, bContext *C)
{
- ED_object_gpencil_modifier_clear(CTX_data_main(C), object);
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+ ED_object_gpencil_modifier_clear(CTX_data_main(C), object);
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
}
/* shader fx */
static ShaderFxData *rna_Object_shaderfx_new(
- Object *object, bContext *C, ReportList *reports,
- const char *name, int type)
+ Object *object, bContext *C, ReportList *reports, const char *name, int type)
{
- return ED_object_shaderfx_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
+ return ED_object_shaderfx_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
}
-static void rna_Object_shaderfx_remove(
- Object *object, bContext *C, ReportList *reports, PointerRNA *gmd_ptr)
+static void rna_Object_shaderfx_remove(Object *object,
+ bContext *C,
+ ReportList *reports,
+ PointerRNA *gmd_ptr)
{
- ShaderFxData *gmd = gmd_ptr->data;
- if (ED_object_shaderfx_remove(reports, CTX_data_main(C), object, gmd) == false) {
- /* error is already set */
- return;
- }
+ ShaderFxData *gmd = gmd_ptr->data;
+ if (ED_object_shaderfx_remove(reports, CTX_data_main(C), object, gmd) == false) {
+ /* error is already set */
+ return;
+ }
- RNA_POINTER_INVALIDATE(gmd_ptr);
+ RNA_POINTER_INVALIDATE(gmd_ptr);
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
}
static void rna_Object_shaderfx_clear(Object *object, bContext *C)
{
- ED_object_shaderfx_clear(CTX_data_main(C), object);
- WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
+ ED_object_shaderfx_clear(CTX_data_main(C), object);
+ WM_main_add_notifier(NC_OBJECT | ND_MODIFIER | NA_REMOVED, object);
}
static void rna_Object_boundbox_get(PointerRNA *ptr, float *values)
{
- Object *ob = (Object *)ptr->id.data;
- BoundBox *bb = BKE_object_boundbox_get(ob);
- if (bb) {
- memcpy(values, bb->vec, sizeof(bb->vec));
- }
- else {
- copy_vn_fl(values, sizeof(bb->vec) / sizeof(float), 0.0f);
- }
-
+ Object *ob = (Object *)ptr->id.data;
+ BoundBox *bb = BKE_object_boundbox_get(ob);
+ if (bb) {
+ memcpy(values, bb->vec, sizeof(bb->vec));
+ }
+ else {
+ copy_vn_fl(values, sizeof(bb->vec) / sizeof(float), 0.0f);
+ }
}
static bDeformGroup *rna_Object_vgroup_new(Object *ob, const char *name)
{
- bDeformGroup *defgroup = BKE_object_defgroup_add_name(ob, name);
+ bDeformGroup *defgroup = BKE_object_defgroup_add_name(ob, name);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
- return defgroup;
+ return defgroup;
}
static void rna_Object_vgroup_remove(Object *ob, ReportList *reports, PointerRNA *defgroup_ptr)
{
- bDeformGroup *defgroup = defgroup_ptr->data;
- if (BLI_findindex(&ob->defbase, defgroup) == -1) {
- BKE_reportf(reports, RPT_ERROR, "DeformGroup '%s' not in object '%s'", defgroup->name, ob->id.name + 2);
- return;
- }
+ bDeformGroup *defgroup = defgroup_ptr->data;
+ if (BLI_findindex(&ob->defbase, defgroup) == -1) {
+ BKE_reportf(reports,
+ RPT_ERROR,
+ "DeformGroup '%s' not in object '%s'",
+ defgroup->name,
+ ob->id.name + 2);
+ return;
+ }
- BKE_object_defgroup_remove(ob, defgroup);
- RNA_POINTER_INVALIDATE(defgroup_ptr);
+ BKE_object_defgroup_remove(ob, defgroup);
+ RNA_POINTER_INVALIDATE(defgroup_ptr);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
}
static void rna_Object_vgroup_clear(Object *ob)
{
- BKE_object_defgroup_remove_all(ob);
+ BKE_object_defgroup_remove_all(ob);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
}
-static void rna_VertexGroup_vertex_add(ID *id, bDeformGroup *def, ReportList *reports, int index_len,
- int *index, float weight, int assignmode)
+static void rna_VertexGroup_vertex_add(ID *id,
+ bDeformGroup *def,
+ ReportList *reports,
+ int index_len,
+ int *index,
+ float weight,
+ int assignmode)
{
- Object *ob = (Object *)id;
+ Object *ob = (Object *)id;
- if (BKE_object_is_in_editmode_vgroup(ob)) {
- BKE_report(reports, RPT_ERROR, "VertexGroup.add(): cannot be called while object is in edit mode");
- return;
- }
+ if (BKE_object_is_in_editmode_vgroup(ob)) {
+ BKE_report(
+ reports, RPT_ERROR, "VertexGroup.add(): cannot be called while object is in edit mode");
+ return;
+ }
- while (index_len--)
- ED_vgroup_vert_add(ob, def, *index++, weight, assignmode); /* XXX, not efficient calling within loop*/
+ while (index_len--)
+ ED_vgroup_vert_add(
+ ob, def, *index++, weight, assignmode); /* XXX, not efficient calling within loop*/
- DEG_id_tag_update(&ob->id, ID_RECALC_GEOMETRY);
- WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
+ DEG_id_tag_update(&ob->id, ID_RECALC_GEOMETRY);
+ WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
}
-static void rna_VertexGroup_vertex_remove(ID *id, bDeformGroup *dg, ReportList *reports, int index_len, int *index)
+static void rna_VertexGroup_vertex_remove(
+ ID *id, bDeformGroup *dg, ReportList *reports, int index_len, int *index)
{
- Object *ob = (Object *)id;
+ Object *ob = (Object *)id;
- if (BKE_object_is_in_editmode_vgroup(ob)) {
- BKE_report(reports, RPT_ERROR, "VertexGroup.remove(): cannot be called while object is in edit mode");
- return;
- }
+ if (BKE_object_is_in_editmode_vgroup(ob)) {
+ BKE_report(
+ reports, RPT_ERROR, "VertexGroup.remove(): cannot be called while object is in edit mode");
+ return;
+ }
- while (index_len--)
- ED_vgroup_vert_remove(ob, dg, *index++);
+ while (index_len--)
+ ED_vgroup_vert_remove(ob, dg, *index++);
- DEG_id_tag_update(&ob->id, ID_RECALC_GEOMETRY);
- WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
+ DEG_id_tag_update(&ob->id, ID_RECALC_GEOMETRY);
+ WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
}
static float rna_VertexGroup_weight(ID *id, bDeformGroup *dg, ReportList *reports, int index)
{
- float weight = ED_vgroup_vert_weight((Object *)id, dg, index);
+ float weight = ED_vgroup_vert_weight((Object *)id, dg, index);
- if (weight < 0) {
- BKE_report(reports, RPT_ERROR, "Vertex not in group");
- }
- return weight;
+ if (weight < 0) {
+ BKE_report(reports, RPT_ERROR, "Vertex not in group");
+ }
+ return weight;
}
static bFaceMap *rna_Object_fmap_new(Object *ob, const char *name)
{
- bFaceMap *fmap = BKE_object_facemap_add_name(ob, name);
+ bFaceMap *fmap = BKE_object_facemap_add_name(ob, name);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
- return fmap;
+ return fmap;
}
static void rna_Object_fmap_remove(Object *ob, ReportList *reports, PointerRNA *fmap_ptr)
{
- bFaceMap *fmap = fmap_ptr->data;
- if (BLI_findindex(&ob->fmaps, fmap) == -1) {
- BKE_reportf(reports, RPT_ERROR, "FaceMap '%s' not in object '%s'", fmap->name, ob->id.name + 2);
- return;
- }
+ bFaceMap *fmap = fmap_ptr->data;
+ if (BLI_findindex(&ob->fmaps, fmap) == -1) {
+ BKE_reportf(
+ reports, RPT_ERROR, "FaceMap '%s' not in object '%s'", fmap->name, ob->id.name + 2);
+ return;
+ }
- BKE_object_facemap_remove(ob, fmap);
- RNA_POINTER_INVALIDATE(fmap_ptr);
+ BKE_object_facemap_remove(ob, fmap);
+ RNA_POINTER_INVALIDATE(fmap_ptr);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
}
-
static void rna_Object_fmap_clear(Object *ob)
{
- BKE_object_facemap_clear(ob);
+ BKE_object_facemap_clear(ob);
- WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
+ WM_main_add_notifier(NC_OBJECT | ND_DRAW, ob);
}
-
-static void rna_FaceMap_face_add(ID *id, bFaceMap *fmap, ReportList *reports, int index_len,
- int *index)
+static void rna_FaceMap_face_add(
+ ID *id, bFaceMap *fmap, ReportList *reports, int index_len, int *index)
{
- Object *ob = (Object *)id;
+ Object *ob = (Object *)id;
- if (BKE_object_is_in_editmode(ob)) {
- BKE_report(reports, RPT_ERROR, "FaceMap.add(): cannot be called while object is in edit mode");
- return;
- }
+ if (BKE_object_is_in_editmode(ob)) {
+ BKE_report(reports, RPT_ERROR, "FaceMap.add(): cannot be called while object is in edit mode");
+ return;
+ }
- while (index_len--)
- ED_object_facemap_face_add(ob, fmap, *index++);
+ while (index_len--)
+ ED_object_facemap_face_add(ob, fmap, *index++);
- WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
+ WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
}
-static void rna_FaceMap_face_remove(ID *id, bFaceMap *fmap, ReportList *reports, int index_len, int *index)
+static void rna_FaceMap_face_remove(
+ ID *id, bFaceMap *fmap, ReportList *reports, int index_len, int *index)
{
- Object *ob = (Object *)id;
+ Object *ob = (Object *)id;
- if (BKE_object_is_in_editmode(ob)) {
- BKE_report(reports, RPT_ERROR, "FaceMap.add(): cannot be called while object is in edit mode");
- return;
- }
+ if (BKE_object_is_in_editmode(ob)) {
+ BKE_report(reports, RPT_ERROR, "FaceMap.add(): cannot be called while object is in edit mode");
+ return;
+ }
- while (index_len--)
- ED_object_facemap_face_remove(ob, fmap, *index++);
+ while (index_len--)
+ ED_object_facemap_face_remove(ob, fmap, *index++);
- WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
+ WM_main_add_notifier(NC_GEOM | ND_DATA, (ID *)ob->data);
}
/* generic poll functions */
bool rna_Lattice_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_LATTICE;
+ return ((Object *)value.id.data)->type == OB_LATTICE;
}
bool rna_Curve_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_CURVE;
+ return ((Object *)value.id.data)->type == OB_CURVE;
}
bool rna_Armature_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_ARMATURE;
+ return ((Object *)value.id.data)->type == OB_ARMATURE;
}
bool rna_Mesh_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_MESH;
+ return ((Object *)value.id.data)->type == OB_MESH;
}
bool rna_Camera_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_CAMERA;
+ return ((Object *)value.id.data)->type == OB_CAMERA;
}
bool rna_Light_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_LAMP;
+ return ((Object *)value.id.data)->type == OB_LAMP;
}
bool rna_GPencil_object_poll(PointerRNA *UNUSED(ptr), PointerRNA value)
{
- return ((Object *)value.id.data)->type == OB_GPENCIL;
+ return ((Object *)value.id.data)->type == OB_GPENCIL;
}
int rna_Object_use_dynamic_topology_sculpting_get(PointerRNA *ptr)
{
- SculptSession *ss = ((Object *)ptr->id.data)->sculpt;
- return (ss && ss->bm);
+ SculptSession *ss = ((Object *)ptr->id.data)->sculpt;
+ return (ss && ss->bm);
}
#else
static void rna_def_vertex_group(BlenderRNA *brna)
{
- StructRNA *srna;
- PropertyRNA *prop;
- FunctionRNA *func;
- PropertyRNA *parm;
-
- static const EnumPropertyItem assign_mode_items[] = {
- {WEIGHT_REPLACE, "REPLACE", 0, "Replace", "Replace"},
- {WEIGHT_ADD, "ADD", 0, "Add", "Add"},
- {WEIGHT_SUBTRACT, "SUBTRACT", 0, "Subtract", "Subtract"},
- {0, NULL, 0, NULL, NULL},
- };
-
- srna = RNA_def_struct(brna, "VertexGroup", NULL);
- RNA_def_struct_sdna(srna, "bDeformGroup");
- RNA_def_struct_ui_text(srna, "Vertex Group", "Group of vertices, used for armature deform and other purposes");
- RNA_def_struct_ui_icon(srna, ICON_GROUP_VERTEX);
-
- prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
- RNA_def_property_ui_text(prop, "Name", "Vertex group name");
- RNA_def_struct_name_property(srna, prop);
- RNA_def_property_string_funcs(prop, NULL, NULL, "rna_VertexGroup_name_set");
- /* update data because modifiers may use [#24761] */
- RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "lock_weight", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_ui_text(prop, "", "Maintain the relative weights for the group");
- RNA_def_property_boolean_sdna(prop, NULL, "flag", 0);
- /* update data because modifiers may use [#24761] */
- RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_int_funcs(prop, "rna_VertexGroup_index_get", NULL, NULL);
- RNA_def_property_ui_text(prop, "Index", "Index number of the vertex group");
-
- func = RNA_def_function(srna, "add", "rna_VertexGroup_vertex_add");
- RNA_def_function_ui_description(func, "Add vertices to the group");
- RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
- /* TODO, see how array size of 0 works, this shouldnt be used */
- parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
- RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
- parm = RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight", 0.0f, 1.0f);
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- parm = RNA_def_enum(func, "type", assign_mode_items, 0, "", "Vertex assign mode");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
-
- func = RNA_def_function(srna, "remove", "rna_VertexGroup_vertex_remove");
- RNA_def_function_ui_description(func, "Remove a vertex from the group");
- RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
- /* TODO, see how array size of 0 works, this shouldnt be used */
- parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
- RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
-
- func = RNA_def_function(srna, "weight", "rna_VertexGroup_weight");
- RNA_def_function_ui_description(func, "Get a vertex weight from the group");
- RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
- parm = RNA_def_int(func, "index", 0, 0, INT_MAX, "Index", "The index of the vertex", 0, INT_MAX);
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- parm = RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight", 0.0f, 1.0f);
- RNA_def_function_return(func, parm);
+ StructRNA *srna;
+ PropertyRNA *prop;
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ static const EnumPropertyItem assign_mode_items[] = {
+ {WEIGHT_REPLACE, "REPLACE", 0, "Replace", "Replace"},
+ {WEIGHT_ADD, "ADD", 0, "Add", "Add"},
+ {WEIGHT_SUBTRACT, "SUBTRACT", 0, "Subtract", "Subtract"},
+ {0, NULL, 0, NULL, NULL},
+ };
+
+ srna = RNA_def_struct(brna, "VertexGroup", NULL);
+ RNA_def_struct_sdna(srna, "bDeformGroup");
+ RNA_def_struct_ui_text(
+ srna, "Vertex Group", "Group of vertices, used for armature deform and other purposes");
+ RNA_def_struct_ui_icon(srna, ICON_GROUP_VERTEX);
+
+ prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
+ RNA_def_property_ui_text(prop, "Name", "Vertex group name");
+ RNA_def_struct_name_property(srna, prop);
+ RNA_def_property_string_funcs(prop, NULL, NULL, "rna_VertexGroup_name_set");
+ /* update data because modifiers may use [#24761] */
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "lock_weight", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_ui_text(prop, "", "Maintain the relative weights for the group");
+ RNA_def_property_boolean_sdna(prop, NULL, "flag", 0);
+ /* update data because modifiers may use [#24761] */
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_int_funcs(prop, "rna_VertexGroup_index_get", NULL, NULL);
+ RNA_def_property_ui_text(prop, "Index", "Index number of the vertex group");
+
+ func = RNA_def_function(srna, "add", "rna_VertexGroup_vertex_add");
+ RNA_def_function_ui_description(func, "Add vertices to the group");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
+ /* TODO, see how array size of 0 works, this shouldnt be used */
+ parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
+ RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
+ parm = RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight", 0.0f, 1.0f);
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ parm = RNA_def_enum(func, "type", assign_mode_items, 0, "", "Vertex assign mode");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+
+ func = RNA_def_function(srna, "remove", "rna_VertexGroup_vertex_remove");
+ RNA_def_function_ui_description(func, "Remove a vertex from the group");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
+ /* TODO, see how array size of 0 works, this shouldnt be used */
+ parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
+ RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
+
+ func = RNA_def_function(srna, "weight", "rna_VertexGroup_weight");
+ RNA_def_function_ui_description(func, "Get a vertex weight from the group");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
+ parm = RNA_def_int(func, "index", 0, 0, INT_MAX, "Index", "The index of the vertex", 0, INT_MAX);
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ parm = RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight", 0.0f, 1.0f);
+ RNA_def_function_return(func, parm);
}
static void rna_def_face_map(BlenderRNA *brna)
{
- StructRNA *srna;
- PropertyRNA *prop;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- srna = RNA_def_struct(brna, "FaceMap", NULL);
- RNA_def_struct_sdna(srna, "bFaceMap");
- RNA_def_struct_ui_text(srna, "Face Map", "Group of faces, each face can only be part of one map");
- RNA_def_struct_ui_icon(srna, ICON_MOD_TRIANGULATE);
-
- prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
- RNA_def_property_ui_text(prop, "Name", "Face map name");
- RNA_def_struct_name_property(srna, prop);
- RNA_def_property_string_funcs(prop, NULL, NULL, "rna_FaceMap_name_set");
- /* update data because modifiers may use [#24761] */
- RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "flag", SELECT);
- RNA_def_property_ui_text(prop, "Select", "Face-map selection state (for tools to use)");
- /* important not to use a notifier here, creates a feedback loop! */
-
- prop = RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_int_funcs(prop, "rna_FaceMap_index_get", NULL, NULL);
- RNA_def_property_ui_text(prop, "Index", "Index number of the face map");
-
- func = RNA_def_function(srna, "add", "rna_FaceMap_face_add");
- RNA_def_function_ui_description(func, "Add vertices to the group");
- RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
- /* TODO, see how array size of 0 works, this shouldnt be used */
- parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
- RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
-
- func = RNA_def_function(srna, "remove", "rna_FaceMap_face_remove");
- RNA_def_function_ui_description(func, "Remove a vertex from the group");
- RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
- /* TODO, see how array size of 0 works, this shouldnt be used */
- parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
- RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
+ StructRNA *srna;
+ PropertyRNA *prop;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ srna = RNA_def_struct(brna, "FaceMap", NULL);
+ RNA_def_struct_sdna(srna, "bFaceMap");
+ RNA_def_struct_ui_text(
+ srna, "Face Map", "Group of faces, each face can only be part of one map");
+ RNA_def_struct_ui_icon(srna, ICON_MOD_TRIANGULATE);
+
+ prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
+ RNA_def_property_ui_text(prop, "Name", "Face map name");
+ RNA_def_struct_name_property(srna, prop);
+ RNA_def_property_string_funcs(prop, NULL, NULL, "rna_FaceMap_name_set");
+ /* update data because modifiers may use [#24761] */
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA | NA_RENAME, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "flag", SELECT);
+ RNA_def_property_ui_text(prop, "Select", "Face-map selection state (for tools to use)");
+ /* important not to use a notifier here, creates a feedback loop! */
+
+ prop = RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_int_funcs(prop, "rna_FaceMap_index_get", NULL, NULL);
+ RNA_def_property_ui_text(prop, "Index", "Index number of the face map");
+
+ func = RNA_def_function(srna, "add", "rna_FaceMap_face_add");
+ RNA_def_function_ui_description(func, "Add vertices to the group");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
+ /* TODO, see how array size of 0 works, this shouldnt be used */
+ parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
+ RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
+
+ func = RNA_def_function(srna, "remove", "rna_FaceMap_face_remove");
+ RNA_def_function_ui_description(func, "Remove a vertex from the group");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_SELF_ID);
+ /* TODO, see how array size of 0 works, this shouldnt be used */
+ parm = RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List", 0, 0);
+ RNA_def_parameter_flags(parm, PROP_DYNAMIC, PARM_REQUIRED);
}
static void rna_def_material_slot(BlenderRNA *brna)
{
- StructRNA *srna;
- PropertyRNA *prop;
-
- static const EnumPropertyItem link_items[] = {
- {1, "OBJECT", 0, "Object", ""},
- {0, "DATA", 0, "Data", ""},
- {0, NULL, 0, NULL, NULL},
- };
-
- /* NOTE: there is no MaterialSlot equivalent in DNA, so the internal
- * pointer data points to ob->mat + index, and we manually implement
- * get/set for the properties. */
-
- srna = RNA_def_struct(brna, "MaterialSlot", NULL);
- RNA_def_struct_ui_text(srna, "Material Slot", "Material slot in an object");
- RNA_def_struct_ui_icon(srna, ICON_MATERIAL_DATA);
-
- /* WARNING! Order is crucial for override to work properly here... :/
- * 'link' must come before material pointer, since it defines where (in object or obdata) that one is set! */
- prop = RNA_def_property(srna, "link", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_items(prop, link_items);
- RNA_def_property_enum_funcs(prop, "rna_MaterialSlot_link_get", "rna_MaterialSlot_link_set", NULL);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Link", "Link material to object or the object's data");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
-
- prop = RNA_def_property(srna, "material", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "Material");
- RNA_def_property_flag(prop, PROP_EDITABLE);
- RNA_def_property_editable_func(prop, "rna_MaterialSlot_material_editable");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_pointer_funcs(prop, "rna_MaterialSlot_material_get", "rna_MaterialSlot_material_set", NULL, "rna_MaterialSlot_material_poll");
- RNA_def_property_ui_text(prop, "Material", "Material data-block used by this material slot");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
-
- prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
- RNA_def_property_string_funcs(prop, "rna_MaterialSlot_name_get", "rna_MaterialSlot_name_length", NULL);
- RNA_def_property_ui_text(prop, "Name", "Material slot name");
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_struct_name_property(srna, prop);
-
- RNA_def_struct_path_func(srna, "rna_MaterialSlot_path");
+ StructRNA *srna;
+ PropertyRNA *prop;
+
+ static const EnumPropertyItem link_items[] = {
+ {1, "OBJECT", 0, "Object", ""},
+ {0, "DATA", 0, "Data", ""},
+ {0, NULL, 0, NULL, NULL},
+ };
+
+ /* NOTE: there is no MaterialSlot equivalent in DNA, so the internal
+ * pointer data points to ob->mat + index, and we manually implement
+ * get/set for the properties. */
+
+ srna = RNA_def_struct(brna, "MaterialSlot", NULL);
+ RNA_def_struct_ui_text(srna, "Material Slot", "Material slot in an object");
+ RNA_def_struct_ui_icon(srna, ICON_MATERIAL_DATA);
+
+ /* WARNING! Order is crucial for override to work properly here... :/
+ * 'link' must come before material pointer, since it defines where (in object or obdata) that one is set! */
+ prop = RNA_def_property(srna, "link", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_items(prop, link_items);
+ RNA_def_property_enum_funcs(
+ prop, "rna_MaterialSlot_link_get", "rna_MaterialSlot_link_set", NULL);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Link", "Link material to object or the object's data");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
+
+ prop = RNA_def_property(srna, "material", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Material");
+ RNA_def_property_flag(prop, PROP_EDITABLE);
+ RNA_def_property_editable_func(prop, "rna_MaterialSlot_material_editable");
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_pointer_funcs(prop,
+ "rna_MaterialSlot_material_get",
+ "rna_MaterialSlot_material_set",
+ NULL,
+ "rna_MaterialSlot_material_poll");
+ RNA_def_property_ui_text(prop, "Material", "Material data-block used by this material slot");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
+
+ prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
+ RNA_def_property_string_funcs(
+ prop, "rna_MaterialSlot_name_get", "rna_MaterialSlot_name_length", NULL);
+ RNA_def_property_ui_text(prop, "Name", "Material slot name");
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_struct_name_property(srna, prop);
+
+ RNA_def_struct_path_func(srna, "rna_MaterialSlot_path");
}
static void rna_def_object_constraints(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
- PropertyRNA *prop;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "ObjectConstraints");
- srna = RNA_def_struct(brna, "ObjectConstraints", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Object Constraints", "Collection of object constraints");
-
-
- /* Collection active property */
- prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "Constraint");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_constraint_get",
- "rna_Object_active_constraint_set", NULL, NULL);
- RNA_def_property_flag(prop, PROP_EDITABLE);
- RNA_def_property_ui_text(prop, "Active Constraint", "Active Object constraint");
-
-
- /* Constraint collection */
- func = RNA_def_function(srna, "new", "rna_Object_constraints_new");
- RNA_def_function_ui_description(func, "Add a new constraint to this object");
- RNA_def_function_flag(func, FUNC_USE_MAIN);
- /* object to add */
- parm = RNA_def_enum(func, "type", rna_enum_constraint_type_items, 1, "", "Constraint type to add");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* return type */
- parm = RNA_def_pointer(func, "constraint", "Constraint", "", "New constraint");
- RNA_def_function_return(func, parm);
-
- func = RNA_def_function(srna, "remove", "rna_Object_constraints_remove");
- RNA_def_function_ui_description(func, "Remove a constraint from this object");
- RNA_def_function_flag(func, FUNC_USE_MAIN | FUNC_USE_REPORTS);
- /* constraint to remove */
- parm = RNA_def_pointer(func, "constraint", "Constraint", "", "Removed constraint");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
-
- func = RNA_def_function(srna, "clear", "rna_Object_constraints_clear");
- RNA_def_function_flag(func, FUNC_USE_MAIN);
- RNA_def_function_ui_description(func, "Remove all constraint from this object");
+ StructRNA *srna;
+ PropertyRNA *prop;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "ObjectConstraints");
+ srna = RNA_def_struct(brna, "ObjectConstraints", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Object Constraints", "Collection of object constraints");
+
+ /* Collection active property */
+ prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Constraint");
+ RNA_def_property_pointer_funcs(
+ prop, "rna_Object_active_constraint_get", "rna_Object_active_constraint_set", NULL, NULL);
+ RNA_def_property_flag(prop, PROP_EDITABLE);
+ RNA_def_property_ui_text(prop, "Active Constraint", "Active Object constraint");
+
+ /* Constraint collection */
+ func = RNA_def_function(srna, "new", "rna_Object_constraints_new");
+ RNA_def_function_ui_description(func, "Add a new constraint to this object");
+ RNA_def_function_flag(func, FUNC_USE_MAIN);
+ /* object to add */
+ parm = RNA_def_enum(
+ func, "type", rna_enum_constraint_type_items, 1, "", "Constraint type to add");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* return type */
+ parm = RNA_def_pointer(func, "constraint", "Constraint", "", "New constraint");
+ RNA_def_function_return(func, parm);
+
+ func = RNA_def_function(srna, "remove", "rna_Object_constraints_remove");
+ RNA_def_function_ui_description(func, "Remove a constraint from this object");
+ RNA_def_function_flag(func, FUNC_USE_MAIN | FUNC_USE_REPORTS);
+ /* constraint to remove */
+ parm = RNA_def_pointer(func, "constraint", "Constraint", "", "Removed constraint");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
+
+ func = RNA_def_function(srna, "clear", "rna_Object_constraints_clear");
+ RNA_def_function_flag(func, FUNC_USE_MAIN);
+ RNA_def_function_ui_description(func, "Remove all constraint from this object");
}
/* object.modifiers */
static void rna_def_object_modifiers(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "ObjectModifiers");
- srna = RNA_def_struct(brna, "ObjectModifiers", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Object Modifiers", "Collection of object modifiers");
-
-#if 0
- prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "EditBone");
- RNA_def_property_pointer_sdna(prop, NULL, "act_edbone");
- RNA_def_property_flag(prop, PROP_EDITABLE);
- RNA_def_property_ui_text(prop, "Active EditBone", "Armatures active edit bone");
- /*RNA_def_property_update(prop, 0, "rna_Armature_act_editbone_update"); */
- RNA_def_property_pointer_funcs(prop, NULL, "rna_Armature_act_edit_bone_set", NULL, NULL);
-
- /* todo, redraw */
-/* RNA_def_property_collection_active(prop, prop_act); */
-#endif
-
- /* add modifier */
- func = RNA_def_function(srna, "new", "rna_Object_modifier_new");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Add a new modifier");
- parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the modifier");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* modifier to add */
- parm = RNA_def_enum(func, "type", rna_enum_object_modifier_type_items, 1, "", "Modifier type to add");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* return type */
- parm = RNA_def_pointer(func, "modifier", "Modifier", "", "Newly created modifier");
- RNA_def_function_return(func, parm);
-
- /* remove modifier */
- func = RNA_def_function(srna, "remove", "rna_Object_modifier_remove");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Remove an existing modifier from the object");
- /* modifier to remove */
- parm = RNA_def_pointer(func, "modifier", "Modifier", "", "Modifier to remove");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
-
- /* clear all modifiers */
- func = RNA_def_function(srna, "clear", "rna_Object_modifier_clear");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT);
- RNA_def_function_ui_description(func, "Remove all modifiers from the object");
+ StructRNA *srna;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "ObjectModifiers");
+ srna = RNA_def_struct(brna, "ObjectModifiers", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Object Modifiers", "Collection of object modifiers");
+
+# if 0
+ prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "EditBone");
+ RNA_def_property_pointer_sdna(prop, NULL, "act_edbone");
+ RNA_def_property_flag(prop, PROP_EDITABLE);
+ RNA_def_property_ui_text(prop, "Active EditBone", "Armatures active edit bone");
+ /*RNA_def_property_update(prop, 0, "rna_Armature_act_editbone_update"); */
+ RNA_def_property_pointer_funcs(prop, NULL, "rna_Armature_act_edit_bone_set", NULL, NULL);
+
+ /* todo, redraw */
+/* RNA_def_property_collection_active(prop, prop_act); */
+# endif
+
+ /* add modifier */
+ func = RNA_def_function(srna, "new", "rna_Object_modifier_new");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Add a new modifier");
+ parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the modifier");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* modifier to add */
+ parm = RNA_def_enum(
+ func, "type", rna_enum_object_modifier_type_items, 1, "", "Modifier type to add");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* return type */
+ parm = RNA_def_pointer(func, "modifier", "Modifier", "", "Newly created modifier");
+ RNA_def_function_return(func, parm);
+
+ /* remove modifier */
+ func = RNA_def_function(srna, "remove", "rna_Object_modifier_remove");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Remove an existing modifier from the object");
+ /* modifier to remove */
+ parm = RNA_def_pointer(func, "modifier", "Modifier", "", "Modifier to remove");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
+
+ /* clear all modifiers */
+ func = RNA_def_function(srna, "clear", "rna_Object_modifier_clear");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT);
+ RNA_def_function_ui_description(func, "Remove all modifiers from the object");
}
/* object.grease_pencil_modifiers */
static void rna_def_object_grease_pencil_modifiers(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "ObjectGpencilModifiers");
- srna = RNA_def_struct(brna, "ObjectGpencilModifiers", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Object Grease Pencil Modifiers", "Collection of object grease pencil modifiers");
-
- /* add greasepencil modifier */
- func = RNA_def_function(srna, "new", "rna_Object_greasepencil_modifier_new");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Add a new greasepencil_modifier");
- parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the greasepencil_modifier");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* greasepencil_modifier to add */
- parm = RNA_def_enum(func, "type", rna_enum_object_greasepencil_modifier_type_items, 1, "", "Modifier type to add");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* return type */
- parm = RNA_def_pointer(func, "greasepencil_modifier", "GpencilModifier", "", "Newly created modifier");
- RNA_def_function_return(func, parm);
-
- /* remove greasepencil_modifier */
- func = RNA_def_function(srna, "remove", "rna_Object_greasepencil_modifier_remove");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Remove an existing greasepencil_modifier from the object");
- /* greasepencil_modifier to remove */
- parm = RNA_def_pointer(func, "greasepencil_modifier", "GpencilModifier", "", "Modifier to remove");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
-
- /* clear all greasepencil modifiers */
- func = RNA_def_function(srna, "clear", "rna_Object_greasepencil_modifier_clear");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT);
- RNA_def_function_ui_description(func, "Remove all grease pencil modifiers from the object");
+ StructRNA *srna;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "ObjectGpencilModifiers");
+ srna = RNA_def_struct(brna, "ObjectGpencilModifiers", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(
+ srna, "Object Grease Pencil Modifiers", "Collection of object grease pencil modifiers");
+
+ /* add greasepencil modifier */
+ func = RNA_def_function(srna, "new", "rna_Object_greasepencil_modifier_new");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Add a new greasepencil_modifier");
+ parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the greasepencil_modifier");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* greasepencil_modifier to add */
+ parm = RNA_def_enum(func,
+ "type",
+ rna_enum_object_greasepencil_modifier_type_items,
+ 1,
+ "",
+ "Modifier type to add");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* return type */
+ parm = RNA_def_pointer(
+ func, "greasepencil_modifier", "GpencilModifier", "", "Newly created modifier");
+ RNA_def_function_return(func, parm);
+
+ /* remove greasepencil_modifier */
+ func = RNA_def_function(srna, "remove", "rna_Object_greasepencil_modifier_remove");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func,
+ "Remove an existing greasepencil_modifier from the object");
+ /* greasepencil_modifier to remove */
+ parm = RNA_def_pointer(
+ func, "greasepencil_modifier", "GpencilModifier", "", "Modifier to remove");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
+
+ /* clear all greasepencil modifiers */
+ func = RNA_def_function(srna, "clear", "rna_Object_greasepencil_modifier_clear");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT);
+ RNA_def_function_ui_description(func, "Remove all grease pencil modifiers from the object");
}
/* object.shaderfxs */
static void rna_def_object_shaderfxs(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "ObjectShaderFx");
- srna = RNA_def_struct(brna, "ObjectShaderFx", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Object Shader Effects", "Collection of object effects");
-
- /* add shader_fx */
- func = RNA_def_function(srna, "new", "rna_Object_shaderfx_new");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Add a new shader fx");
- parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the effect");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* shader to add */
- parm = RNA_def_enum(func, "type", rna_enum_object_shaderfx_type_items, 1, "", "Effect type to add");
- RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
- /* return type */
- parm = RNA_def_pointer(func, "shader_fx", "ShaderFx", "", "Newly created effect");
- RNA_def_function_return(func, parm);
-
- /* remove shader_fx */
- func = RNA_def_function(srna, "remove", "rna_Object_shaderfx_remove");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Remove an existing effect from the object");
- /* shader to remove */
- parm = RNA_def_pointer(func, "shader_fx", "ShaderFx", "", "Effect to remove");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
-
- /* clear all shader fx */
- func = RNA_def_function(srna, "clear", "rna_Object_shaderfx_clear");
- RNA_def_function_flag(func, FUNC_USE_CONTEXT);
- RNA_def_function_ui_description(func, "Remove all effects from the object");
+ StructRNA *srna;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "ObjectShaderFx");
+ srna = RNA_def_struct(brna, "ObjectShaderFx", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Object Shader Effects", "Collection of object effects");
+
+ /* add shader_fx */
+ func = RNA_def_function(srna, "new", "rna_Object_shaderfx_new");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Add a new shader fx");
+ parm = RNA_def_string(func, "name", "Name", 0, "", "New name for the effect");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* shader to add */
+ parm = RNA_def_enum(
+ func, "type", rna_enum_object_shaderfx_type_items, 1, "", "Effect type to add");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ /* return type */
+ parm = RNA_def_pointer(func, "shader_fx", "ShaderFx", "", "Newly created effect");
+ RNA_def_function_return(func, parm);
+
+ /* remove shader_fx */
+ func = RNA_def_function(srna, "remove", "rna_Object_shaderfx_remove");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Remove an existing effect from the object");
+ /* shader to remove */
+ parm = RNA_def_pointer(func, "shader_fx", "ShaderFx", "", "Effect to remove");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
+
+ /* clear all shader fx */
+ func = RNA_def_function(srna, "clear", "rna_Object_shaderfx_clear");
+ RNA_def_function_flag(func, FUNC_USE_CONTEXT);
+ RNA_def_function_ui_description(func, "Remove all effects from the object");
}
/* object.particle_systems */
static void rna_def_object_particle_systems(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
+ StructRNA *srna;
- PropertyRNA *prop;
+ PropertyRNA *prop;
- /* FunctionRNA *func; */
- /* PropertyRNA *parm; */
+ /* FunctionRNA *func; */
+ /* PropertyRNA *parm; */
- RNA_def_property_srna(cprop, "ParticleSystems");
- srna = RNA_def_struct(brna, "ParticleSystems", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Particle Systems", "Collection of particle systems");
+ RNA_def_property_srna(cprop, "ParticleSystems");
+ srna = RNA_def_struct(brna, "ParticleSystems", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Particle Systems", "Collection of particle systems");
- prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "ParticleSystem");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_particle_system_get", NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Active Particle System", "Active particle system being displayed");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+ prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "ParticleSystem");
+ RNA_def_property_pointer_funcs(prop, "rna_Object_active_particle_system_get", NULL, NULL, NULL);
+ RNA_def_property_ui_text(
+ prop, "Active Particle System", "Active particle system being displayed");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
- prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_int_funcs(prop, "rna_Object_active_particle_system_index_get",
- "rna_Object_active_particle_system_index_set",
- "rna_Object_active_particle_system_index_range");
- RNA_def_property_ui_text(prop, "Active Particle System Index", "Index of active particle system slot");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_particle_update");
+ prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_int_funcs(prop,
+ "rna_Object_active_particle_system_index_get",
+ "rna_Object_active_particle_system_index_set",
+ "rna_Object_active_particle_system_index_range");
+ RNA_def_property_ui_text(
+ prop, "Active Particle System Index", "Index of active particle system slot");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_particle_update");
}
-
/* object.vertex_groups */
static void rna_def_object_vertex_groups(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
-
- PropertyRNA *prop;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "VertexGroups");
- srna = RNA_def_struct(brna, "VertexGroups", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Vertex Groups", "Collection of vertex groups");
-
- prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "VertexGroup");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_vertex_group_get",
- "rna_Object_active_vertex_group_set", NULL, NULL);
- RNA_def_property_ui_text(prop, "Active Vertex Group", "Vertex groups of the object");
- RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_int_sdna(prop, NULL, "actdef");
- RNA_def_property_int_funcs(prop, "rna_Object_active_vertex_group_index_get",
- "rna_Object_active_vertex_group_index_set",
- "rna_Object_active_vertex_group_index_range");
- RNA_def_property_ui_text(prop, "Active Vertex Group Index", "Active index in vertex group array");
- RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
-
- /* vertex groups */ /* add_vertex_group */
- func = RNA_def_function(srna, "new", "rna_Object_vgroup_new");
- RNA_def_function_ui_description(func, "Add vertex group to object");
- RNA_def_string(func, "name", "Group", 0, "", "Vertex group name"); /* optional */
- parm = RNA_def_pointer(func, "group", "VertexGroup", "", "New vertex group");
- RNA_def_function_return(func, parm);
-
- func = RNA_def_function(srna, "remove", "rna_Object_vgroup_remove");
- RNA_def_function_flag(func, FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Delete vertex group from object");
- parm = RNA_def_pointer(func, "group", "VertexGroup", "", "Vertex group to remove");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
-
- func = RNA_def_function(srna, "clear", "rna_Object_vgroup_clear");
- RNA_def_function_ui_description(func, "Delete all vertex groups from object");
+ StructRNA *srna;
+
+ PropertyRNA *prop;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "VertexGroups");
+ srna = RNA_def_struct(brna, "VertexGroups", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Vertex Groups", "Collection of vertex groups");
+
+ prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "VertexGroup");
+ RNA_def_property_pointer_funcs(prop,
+ "rna_Object_active_vertex_group_get",
+ "rna_Object_active_vertex_group_set",
+ NULL,
+ NULL);
+ RNA_def_property_ui_text(prop, "Active Vertex Group", "Vertex groups of the object");
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_int_sdna(prop, NULL, "actdef");
+ RNA_def_property_int_funcs(prop,
+ "rna_Object_active_vertex_group_index_get",
+ "rna_Object_active_vertex_group_index_set",
+ "rna_Object_active_vertex_group_index_range");
+ RNA_def_property_ui_text(
+ prop, "Active Vertex Group Index", "Active index in vertex group array");
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
+
+ /* vertex groups */ /* add_vertex_group */
+ func = RNA_def_function(srna, "new", "rna_Object_vgroup_new");
+ RNA_def_function_ui_description(func, "Add vertex group to object");
+ RNA_def_string(func, "name", "Group", 0, "", "Vertex group name"); /* optional */
+ parm = RNA_def_pointer(func, "group", "VertexGroup", "", "New vertex group");
+ RNA_def_function_return(func, parm);
+
+ func = RNA_def_function(srna, "remove", "rna_Object_vgroup_remove");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Delete vertex group from object");
+ parm = RNA_def_pointer(func, "group", "VertexGroup", "", "Vertex group to remove");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
+
+ func = RNA_def_function(srna, "clear", "rna_Object_vgroup_clear");
+ RNA_def_function_ui_description(func, "Delete all vertex groups from object");
}
/* object.face_maps */
static void rna_def_object_face_maps(BlenderRNA *brna, PropertyRNA *cprop)
{
- StructRNA *srna;
-
- PropertyRNA *prop;
-
- FunctionRNA *func;
- PropertyRNA *parm;
-
- RNA_def_property_srna(cprop, "FaceMaps");
- srna = RNA_def_struct(brna, "FaceMaps", NULL);
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_ui_text(srna, "Face Maps", "Collection of face maps");
-
- prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "FaceMap");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_face_map_get",
- "rna_Object_active_face_map_set", NULL, NULL);
- RNA_def_property_ui_text(prop, "Active Face Map", "Face maps of the object");
- RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_int_sdna(prop, NULL, "actfmap");
- RNA_def_property_int_funcs(prop, "rna_Object_active_face_map_index_get",
- "rna_Object_active_face_map_index_set",
- "rna_Object_active_face_map_index_range");
- RNA_def_property_ui_text(prop, "Active Face Map Index", "Active index in face map array");
- RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
-
- /* face maps */ /* add_face_map */
- func = RNA_def_function(srna, "new", "rna_Object_fmap_new");
- RNA_def_function_ui_description(func, "Add face map to object");
- RNA_def_string(func, "name", "Map", 0, "", "face map name"); /* optional */
- parm = RNA_def_pointer(func, "fmap", "FaceMap", "", "New face map");
- RNA_def_function_return(func, parm);
-
- func = RNA_def_function(srna, "remove", "rna_Object_fmap_remove");
- RNA_def_function_flag(func, FUNC_USE_REPORTS);
- RNA_def_function_ui_description(func, "Delete vertex group from object");
- parm = RNA_def_pointer(func, "group", "FaceMap", "", "Face map to remove");
- RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
- RNA_def_property_clear_flag(parm, PROP_THICK_WRAP);
-
- func = RNA_def_function(srna, "clear", "rna_Object_fmap_clear");
- RNA_def_function_ui_description(func, "Delete all vertex groups from object");
+ StructRNA *srna;
+
+ PropertyRNA *prop;
+
+ FunctionRNA *func;
+ PropertyRNA *parm;
+
+ RNA_def_property_srna(cprop, "FaceMaps");
+ srna = RNA_def_struct(brna, "FaceMaps", NULL);
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_ui_text(srna, "Face Maps", "Collection of face maps");
+
+ prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "FaceMap");
+ RNA_def_property_pointer_funcs(
+ prop, "rna_Object_active_face_map_get", "rna_Object_active_face_map_set", NULL, NULL);
+ RNA_def_property_ui_text(prop, "Active Face Map", "Face maps of the object");
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_int_sdna(prop, NULL, "actfmap");
+ RNA_def_property_int_funcs(prop,
+ "rna_Object_active_face_map_index_get",
+ "rna_Object_active_face_map_index_set",
+ "rna_Object_active_face_map_index_range");
+ RNA_def_property_ui_text(prop, "Active Face Map Index", "Active index in face map array");
+ RNA_def_property_update(prop, NC_GEOM | ND_DATA, "rna_Object_internal_update_data");
+
+ /* face maps */ /* add_face_map */
+ func = RNA_def_function(srna, "new", "rna_Object_fmap_new");
+ RNA_def_function_ui_description(func, "Add face map to object");
+ RNA_def_string(func, "name", "Map", 0, "", "face map name"); /* optional */
+ parm = RNA_def_pointer(func, "fmap", "FaceMap", "", "New face map");
+ RNA_def_function_return(func, parm);
+
+ func = RNA_def_function(srna, "remove", "rna_Object_fmap_remove");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Delete vertex group from object");
+ parm = RNA_def_pointer(func, "group", "FaceMap", "", "Face map to remove");
+ RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
+ RNA_def_property_clear_flag(parm, PROP_THICK_WRAP);
+
+ func = RNA_def_function(srna, "clear", "rna_Object_fmap_clear");
+ RNA_def_function_ui_description(func, "Delete all vertex groups from object");
}
static void rna_def_object_display(BlenderRNA *brna)
{
- StructRNA *srna;
- PropertyRNA *prop;
+ StructRNA *srna;
+ PropertyRNA *prop;
- srna = RNA_def_struct(brna, "ObjectDisplay", NULL);
- RNA_def_struct_ui_text(srna, "Object Display", "Object display settings for 3d viewport");
- RNA_def_struct_sdna(srna, "Object");
- RNA_def_struct_nested(brna, srna, "Object");
- RNA_def_struct_path_func(srna, "rna_ObjectDisplay_path");
+ srna = RNA_def_struct(brna, "ObjectDisplay", NULL);
+ RNA_def_struct_ui_text(srna, "Object Display", "Object display settings for 3d viewport");
+ RNA_def_struct_sdna(srna, "Object");
+ RNA_def_struct_nested(brna, srna, "Object");
+ RNA_def_struct_path_func(srna, "rna_ObjectDisplay_path");
- prop = RNA_def_property(srna, "show_shadows", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_negative_sdna(prop, NULL, "dtx", OB_DRAW_NO_SHADOW_CAST);
- RNA_def_property_boolean_default(prop, true);
- RNA_def_property_ui_text(prop, "Shadow", "Object cast shadows in the 3d viewport");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+ prop = RNA_def_property(srna, "show_shadows", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_negative_sdna(prop, NULL, "dtx", OB_DRAW_NO_SHADOW_CAST);
+ RNA_def_property_boolean_default(prop, true);
+ RNA_def_property_ui_text(prop, "Shadow", "Object cast shadows in the 3d viewport");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
}
static void rna_def_object(BlenderRNA *brna)
{
- StructRNA *srna;
- PropertyRNA *prop;
-
- static const EnumPropertyItem up_items[] = {
- {OB_POSX, "X", 0, "X", ""},
- {OB_POSY, "Y", 0, "Y", ""},
- {OB_POSZ, "Z", 0, "Z", ""},
- {0, NULL, 0, NULL, NULL},
- };
-
- static const EnumPropertyItem drawtype_items[] = {
- {OB_BOUNDBOX, "BOUNDS", 0, "Bounds", "Display the bounds of the object"},
- {OB_WIRE, "WIRE", 0, "Wire", "Display the object as a wireframe"},
- {OB_SOLID, "SOLID", 0, "Solid", "Display the object as a solid (if solid drawing is enabled in the viewport)"},
- {OB_TEXTURE, "TEXTURED", 0, "Textured",
- "Display the object with textures (if textures are enabled in the viewport)"},
- {0, NULL, 0, NULL, NULL},
- };
-
- static const EnumPropertyItem boundtype_items[] = {
- {OB_BOUND_BOX, "BOX", 0, "Box", "Display bounds as box"},
- {OB_BOUND_SPHERE, "SPHERE", 0, "Sphere", "Display bounds as sphere"},
- {OB_BOUND_CYLINDER, "CYLINDER", 0, "Cylinder", "Display bounds as cylinder"},
- {OB_BOUND_CONE, "CONE", 0, "Cone", "Display bounds as cone"},
- {OB_BOUND_CAPSULE, "CAPSULE", 0, "Capsule", "Display bounds as capsule"},
- {0, NULL, 0, NULL, NULL},
- };
-
- static int boundbox_dimsize[] = {8, 3};
-
- srna = RNA_def_struct(brna, "Object", "ID");
- RNA_def_struct_ui_text(srna, "Object", "Object data-block defining an object in a scene");
- RNA_def_struct_clear_flag(srna, STRUCT_ID_REFCOUNT);
- RNA_def_struct_ui_icon(srna, ICON_OBJECT_DATA);
-
- prop = RNA_def_property(srna, "data", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "ID");
- RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_data_set", "rna_Object_data_typef", "rna_Object_data_poll");
- RNA_def_property_flag(prop, PROP_EDITABLE | PROP_NEVER_UNLINK);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Data", "Object data");
- RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "type");
- RNA_def_property_enum_items(prop, rna_enum_object_type_items);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_ui_text(prop, "Type", "Type of Object");
- RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_ID);
-
- prop = RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "mode");
- RNA_def_property_enum_items(prop, rna_enum_object_mode_items);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_ui_text(prop, "Mode", "Object interaction mode");
-
- /* for data access */
- prop = RNA_def_property(srna, "bound_box", PROP_FLOAT, PROP_NONE);
- RNA_def_property_multi_array(prop, 2, boundbox_dimsize);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_float_funcs(prop, "rna_Object_boundbox_get", NULL, NULL);
- RNA_def_property_ui_text(prop, "Bounding Box",
- "Object's bounding box in object-space coordinates, all values are -1.0 when "
- "not available");
-
- /* parent */
- prop = RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_parent_set", NULL, NULL);
- RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Parent", "Parent Object");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
-
- prop = RNA_def_property(srna, "parent_type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_bitflag_sdna(prop, NULL, "partype");
- RNA_def_property_enum_items(prop, parent_type_items);
- RNA_def_property_enum_funcs(prop, NULL, "rna_Object_parent_type_set", "rna_Object_parent_type_itemf");
- RNA_def_property_ui_text(prop, "Parent Type", "Type of parent relation");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
-
- prop = RNA_def_property(srna, "parent_vertices", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_int_sdna(prop, NULL, "par1");
- RNA_def_property_array(prop, 3);
- RNA_def_property_ui_text(prop, "Parent Vertices", "Indices of vertices in case of a vertex parenting relation");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "parent_bone", PROP_STRING, PROP_NONE);
- RNA_def_property_string_sdna(prop, NULL, "parsubstr");
- RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Object_parent_bone_set");
- RNA_def_property_ui_text(prop, "Parent Bone", "Name of parent bone in case of a bone parenting relation");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
-
- /* Track and Up flags */
- /* XXX: these have been saved here for a bit longer (after old track was removed),
- * since some other tools still refer to this */
- prop = RNA_def_property(srna, "track_axis", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "trackflag");
- RNA_def_property_enum_items(prop, rna_enum_object_axis_items);
- RNA_def_property_ui_text(prop, "Track Axis",
- "Axis that points in 'forward' direction (applies to InstanceFrame when "
- "parent 'Follow' is enabled)");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "up_axis", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "upflag");
- RNA_def_property_enum_items(prop, up_items);
- RNA_def_property_ui_text(prop, "Up Axis",
- "Axis that points in the upward direction (applies to InstanceFrame when "
- "parent 'Follow' is enabled)");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- /* proxy */
- prop = RNA_def_property(srna, "proxy", PROP_POINTER, PROP_NONE);
- RNA_def_property_ui_text(prop, "Proxy", "Library object this proxy object controls");
-
- prop = RNA_def_property(srna, "proxy_collection", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "proxy_group");
- RNA_def_property_ui_text(prop, "Proxy Collection", "Library collection duplicator object this proxy object controls");
-
- /* materials */
- prop = RNA_def_property(srna, "material_slots", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
- RNA_def_property_struct_type(prop, "MaterialSlot");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_NO_PROP_NAME);
- /* don't dereference pointer! */
- RNA_def_property_collection_funcs(prop, NULL, NULL, NULL, "rna_iterator_array_get", NULL, NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Material Slots", "Material slots in the object");
-
- prop = RNA_def_property(srna, "active_material", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "Material");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_material_get",
- "rna_Object_active_material_set", NULL,
- "rna_MaterialSlot_material_poll");
- RNA_def_property_flag(prop, PROP_EDITABLE);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_editable_func(prop, "rna_Object_active_material_editable");
- RNA_def_property_ui_text(prop, "Active Material", "Active material being displayed");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
-
- prop = RNA_def_property(srna, "active_material_index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_int_sdna(prop, NULL, "actcol");
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_int_funcs(prop, "rna_Object_active_material_index_get", "rna_Object_active_material_index_set",
- "rna_Object_active_material_index_range");
- RNA_def_property_ui_text(prop, "Active Material Index", "Index of active material slot");
- RNA_def_property_update(prop, NC_MATERIAL | ND_SHADING_LINKS, "rna_MaterialIndex_update");
-
- /* transform */
- prop = RNA_def_property(srna, "location", PROP_FLOAT, PROP_TRANSLATION);
- RNA_def_property_float_sdna(prop, NULL, "loc");
- RNA_def_property_editable_array_func(prop, "rna_Object_location_editable");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Location", "Location of the object");
- RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "rotation_quaternion", PROP_FLOAT, PROP_QUATERNION);
- RNA_def_property_float_sdna(prop, NULL, "quat");
- RNA_def_property_editable_array_func(prop, "rna_Object_rotation_4d_editable");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_float_array_default(prop, rna_default_quaternion);
- RNA_def_property_ui_text(prop, "Quaternion Rotation", "Rotation in Quaternions");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /* XXX: for axis-angle, it would have been nice to have 2 separate fields for UI purposes, but
- * having a single one is better for Keyframing and other property-management situations...
- */
- prop = RNA_def_property(srna, "rotation_axis_angle", PROP_FLOAT, PROP_AXISANGLE);
- RNA_def_property_array(prop, 4);
- RNA_def_property_float_funcs(prop, "rna_Object_rotation_axis_angle_get",
- "rna_Object_rotation_axis_angle_set", NULL);
- RNA_def_property_editable_array_func(prop, "rna_Object_rotation_4d_editable");
- RNA_def_property_float_array_default(prop, rna_default_axis_angle);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Axis-Angle Rotation", "Angle of Rotation for Axis-Angle rotation representation");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "rotation_euler", PROP_FLOAT, PROP_EULER);
- RNA_def_property_float_sdna(prop, NULL, "rot");
- RNA_def_property_editable_array_func(prop, "rna_Object_rotation_euler_editable");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Euler Rotation", "Rotation in Eulers");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "rotation_mode", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "rotmode");
- RNA_def_property_enum_items(prop, rna_enum_object_rotation_mode_items);
- RNA_def_property_enum_funcs(prop, NULL, "rna_Object_rotation_mode_set", NULL);
- RNA_def_property_ui_text(prop, "Rotation Mode", "");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "scale", PROP_FLOAT, PROP_XYZ);
- RNA_def_property_flag(prop, PROP_PROPORTIONAL);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_editable_array_func(prop, "rna_Object_scale_editable");
- RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
- RNA_def_property_float_array_default(prop, rna_default_scale_3d);
- RNA_def_property_ui_text(prop, "Scale", "Scaling of the object");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "dimensions", PROP_FLOAT, PROP_XYZ_LENGTH);
- RNA_def_property_array(prop, 3);
- /* Only as convinient helper for py API, and conflicts with animating scale. */
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_float_funcs(prop, "rna_Object_dimensions_get", "rna_Object_dimensions_set", NULL);
- RNA_def_property_ui_range(prop, 0.0f, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
- RNA_def_property_ui_text(prop, "Dimensions",
- "Absolute bounding box dimensions of the object (WARNING: assigning to it or "
- "its members mutiple consecutive times will not work correctly, "
- "as this needs up-to-date evaluated data)");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
-
- /* delta transforms */
- prop = RNA_def_property(srna, "delta_location", PROP_FLOAT, PROP_TRANSLATION);
- RNA_def_property_float_sdna(prop, NULL, "dloc");
- RNA_def_property_ui_text(prop, "Delta Location", "Extra translation added to the location of the object");
- RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "delta_rotation_euler", PROP_FLOAT, PROP_EULER);
- RNA_def_property_float_sdna(prop, NULL, "drot");
- RNA_def_property_ui_text(prop, "Delta Rotation (Euler)",
- "Extra rotation added to the rotation of the object (when using Euler rotations)");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "delta_rotation_quaternion", PROP_FLOAT, PROP_QUATERNION);
- RNA_def_property_float_sdna(prop, NULL, "dquat");
- RNA_def_property_float_array_default(prop, rna_default_quaternion);
- RNA_def_property_ui_text(prop, "Delta Rotation (Quaternion)",
- "Extra rotation added to the rotation of the object (when using Quaternion rotations)");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
-#if 0 /* XXX not supported well yet... */
- prop = RNA_def_property(srna, "delta_rotation_axis_angle", PROP_FLOAT, PROP_AXISANGLE);
- /* FIXME: this is not a single field any more! (drotAxis and drotAngle) */
- RNA_def_property_float_sdna(prop, NULL, "dquat");
- RNA_def_property_float_array_default(prop, rna_default_axis_angle);
- RNA_def_property_ui_text(prop, "Delta Rotation (Axis Angle)",
- "Extra rotation added to the rotation of the object (when using Axis-Angle rotations)");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-#endif
-
- prop = RNA_def_property(srna, "delta_scale", PROP_FLOAT, PROP_XYZ);
- RNA_def_property_float_sdna(prop, NULL, "dscale");
- RNA_def_property_flag(prop, PROP_PROPORTIONAL);
- RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
- RNA_def_property_float_array_default(prop, rna_default_scale_3d);
- RNA_def_property_ui_text(prop, "Delta Scale", "Extra scaling added to the scale of the object");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /* transform locks */
- prop = RNA_def_property(srna, "lock_location", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_LOCX);
- RNA_def_property_array(prop, 3);
- RNA_def_property_ui_text(prop, "Lock Location", "Lock editing of location in the interface");
- RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "lock_rotation", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROTX);
- RNA_def_property_array(prop, 3);
- RNA_def_property_ui_text(prop, "Lock Rotation", "Lock editing of rotation in the interface");
- RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /* XXX this is sub-optimal - it really should be included above,
- * but due to technical reasons we can't do this! */
- prop = RNA_def_property(srna, "lock_rotation_w", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROTW);
- RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
- RNA_def_property_ui_text(prop, "Lock Rotation (4D Angle)",
- "Lock editing of 'angle' component of four-component rotations in the interface");
- /* XXX this needs a better name */
- prop = RNA_def_property(srna, "lock_rotations_4d", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROT4D);
- RNA_def_property_ui_text(prop, "Lock Rotations (4D)",
- "Lock editing of four component rotations by components (instead of as Eulers)");
-
- prop = RNA_def_property(srna, "lock_scale", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_SCALEX);
- RNA_def_property_array(prop, 3);
- RNA_def_property_ui_text(prop, "Lock Scale", "Lock editing of scale in the interface");
- RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /* matrix */
- prop = RNA_def_property(srna, "matrix_world", PROP_FLOAT, PROP_MATRIX);
- RNA_def_property_float_sdna(prop, NULL, "obmat");
- RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_ui_text(prop, "Matrix World", "Worldspace transformation matrix");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_matrix_world_update");
-
- prop = RNA_def_property(srna, "matrix_local", PROP_FLOAT, PROP_MATRIX);
- RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_ui_text(prop, "Local Matrix", "Parent relative transformation matrix - "
- "WARNING: Only takes into account 'Object' parenting, so e.g. in case of bone parenting "
- "you get a matrix relative to the Armature object, not to the actual parent bone");
- RNA_def_property_float_funcs(prop, "rna_Object_matrix_local_get", "rna_Object_matrix_local_set", NULL);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "matrix_basis", PROP_FLOAT, PROP_MATRIX);
- RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_ui_text(prop, "Input Matrix",
- "Matrix access to location, rotation and scale (including deltas), "
- "before constraints and parenting are applied");
- RNA_def_property_float_funcs(prop, "rna_Object_matrix_basis_get", "rna_Object_matrix_basis_set", NULL);
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /*parent_inverse*/
- prop = RNA_def_property(srna, "matrix_parent_inverse", PROP_FLOAT, PROP_MATRIX);
- RNA_def_property_float_sdna(prop, NULL, "parentinv");
- RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
- RNA_def_property_ui_text(prop, "Matrix", "Inverse of object's parent matrix at time of parenting");
- RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
-
- /* modifiers */
- prop = RNA_def_property(srna, "modifiers", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_struct_type(prop, "Modifier");
- RNA_def_property_ui_text(prop, "Modifiers", "Modifiers affecting the geometric data of the object");
- RNA_def_property_override_funcs(prop, NULL, NULL, "rna_Object_modifiers_override_apply");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_STATIC_INSERTION);
- rna_def_object_modifiers(brna, prop);
-
- /* Grease Pencil modifiers. */
- prop = RNA_def_property(srna, "grease_pencil_modifiers", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "greasepencil_modifiers", NULL);
- RNA_def_property_struct_type(prop, "GpencilModifier");
- RNA_def_property_ui_text(prop, "Grease Pencil Modifiers", "Modifiers affecting the data of the grease pencil object");
- rna_def_object_grease_pencil_modifiers(brna, prop);
-
- /* Shader FX. */
- prop = RNA_def_property(srna, "shader_effects", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "shader_fx", NULL);
- RNA_def_property_struct_type(prop, "ShaderFx");
- RNA_def_property_ui_text(prop, "Shader Effects", "Effects affecting display of object");
- rna_def_object_shaderfxs(brna, prop);
-
- /* constraints */
- prop = RNA_def_property(srna, "constraints", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_struct_type(prop, "Constraint");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_STATIC_INSERTION);
- RNA_def_property_ui_text(prop, "Constraints", "Constraints affecting the transformation of the object");
- RNA_def_property_override_funcs(prop, NULL, NULL, "rna_Object_constraints_override_apply");
-/* RNA_def_property_collection_funcs(prop, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "constraints__add", "constraints__remove"); */
- rna_def_object_constraints(brna, prop);
-
- /* vertex groups */
- prop = RNA_def_property(srna, "vertex_groups", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "defbase", NULL);
- RNA_def_property_struct_type(prop, "VertexGroup");
- RNA_def_property_ui_text(prop, "Vertex Groups", "Vertex groups of the object");
- rna_def_object_vertex_groups(brna, prop);
-
-
- /* face maps */
- prop = RNA_def_property(srna, "face_maps", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "fmaps", NULL);
- RNA_def_property_struct_type(prop, "FaceMap");
- RNA_def_property_ui_text(prop, "Face Maps", "Maps of faces of the object");
- rna_def_object_face_maps(brna, prop);
-
- /* empty */
- prop = RNA_def_property(srna, "empty_display_type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "empty_drawtype");
- RNA_def_property_enum_items(prop, rna_enum_object_empty_drawtype_items);
- RNA_def_property_enum_funcs(prop, NULL, "rna_Object_empty_display_type_set", NULL);
- RNA_def_property_ui_text(prop, "Empty Display Type", "Viewport display style for empties");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "empty_display_size", PROP_FLOAT, PROP_DISTANCE);
- RNA_def_property_float_sdna(prop, NULL, "empty_drawsize");
- RNA_def_property_range(prop, 0.0001f, 1000.0f);
- RNA_def_property_ui_range(prop, 0.01, 100, 1, 2);
- RNA_def_property_ui_text(prop, "Empty Display Size", "Size of display for empties in the viewport");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "empty_image_offset", PROP_FLOAT, PROP_NONE);
- RNA_def_property_float_sdna(prop, NULL, "ima_ofs");
- RNA_def_property_ui_text(prop, "Origin Offset", "Origin offset distance");
- RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 0.1f, 2);
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "image_user", PROP_POINTER, PROP_NONE);
- RNA_def_property_flag(prop, PROP_NEVER_NULL);
- RNA_def_property_pointer_sdna(prop, NULL, "iuser");
- RNA_def_property_ui_text(prop, "Image User",
- "Parameters defining which layer, pass and frame of the image is displayed");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "empty_image_depth", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_items(prop, rna_enum_object_empty_image_depth_items);
- RNA_def_property_ui_text(prop, "Empty Image Depth", "Determine which other objects will occlude the image");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_empty_image_perspective", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_negative_sdna(prop, NULL, "empty_image_visibility_flag", OB_EMPTY_IMAGE_HIDE_PERSPECTIVE);
- RNA_def_property_ui_text(prop, "Display in Perspective Mode", "Display image in perspective mode");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_empty_image_orthographic", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_negative_sdna(prop, NULL, "empty_image_visibility_flag", OB_EMPTY_IMAGE_HIDE_ORTHOGRAPHIC);
- RNA_def_property_ui_text(prop, "Display in Orthographic Mode", "Display image in orthographic mode");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "use_empty_image_alpha", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "empty_image_flag", OB_EMPTY_IMAGE_USE_ALPHA_BLEND);
- RNA_def_property_ui_text(prop, "Use Alpha", "Use alpha blending instead of alpha test (can produce sorting artifacts)");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- static EnumPropertyItem prop_empty_image_side_items[] = {
- {0, "DOUBLE_SIDED", 0, "Both", ""},
- {OB_EMPTY_IMAGE_HIDE_BACK, "FRONT", 0, "Front", ""},
- {OB_EMPTY_IMAGE_HIDE_FRONT, "BACK", 0, "Back", ""},
- {0, NULL, 0, NULL, NULL},
- };
- prop = RNA_def_property(srna, "empty_image_side", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_bitflag_sdna(prop, NULL, "empty_image_visibility_flag");
- RNA_def_property_enum_items(prop, prop_empty_image_side_items);
- RNA_def_property_ui_text(prop, "Empty Image Side", "Show front/back side");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- /* render */
- prop = RNA_def_property(srna, "pass_index", PROP_INT, PROP_UNSIGNED);
- RNA_def_property_int_sdna(prop, NULL, "index");
- RNA_def_property_ui_text(prop, "Pass Index", "Index number for the \"Object Index\" render pass");
- RNA_def_property_update(prop, NC_OBJECT, "rna_Object_internal_update_draw");
-
- prop = RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
- RNA_def_property_ui_text(prop, "Color", "Object color and alpha, used when faces have the ObColor mode enabled");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- /* physics */
- prop = RNA_def_property(srna, "field", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "pd");
- RNA_def_property_struct_type(prop, "FieldSettings");
- RNA_def_property_pointer_funcs(prop, "rna_Object_field_get", NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Field Settings", "Settings for using the object as a field in physics simulation");
-
- prop = RNA_def_property(srna, "collision", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "pd");
- RNA_def_property_struct_type(prop, "CollisionSettings");
- RNA_def_property_pointer_funcs(prop, "rna_Object_collision_get", NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Collision Settings",
- "Settings for using the object as a collider in physics simulation");
-
- prop = RNA_def_property(srna, "soft_body", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "soft");
- RNA_def_property_struct_type(prop, "SoftBodySettings");
- RNA_def_property_ui_text(prop, "Soft Body Settings", "Settings for soft body simulation");
-
- prop = RNA_def_property(srna, "particle_systems", PROP_COLLECTION, PROP_NONE);
- RNA_def_property_collection_sdna(prop, NULL, "particlesystem", NULL);
- RNA_def_property_struct_type(prop, "ParticleSystem");
- RNA_def_property_ui_text(prop, "Particle Systems", "Particle systems emitted from the object");
- rna_def_object_particle_systems(brna, prop);
-
-
- prop = RNA_def_property(srna, "rigid_body", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "rigidbody_object");
- RNA_def_property_struct_type(prop, "RigidBodyObject");
- RNA_def_property_ui_text(prop, "Rigid Body Settings", "Settings for rigid body simulation");
-
- prop = RNA_def_property(srna, "rigid_body_constraint", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "rigidbody_constraint");
- RNA_def_property_struct_type(prop, "RigidBodyConstraint");
- RNA_def_property_ui_text(prop, "Rigid Body Constraint", "Constraint constraining rigid bodies");
-
- /* restrict */
- prop = RNA_def_property(srna, "hide_viewport", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_VIEW);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Disable View", "Disable object in the viewport");
- RNA_def_property_ui_icon(prop, ICON_RESTRICT_VIEW_OFF, -1);
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
-
- prop = RNA_def_property(srna, "hide_select", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_SELECT);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Disable Select", "Disable object selection in the viewport");
- RNA_def_property_ui_icon(prop, ICON_RESTRICT_SELECT_OFF, -1);
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
-
- prop = RNA_def_property(srna, "hide_render", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_RENDER);
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Disable Render", "Disable object in renders");
- RNA_def_property_ui_icon(prop, ICON_RESTRICT_RENDER_OFF, -1);
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
-
- prop = RNA_def_property(srna, "show_instancer_for_render", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "duplicator_visibility_flag", OB_DUPLI_FLAG_RENDER);
- RNA_def_property_ui_text(prop, "Render Instancer", "Make instancer visible when rendering");
-
- prop = RNA_def_property(srna, "show_instancer_for_viewport", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "duplicator_visibility_flag", OB_DUPLI_FLAG_VIEWPORT);
- RNA_def_property_ui_text(prop, "Display Instancer", "Make instancer visible in the viewport");
-
- /* anim */
- rna_def_animdata_common(srna);
-
- rna_def_animviz_common(srna);
- rna_def_motionpath_common(srna);
-
- /* instancing */
- prop = RNA_def_property(srna, "instance_type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_bitflag_sdna(prop, NULL, "transflag");
- RNA_def_property_enum_items(prop, instance_items);
- RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Object_instance_type_itemf");
- RNA_def_property_ui_text(prop, "Instance Type", "If not None, object instancing method to use");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
-
- prop = RNA_def_property(srna, "use_instance_vertices_rotation", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLIROT);
- RNA_def_property_ui_text(prop, "Orient with Normals", "Rotate instance according to vertex normal");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "use_instance_faces_scale", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLIFACES_SCALE);
- RNA_def_property_ui_text(prop, "Scale to Face Sizes", "Scale instance based on face size");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "instance_faces_scale", PROP_FLOAT, PROP_NONE);
- RNA_def_property_float_sdna(prop, NULL, "instance_faces_scale");
- RNA_def_property_range(prop, 0.001f, 10000.0f);
- RNA_def_property_ui_text(prop, "Instance Faces Scale", "Scale the face instance objects");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "instance_collection", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "Collection");
- RNA_def_property_pointer_sdna(prop, NULL, "instance_collection");
- RNA_def_property_flag(prop, PROP_EDITABLE);
- RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_dup_collection_set", NULL, NULL);
- RNA_def_property_ui_text(prop, "Instance Collection", "Instance an existing collection");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
-
- prop = RNA_def_property(srna, "is_instancer", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLI);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-
- /* drawing */
- prop = RNA_def_property(srna, "display_type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "dt");
- RNA_def_property_enum_items(prop, drawtype_items);
- RNA_def_property_ui_text(prop, "Display As", "How to display object in viewport");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
-
- prop = RNA_def_property(srna, "show_bounds", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWBOUNDOX);
- RNA_def_property_ui_text(prop, "Display Bounds", "Display the object's bounds");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "display_bounds_type", PROP_ENUM, PROP_NONE);
- RNA_def_property_enum_sdna(prop, NULL, "boundtype");
- RNA_def_property_enum_items(prop, boundtype_items);
- RNA_def_property_ui_text(prop, "Display Bounds Type", "Object boundary display type");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_name", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWNAME);
- RNA_def_property_ui_text(prop, "Display Name", "Display the object's name");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_axis", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_AXIS);
- RNA_def_property_ui_text(prop, "Display Axes", "Display the object's origin and axes");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_texture_space", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_TEXSPACE);
- RNA_def_property_ui_text(prop, "Display Texture Space", "Display the object's texture space");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_wire", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWWIRE);
- RNA_def_property_ui_text(prop, "Display Wire", "Add the object's wireframe over solid drawing");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_all_edges", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAW_ALL_EDGES);
- RNA_def_property_ui_text(prop, "Display All Edges", "Display all edges for mesh objects");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_transparent", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWTRANSP);
- RNA_def_property_ui_text(prop, "Display Transparent",
- "Display material transparency in the object");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- prop = RNA_def_property(srna, "show_in_front", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWXRAY);
- RNA_def_property_ui_text(prop, "In Front",
- "Make the object draw in front of others");
- RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
-
- /* pose */
- prop = RNA_def_property(srna, "pose_library", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "poselib");
- RNA_def_property_struct_type(prop, "Action");
- RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_REFCOUNT);
- RNA_def_property_ui_text(prop, "Pose Library", "Action used as a pose library for armatures");
-
- prop = RNA_def_property(srna, "pose", PROP_POINTER, PROP_NONE);
- RNA_def_property_pointer_sdna(prop, NULL, "pose");
- RNA_def_property_struct_type(prop, "Pose");
- RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
- RNA_def_property_ui_text(prop, "Pose", "Current pose for armatures");
-
- /* shape keys */
- prop = RNA_def_property(srna, "show_only_shape_key", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_LOCK);
- RNA_def_property_ui_text(prop, "Shape Key Lock", "Always show the current Shape for this Object");
- RNA_def_property_ui_icon(prop, ICON_UNPINNED, 1);
- RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "use_shape_key_edit_mode", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_EDIT_MODE);
- RNA_def_property_ui_text(prop, "Shape Key Edit Mode", "Apply shape keys in edit mode (for Meshes only)");
- RNA_def_property_ui_icon(prop, ICON_EDITMODE_HLT, 0);
- RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
-
- prop = RNA_def_property(srna, "active_shape_key", PROP_POINTER, PROP_NONE);
- RNA_def_property_struct_type(prop, "ShapeKey");
- RNA_def_property_pointer_funcs(prop, "rna_Object_active_shape_key_get", NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Active Shape Key", "Current shape key");
-
- prop = RNA_def_property(srna, "active_shape_key_index", PROP_INT, PROP_NONE);
- RNA_def_property_int_sdna(prop, NULL, "shapenr");
- RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
- RNA_def_property_clear_flag(prop, PROP_ANIMATABLE); /* XXX this is really unpredictable... */
- RNA_def_property_int_funcs(prop, "rna_Object_active_shape_key_index_get", "rna_Object_active_shape_key_index_set",
- "rna_Object_active_shape_key_index_range");
- RNA_def_property_ui_text(prop, "Active Shape Key Index", "Current shape key index");
- RNA_def_property_update(prop, 0, "rna_Object_active_shape_update");
-
- /* sculpt */
- prop = RNA_def_property(srna, "use_dynamic_topology_sculpting", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_funcs(prop, "rna_Object_use_dynamic_topology_sculpting_get", NULL);
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
- RNA_def_property_ui_text(prop, "Dynamic Topology Sculpting", NULL);
-
- /* Base Settings */
- prop = RNA_def_property(srna, "is_from_instancer", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "base_flag", BASE_FROM_DUPLI);
- RNA_def_property_ui_text(prop, "Base from Instancer", "Object comes from a instancer");
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-
- prop = RNA_def_property(srna, "is_from_set", PROP_BOOLEAN, PROP_NONE);
- RNA_def_property_boolean_sdna(prop, NULL, "base_flag", BASE_FROM_SET);
- RNA_def_property_ui_text(prop, "Base from Set", "Object comes from a background set");
- RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-
- /* Object Display */
- prop = RNA_def_property(srna, "display", PROP_POINTER, PROP_NONE);
- RNA_def_property_flag(prop, PROP_NEVER_NULL);
- RNA_def_property_struct_type(prop, "ObjectDisplay");
- RNA_def_property_pointer_funcs(prop, "rna_Object_display_get", NULL, NULL, NULL);
- RNA_def_property_ui_text(prop, "Object Display", "Object display settings for 3d viewport");
-
- RNA_api_object(srna);
+ StructRNA *srna;
+ PropertyRNA *prop;
+
+ static const EnumPropertyItem up_items[] = {
+ {OB_POSX, "X", 0, "X", ""},
+ {OB_POSY, "Y", 0, "Y", ""},
+ {OB_POSZ, "Z", 0, "Z", ""},
+ {0, NULL, 0, NULL, NULL},
+ };
+
+ static const EnumPropertyItem drawtype_items[] = {
+ {OB_BOUNDBOX, "BOUNDS", 0, "Bounds", "Display the bounds of the object"},
+ {OB_WIRE, "WIRE", 0, "Wire", "Display the object as a wireframe"},
+ {OB_SOLID,
+ "SOLID",
+ 0,
+ "Solid",
+ "Display the object as a solid (if solid drawing is enabled in the viewport)"},
+ {OB_TEXTURE,
+ "TEXTURED",
+ 0,
+ "Textured",
+ "Display the object with textures (if textures are enabled in the viewport)"},
+ {0, NULL, 0, NULL, NULL},
+ };
+
+ static const EnumPropertyItem boundtype_items[] = {
+ {OB_BOUND_BOX, "BOX", 0, "Box", "Display bounds as box"},
+ {OB_BOUND_SPHERE, "SPHERE", 0, "Sphere", "Display bounds as sphere"},
+ {OB_BOUND_CYLINDER, "CYLINDER", 0, "Cylinder", "Display bounds as cylinder"},
+ {OB_BOUND_CONE, "CONE", 0, "Cone", "Display bounds as cone"},
+ {OB_BOUND_CAPSULE, "CAPSULE", 0, "Capsule", "Display bounds as capsule"},
+ {0, NULL, 0, NULL, NULL},
+ };
+
+ static int boundbox_dimsize[] = {8, 3};
+
+ srna = RNA_def_struct(brna, "Object", "ID");
+ RNA_def_struct_ui_text(srna, "Object", "Object data-block defining an object in a scene");
+ RNA_def_struct_clear_flag(srna, STRUCT_ID_REFCOUNT);
+ RNA_def_struct_ui_icon(srna, ICON_OBJECT_DATA);
+
+ prop = RNA_def_property(srna, "data", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "ID");
+ RNA_def_property_pointer_funcs(
+ prop, NULL, "rna_Object_data_set", "rna_Object_data_typef", "rna_Object_data_poll");
+ RNA_def_property_flag(prop, PROP_EDITABLE | PROP_NEVER_UNLINK);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Data", "Object data");
+ RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "type");
+ RNA_def_property_enum_items(prop, rna_enum_object_type_items);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_ui_text(prop, "Type", "Type of Object");
+ RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_ID);
+
+ prop = RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "mode");
+ RNA_def_property_enum_items(prop, rna_enum_object_mode_items);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_ui_text(prop, "Mode", "Object interaction mode");
+
+ /* for data access */
+ prop = RNA_def_property(srna, "bound_box", PROP_FLOAT, PROP_NONE);
+ RNA_def_property_multi_array(prop, 2, boundbox_dimsize);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_float_funcs(prop, "rna_Object_boundbox_get", NULL, NULL);
+ RNA_def_property_ui_text(
+ prop,
+ "Bounding Box",
+ "Object's bounding box in object-space coordinates, all values are -1.0 when "
+ "not available");
+
+ /* parent */
+ prop = RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_parent_set", NULL, NULL);
+ RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Parent", "Parent Object");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
+
+ prop = RNA_def_property(srna, "parent_type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_bitflag_sdna(prop, NULL, "partype");
+ RNA_def_property_enum_items(prop, parent_type_items);
+ RNA_def_property_enum_funcs(
+ prop, NULL, "rna_Object_parent_type_set", "rna_Object_parent_type_itemf");
+ RNA_def_property_ui_text(prop, "Parent Type", "Type of parent relation");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
+
+ prop = RNA_def_property(srna, "parent_vertices", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_int_sdna(prop, NULL, "par1");
+ RNA_def_property_array(prop, 3);
+ RNA_def_property_ui_text(
+ prop, "Parent Vertices", "Indices of vertices in case of a vertex parenting relation");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "parent_bone", PROP_STRING, PROP_NONE);
+ RNA_def_property_string_sdna(prop, NULL, "parsubstr");
+ RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Object_parent_bone_set");
+ RNA_def_property_ui_text(
+ prop, "Parent Bone", "Name of parent bone in case of a bone parenting relation");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
+
+ /* Track and Up flags */
+ /* XXX: these have been saved here for a bit longer (after old track was removed),
+ * since some other tools still refer to this */
+ prop = RNA_def_property(srna, "track_axis", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "trackflag");
+ RNA_def_property_enum_items(prop, rna_enum_object_axis_items);
+ RNA_def_property_ui_text(
+ prop,
+ "Track Axis",
+ "Axis that points in 'forward' direction (applies to InstanceFrame when "
+ "parent 'Follow' is enabled)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "up_axis", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "upflag");
+ RNA_def_property_enum_items(prop, up_items);
+ RNA_def_property_ui_text(
+ prop,
+ "Up Axis",
+ "Axis that points in the upward direction (applies to InstanceFrame when "
+ "parent 'Follow' is enabled)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ /* proxy */
+ prop = RNA_def_property(srna, "proxy", PROP_POINTER, PROP_NONE);
+ RNA_def_property_ui_text(prop, "Proxy", "Library object this proxy object controls");
+
+ prop = RNA_def_property(srna, "proxy_collection", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "proxy_group");
+ RNA_def_property_ui_text(
+ prop, "Proxy Collection", "Library collection duplicator object this proxy object controls");
+
+ /* materials */
+ prop = RNA_def_property(srna, "material_slots", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
+ RNA_def_property_struct_type(prop, "MaterialSlot");
+ RNA_def_property_override_flag(prop,
+ PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_NO_PROP_NAME);
+ /* don't dereference pointer! */
+ RNA_def_property_collection_funcs(
+ prop, NULL, NULL, NULL, "rna_iterator_array_get", NULL, NULL, NULL, NULL);
+ RNA_def_property_ui_text(prop, "Material Slots", "Material slots in the object");
+
+ prop = RNA_def_property(srna, "active_material", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Material");
+ RNA_def_property_pointer_funcs(prop,
+ "rna_Object_active_material_get",
+ "rna_Object_active_material_set",
+ NULL,
+ "rna_MaterialSlot_material_poll");
+ RNA_def_property_flag(prop, PROP_EDITABLE);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_editable_func(prop, "rna_Object_active_material_editable");
+ RNA_def_property_ui_text(prop, "Active Material", "Active material being displayed");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_MaterialSlot_update");
+
+ prop = RNA_def_property(srna, "active_material_index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_int_sdna(prop, NULL, "actcol");
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_int_funcs(prop,
+ "rna_Object_active_material_index_get",
+ "rna_Object_active_material_index_set",
+ "rna_Object_active_material_index_range");
+ RNA_def_property_ui_text(prop, "Active Material Index", "Index of active material slot");
+ RNA_def_property_update(prop, NC_MATERIAL | ND_SHADING_LINKS, "rna_MaterialIndex_update");
+
+ /* transform */
+ prop = RNA_def_property(srna, "location", PROP_FLOAT, PROP_TRANSLATION);
+ RNA_def_property_float_sdna(prop, NULL, "loc");
+ RNA_def_property_editable_array_func(prop, "rna_Object_location_editable");
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Location", "Location of the object");
+ RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "rotation_quaternion", PROP_FLOAT, PROP_QUATERNION);
+ RNA_def_property_float_sdna(prop, NULL, "quat");
+ RNA_def_property_editable_array_func(prop, "rna_Object_rotation_4d_editable");
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_float_array_default(prop, rna_default_quaternion);
+ RNA_def_property_ui_text(prop, "Quaternion Rotation", "Rotation in Quaternions");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* XXX: for axis-angle, it would have been nice to have 2 separate fields for UI purposes, but
+ * having a single one is better for Keyframing and other property-management situations...
+ */
+ prop = RNA_def_property(srna, "rotation_axis_angle", PROP_FLOAT, PROP_AXISANGLE);
+ RNA_def_property_array(prop, 4);
+ RNA_def_property_float_funcs(
+ prop, "rna_Object_rotation_axis_angle_get", "rna_Object_rotation_axis_angle_set", NULL);
+ RNA_def_property_editable_array_func(prop, "rna_Object_rotation_4d_editable");
+ RNA_def_property_float_array_default(prop, rna_default_axis_angle);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(
+ prop, "Axis-Angle Rotation", "Angle of Rotation for Axis-Angle rotation representation");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "rotation_euler", PROP_FLOAT, PROP_EULER);
+ RNA_def_property_float_sdna(prop, NULL, "rot");
+ RNA_def_property_editable_array_func(prop, "rna_Object_rotation_euler_editable");
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Euler Rotation", "Rotation in Eulers");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "rotation_mode", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "rotmode");
+ RNA_def_property_enum_items(prop, rna_enum_object_rotation_mode_items);
+ RNA_def_property_enum_funcs(prop, NULL, "rna_Object_rotation_mode_set", NULL);
+ RNA_def_property_ui_text(prop, "Rotation Mode", "");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "scale", PROP_FLOAT, PROP_XYZ);
+ RNA_def_property_flag(prop, PROP_PROPORTIONAL);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_editable_array_func(prop, "rna_Object_scale_editable");
+ RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
+ RNA_def_property_float_array_default(prop, rna_default_scale_3d);
+ RNA_def_property_ui_text(prop, "Scale", "Scaling of the object");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "dimensions", PROP_FLOAT, PROP_XYZ_LENGTH);
+ RNA_def_property_array(prop, 3);
+ /* Only as convinient helper for py API, and conflicts with animating scale. */
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_float_funcs(
+ prop, "rna_Object_dimensions_get", "rna_Object_dimensions_set", NULL);
+ RNA_def_property_ui_range(prop, 0.0f, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
+ RNA_def_property_ui_text(
+ prop,
+ "Dimensions",
+ "Absolute bounding box dimensions of the object (WARNING: assigning to it or "
+ "its members mutiple consecutive times will not work correctly, "
+ "as this needs up-to-date evaluated data)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* delta transforms */
+ prop = RNA_def_property(srna, "delta_location", PROP_FLOAT, PROP_TRANSLATION);
+ RNA_def_property_float_sdna(prop, NULL, "dloc");
+ RNA_def_property_ui_text(
+ prop, "Delta Location", "Extra translation added to the location of the object");
+ RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, RNA_TRANSLATION_PREC_DEFAULT);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "delta_rotation_euler", PROP_FLOAT, PROP_EULER);
+ RNA_def_property_float_sdna(prop, NULL, "drot");
+ RNA_def_property_ui_text(
+ prop,
+ "Delta Rotation (Euler)",
+ "Extra rotation added to the rotation of the object (when using Euler rotations)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "delta_rotation_quaternion", PROP_FLOAT, PROP_QUATERNION);
+ RNA_def_property_float_sdna(prop, NULL, "dquat");
+ RNA_def_property_float_array_default(prop, rna_default_quaternion);
+ RNA_def_property_ui_text(
+ prop,
+ "Delta Rotation (Quaternion)",
+ "Extra rotation added to the rotation of the object (when using Quaternion rotations)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+# if 0 /* XXX not supported well yet... */
+ prop = RNA_def_property(srna, "delta_rotation_axis_angle", PROP_FLOAT, PROP_AXISANGLE);
+ /* FIXME: this is not a single field any more! (drotAxis and drotAngle) */
+ RNA_def_property_float_sdna(prop, NULL, "dquat");
+ RNA_def_property_float_array_default(prop, rna_default_axis_angle);
+ RNA_def_property_ui_text(prop, "Delta Rotation (Axis Angle)",
+ "Extra rotation added to the rotation of the object (when using Axis-Angle rotations)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+# endif
+
+ prop = RNA_def_property(srna, "delta_scale", PROP_FLOAT, PROP_XYZ);
+ RNA_def_property_float_sdna(prop, NULL, "dscale");
+ RNA_def_property_flag(prop, PROP_PROPORTIONAL);
+ RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
+ RNA_def_property_float_array_default(prop, rna_default_scale_3d);
+ RNA_def_property_ui_text(prop, "Delta Scale", "Extra scaling added to the scale of the object");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* transform locks */
+ prop = RNA_def_property(srna, "lock_location", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_LOCX);
+ RNA_def_property_array(prop, 3);
+ RNA_def_property_ui_text(prop, "Lock Location", "Lock editing of location in the interface");
+ RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "lock_rotation", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROTX);
+ RNA_def_property_array(prop, 3);
+ RNA_def_property_ui_text(prop, "Lock Rotation", "Lock editing of rotation in the interface");
+ RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* XXX this is sub-optimal - it really should be included above,
+ * but due to technical reasons we can't do this! */
+ prop = RNA_def_property(srna, "lock_rotation_w", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROTW);
+ RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
+ RNA_def_property_ui_text(
+ prop,
+ "Lock Rotation (4D Angle)",
+ "Lock editing of 'angle' component of four-component rotations in the interface");
+ /* XXX this needs a better name */
+ prop = RNA_def_property(srna, "lock_rotations_4d", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROT4D);
+ RNA_def_property_ui_text(
+ prop,
+ "Lock Rotations (4D)",
+ "Lock editing of four component rotations by components (instead of as Eulers)");
+
+ prop = RNA_def_property(srna, "lock_scale", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_SCALEX);
+ RNA_def_property_array(prop, 3);
+ RNA_def_property_ui_text(prop, "Lock Scale", "Lock editing of scale in the interface");
+ RNA_def_property_ui_icon(prop, ICON_UNLOCKED, 1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* matrix */
+ prop = RNA_def_property(srna, "matrix_world", PROP_FLOAT, PROP_MATRIX);
+ RNA_def_property_float_sdna(prop, NULL, "obmat");
+ RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_ui_text(prop, "Matrix World", "Worldspace transformation matrix");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_matrix_world_update");
+
+ prop = RNA_def_property(srna, "matrix_local", PROP_FLOAT, PROP_MATRIX);
+ RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_ui_text(
+ prop,
+ "Local Matrix",
+ "Parent relative transformation matrix - "
+ "WARNING: Only takes into account 'Object' parenting, so e.g. in case of bone parenting "
+ "you get a matrix relative to the Armature object, not to the actual parent bone");
+ RNA_def_property_float_funcs(
+ prop, "rna_Object_matrix_local_get", "rna_Object_matrix_local_set", NULL);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "matrix_basis", PROP_FLOAT, PROP_MATRIX);
+ RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_ui_text(prop,
+ "Input Matrix",
+ "Matrix access to location, rotation and scale (including deltas), "
+ "before constraints and parenting are applied");
+ RNA_def_property_float_funcs(
+ prop, "rna_Object_matrix_basis_get", "rna_Object_matrix_basis_set", NULL);
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /*parent_inverse*/
+ prop = RNA_def_property(srna, "matrix_parent_inverse", PROP_FLOAT, PROP_MATRIX);
+ RNA_def_property_float_sdna(prop, NULL, "parentinv");
+ RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+ RNA_def_property_ui_text(
+ prop, "Matrix", "Inverse of object's parent matrix at time of parenting");
+ RNA_def_property_update(prop, NC_OBJECT | ND_TRANSFORM, "rna_Object_internal_update");
+
+ /* modifiers */
+ prop = RNA_def_property(srna, "modifiers", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Modifier");
+ RNA_def_property_ui_text(
+ prop, "Modifiers", "Modifiers affecting the geometric data of the object");
+ RNA_def_property_override_funcs(prop, NULL, NULL, "rna_Object_modifiers_override_apply");
+ RNA_def_property_override_flag(prop,
+ PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_STATIC_INSERTION);
+ rna_def_object_modifiers(brna, prop);
+
+ /* Grease Pencil modifiers. */
+ prop = RNA_def_property(srna, "grease_pencil_modifiers", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "greasepencil_modifiers", NULL);
+ RNA_def_property_struct_type(prop, "GpencilModifier");
+ RNA_def_property_ui_text(
+ prop, "Grease Pencil Modifiers", "Modifiers affecting the data of the grease pencil object");
+ rna_def_object_grease_pencil_modifiers(brna, prop);
+
+ /* Shader FX. */
+ prop = RNA_def_property(srna, "shader_effects", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "shader_fx", NULL);
+ RNA_def_property_struct_type(prop, "ShaderFx");
+ RNA_def_property_ui_text(prop, "Shader Effects", "Effects affecting display of object");
+ rna_def_object_shaderfxs(brna, prop);
+
+ /* constraints */
+ prop = RNA_def_property(srna, "constraints", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Constraint");
+ RNA_def_property_override_flag(prop,
+ PROPOVERRIDE_OVERRIDABLE_STATIC | PROPOVERRIDE_STATIC_INSERTION);
+ RNA_def_property_ui_text(
+ prop, "Constraints", "Constraints affecting the transformation of the object");
+ RNA_def_property_override_funcs(prop, NULL, NULL, "rna_Object_constraints_override_apply");
+ /* RNA_def_property_collection_funcs(prop, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "constraints__add", "constraints__remove"); */
+ rna_def_object_constraints(brna, prop);
+
+ /* vertex groups */
+ prop = RNA_def_property(srna, "vertex_groups", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "defbase", NULL);
+ RNA_def_property_struct_type(prop, "VertexGroup");
+ RNA_def_property_ui_text(prop, "Vertex Groups", "Vertex groups of the object");
+ rna_def_object_vertex_groups(brna, prop);
+
+ /* face maps */
+ prop = RNA_def_property(srna, "face_maps", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "fmaps", NULL);
+ RNA_def_property_struct_type(prop, "FaceMap");
+ RNA_def_property_ui_text(prop, "Face Maps", "Maps of faces of the object");
+ rna_def_object_face_maps(brna, prop);
+
+ /* empty */
+ prop = RNA_def_property(srna, "empty_display_type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "empty_drawtype");
+ RNA_def_property_enum_items(prop, rna_enum_object_empty_drawtype_items);
+ RNA_def_property_enum_funcs(prop, NULL, "rna_Object_empty_display_type_set", NULL);
+ RNA_def_property_ui_text(prop, "Empty Display Type", "Viewport display style for empties");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "empty_display_size", PROP_FLOAT, PROP_DISTANCE);
+ RNA_def_property_float_sdna(prop, NULL, "empty_drawsize");
+ RNA_def_property_range(prop, 0.0001f, 1000.0f);
+ RNA_def_property_ui_range(prop, 0.01, 100, 1, 2);
+ RNA_def_property_ui_text(
+ prop, "Empty Display Size", "Size of display for empties in the viewport");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "empty_image_offset", PROP_FLOAT, PROP_NONE);
+ RNA_def_property_float_sdna(prop, NULL, "ima_ofs");
+ RNA_def_property_ui_text(prop, "Origin Offset", "Origin offset distance");
+ RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 0.1f, 2);
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "image_user", PROP_POINTER, PROP_NONE);
+ RNA_def_property_flag(prop, PROP_NEVER_NULL);
+ RNA_def_property_pointer_sdna(prop, NULL, "iuser");
+ RNA_def_property_ui_text(
+ prop,
+ "Image User",
+ "Parameters defining which layer, pass and frame of the image is displayed");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "empty_image_depth", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_items(prop, rna_enum_object_empty_image_depth_items);
+ RNA_def_property_ui_text(
+ prop, "Empty Image Depth", "Determine which other objects will occlude the image");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_empty_image_perspective", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_negative_sdna(
+ prop, NULL, "empty_image_visibility_flag", OB_EMPTY_IMAGE_HIDE_PERSPECTIVE);
+ RNA_def_property_ui_text(
+ prop, "Display in Perspective Mode", "Display image in perspective mode");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_empty_image_orthographic", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_negative_sdna(
+ prop, NULL, "empty_image_visibility_flag", OB_EMPTY_IMAGE_HIDE_ORTHOGRAPHIC);
+ RNA_def_property_ui_text(
+ prop, "Display in Orthographic Mode", "Display image in orthographic mode");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "use_empty_image_alpha", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "empty_image_flag", OB_EMPTY_IMAGE_USE_ALPHA_BLEND);
+ RNA_def_property_ui_text(
+ prop,
+ "Use Alpha",
+ "Use alpha blending instead of alpha test (can produce sorting artifacts)");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ static EnumPropertyItem prop_empty_image_side_items[] = {
+ {0, "DOUBLE_SIDED", 0, "Both", ""},
+ {OB_EMPTY_IMAGE_HIDE_BACK, "FRONT", 0, "Front", ""},
+ {OB_EMPTY_IMAGE_HIDE_FRONT, "BACK", 0, "Back", ""},
+ {0, NULL, 0, NULL, NULL},
+ };
+ prop = RNA_def_property(srna, "empty_image_side", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_bitflag_sdna(prop, NULL, "empty_image_visibility_flag");
+ RNA_def_property_enum_items(prop, prop_empty_image_side_items);
+ RNA_def_property_ui_text(prop, "Empty Image Side", "Show front/back side");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ /* render */
+ prop = RNA_def_property(srna, "pass_index", PROP_INT, PROP_UNSIGNED);
+ RNA_def_property_int_sdna(prop, NULL, "index");
+ RNA_def_property_ui_text(
+ prop, "Pass Index", "Index number for the \"Object Index\" render pass");
+ RNA_def_property_update(prop, NC_OBJECT, "rna_Object_internal_update_draw");
+
+ prop = RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
+ RNA_def_property_ui_text(
+ prop, "Color", "Object color and alpha, used when faces have the ObColor mode enabled");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ /* physics */
+ prop = RNA_def_property(srna, "field", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "pd");
+ RNA_def_property_struct_type(prop, "FieldSettings");
+ RNA_def_property_pointer_funcs(prop, "rna_Object_field_get", NULL, NULL, NULL);
+ RNA_def_property_ui_text(
+ prop, "Field Settings", "Settings for using the object as a field in physics simulation");
+
+ prop = RNA_def_property(srna, "collision", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "pd");
+ RNA_def_property_struct_type(prop, "CollisionSettings");
+ RNA_def_property_pointer_funcs(prop, "rna_Object_collision_get", NULL, NULL, NULL);
+ RNA_def_property_ui_text(prop,
+ "Collision Settings",
+ "Settings for using the object as a collider in physics simulation");
+
+ prop = RNA_def_property(srna, "soft_body", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "soft");
+ RNA_def_property_struct_type(prop, "SoftBodySettings");
+ RNA_def_property_ui_text(prop, "Soft Body Settings", "Settings for soft body simulation");
+
+ prop = RNA_def_property(srna, "particle_systems", PROP_COLLECTION, PROP_NONE);
+ RNA_def_property_collection_sdna(prop, NULL, "particlesystem", NULL);
+ RNA_def_property_struct_type(prop, "ParticleSystem");
+ RNA_def_property_ui_text(prop, "Particle Systems", "Particle systems emitted from the object");
+ rna_def_object_particle_systems(brna, prop);
+
+ prop = RNA_def_property(srna, "rigid_body", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "rigidbody_object");
+ RNA_def_property_struct_type(prop, "RigidBodyObject");
+ RNA_def_property_ui_text(prop, "Rigid Body Settings", "Settings for rigid body simulation");
+
+ prop = RNA_def_property(srna, "rigid_body_constraint", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "rigidbody_constraint");
+ RNA_def_property_struct_type(prop, "RigidBodyConstraint");
+ RNA_def_property_ui_text(prop, "Rigid Body Constraint", "Constraint constraining rigid bodies");
+
+ /* restrict */
+ prop = RNA_def_property(srna, "hide_viewport", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_VIEW);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Disable View", "Disable object in the viewport");
+ RNA_def_property_ui_icon(prop, ICON_RESTRICT_VIEW_OFF, -1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
+
+ prop = RNA_def_property(srna, "hide_select", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_SELECT);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Disable Select", "Disable object selection in the viewport");
+ RNA_def_property_ui_icon(prop, ICON_RESTRICT_SELECT_OFF, -1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
+
+ prop = RNA_def_property(srna, "hide_render", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_RENDER);
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Disable Render", "Disable object in renders");
+ RNA_def_property_ui_icon(prop, ICON_RESTRICT_RENDER_OFF, -1);
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_hide_update");
+
+ prop = RNA_def_property(srna, "show_instancer_for_render", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "duplicator_visibility_flag", OB_DUPLI_FLAG_RENDER);
+ RNA_def_property_ui_text(prop, "Render Instancer", "Make instancer visible when rendering");
+
+ prop = RNA_def_property(srna, "show_instancer_for_viewport", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "duplicator_visibility_flag", OB_DUPLI_FLAG_VIEWPORT);
+ RNA_def_property_ui_text(prop, "Display Instancer", "Make instancer visible in the viewport");
+
+ /* anim */
+ rna_def_animdata_common(srna);
+
+ rna_def_animviz_common(srna);
+ rna_def_motionpath_common(srna);
+
+ /* instancing */
+ prop = RNA_def_property(srna, "instance_type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_bitflag_sdna(prop, NULL, "transflag");
+ RNA_def_property_enum_items(prop, instance_items);
+ RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Object_instance_type_itemf");
+ RNA_def_property_ui_text(prop, "Instance Type", "If not None, object instancing method to use");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
+
+ prop = RNA_def_property(srna, "use_instance_vertices_rotation", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLIROT);
+ RNA_def_property_ui_text(
+ prop, "Orient with Normals", "Rotate instance according to vertex normal");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "use_instance_faces_scale", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLIFACES_SCALE);
+ RNA_def_property_ui_text(prop, "Scale to Face Sizes", "Scale instance based on face size");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "instance_faces_scale", PROP_FLOAT, PROP_NONE);
+ RNA_def_property_float_sdna(prop, NULL, "instance_faces_scale");
+ RNA_def_property_range(prop, 0.001f, 10000.0f);
+ RNA_def_property_ui_text(prop, "Instance Faces Scale", "Scale the face instance objects");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "instance_collection", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "Collection");
+ RNA_def_property_pointer_sdna(prop, NULL, "instance_collection");
+ RNA_def_property_flag(prop, PROP_EDITABLE);
+ RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_dup_collection_set", NULL, NULL);
+ RNA_def_property_ui_text(prop, "Instance Collection", "Instance an existing collection");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_dependency_update");
+
+ prop = RNA_def_property(srna, "is_instancer", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLI);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+
+ /* drawing */
+ prop = RNA_def_property(srna, "display_type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "dt");
+ RNA_def_property_enum_items(prop, drawtype_items);
+ RNA_def_property_ui_text(prop, "Display As", "How to display object in viewport");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_Object_internal_update");
+
+ prop = RNA_def_property(srna, "show_bounds", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWBOUNDOX);
+ RNA_def_property_ui_text(prop, "Display Bounds", "Display the object's bounds");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "display_bounds_type", PROP_ENUM, PROP_NONE);
+ RNA_def_property_enum_sdna(prop, NULL, "boundtype");
+ RNA_def_property_enum_items(prop, boundtype_items);
+ RNA_def_property_ui_text(prop, "Display Bounds Type", "Object boundary display type");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_name", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWNAME);
+ RNA_def_property_ui_text(prop, "Display Name", "Display the object's name");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_axis", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_AXIS);
+ RNA_def_property_ui_text(prop, "Display Axes", "Display the object's origin and axes");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_texture_space", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_TEXSPACE);
+ RNA_def_property_ui_text(prop, "Display Texture Space", "Display the object's texture space");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_wire", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWWIRE);
+ RNA_def_property_ui_text(prop, "Display Wire", "Add the object's wireframe over solid drawing");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_all_edges", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAW_ALL_EDGES);
+ RNA_def_property_ui_text(prop, "Display All Edges", "Display all edges for mesh objects");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_transparent", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWTRANSP);
+ RNA_def_property_ui_text(
+ prop, "Display Transparent", "Display material transparency in the object");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ prop = RNA_def_property(srna, "show_in_front", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWXRAY);
+ RNA_def_property_ui_text(prop, "In Front", "Make the object draw in front of others");
+ RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, NULL);
+
+ /* pose */
+ prop = RNA_def_property(srna, "pose_library", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "poselib");
+ RNA_def_property_struct_type(prop, "Action");
+ RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_REFCOUNT);
+ RNA_def_property_ui_text(prop, "Pose Library", "Action used as a pose library for armatures");
+
+ prop = RNA_def_property(srna, "pose", PROP_POINTER, PROP_NONE);
+ RNA_def_property_pointer_sdna(prop, NULL, "pose");
+ RNA_def_property_struct_type(prop, "Pose");
+ RNA_def_property_override_flag(prop, PROPOVERRIDE_OVERRIDABLE_STATIC);
+ RNA_def_property_ui_text(prop, "Pose", "Current pose for armatures");
+
+ /* shape keys */
+ prop = RNA_def_property(srna, "show_only_shape_key", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_LOCK);
+ RNA_def_property_ui_text(
+ prop, "Shape Key Lock", "Always show the current Shape for this Object");
+ RNA_def_property_ui_icon(prop, ICON_UNPINNED, 1);
+ RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "use_shape_key_edit_mode", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_EDIT_MODE);
+ RNA_def_property_ui_text(
+ prop, "Shape Key Edit Mode", "Apply shape keys in edit mode (for Meshes only)");
+ RNA_def_property_ui_icon(prop, ICON_EDITMODE_HLT, 0);
+ RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
+
+ prop = RNA_def_property(srna, "active_shape_key", PROP_POINTER, PROP_NONE);
+ RNA_def_property_struct_type(prop, "ShapeKey");
+ RNA_def_property_pointer_funcs(prop, "rna_Object_active_shape_key_get", NULL, NULL, NULL);
+ RNA_def_property_ui_text(prop, "Active Shape Key", "Current shape key");
+
+ prop = RNA_def_property(srna, "active_shape_key_index", PROP_INT, PROP_NONE);
+ RNA_def_property_int_sdna(prop, NULL, "shapenr");
+ RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
+ RNA_def_property_clear_flag(prop, PROP_ANIMATABLE); /* XXX this is really unpredictable... */
+ RNA_def_property_int_funcs(prop,
+ "rna_Object_active_shape_key_index_get",
+ "rna_Object_active_shape_key_index_set",
+ "rna_Object_active_shape_key_index_range");
+ RNA_def_property_ui_text(prop, "Active Shape Key Index", "Current shape key index");
+ RNA_def_property_update(prop, 0, "rna_Object_active_shape_update");
+
+ /* sculpt */
+ prop = RNA_def_property(srna, "use_dynamic_topology_sculpting", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_funcs(prop, "rna_Object_use_dynamic_topology_sculpting_get", NULL);
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+ RNA_def_property_ui_text(prop, "Dynamic Topology Sculpting", NULL);
+
+ /* Base Settings */
+ prop = RNA_def_property(srna, "is_from_instancer", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "base_flag", BASE_FROM_DUPLI);
+ RNA_def_property_ui_text(prop, "Base from Instancer", "Object comes from a instancer");
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+
+ prop = RNA_def_property(srna, "is_from_set", PROP_BOOLEAN, PROP_NONE);
+ RNA_def_property_boolean_sdna(prop, NULL, "base_flag", BASE_FROM_SET);
+ RNA_def_property_ui_text(prop, "Base from Set", "Object comes from a background set");
+ RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+
+ /* Object Display */
+ prop = RNA_def_property(srna, "display", PROP_POINTER, PROP_NONE);
+ RNA_def_property_flag(prop, PROP_NEVER_NULL);
+ RNA_def_property_struct_type(prop, "ObjectDisplay");
+ RNA_def_property_pointer_funcs(prop, "rna_Object_display_get", NULL, NULL, NULL);
+ RNA_def_property_ui_text(prop, "Object Display", "Object display settings for 3d viewport");
+
+ RNA_api_object(srna);
}
void RNA_def_object(BlenderRNA *brna)
{
- rna_def_object(brna);
+ rna_def_object(brna);
- RNA_define_animate_sdna(false);
- rna_def_vertex_group(brna);
- rna_def_face_map(brna);
- rna_def_material_slot(brna);
- rna_def_object_display(brna);
- RNA_define_animate_sdna(true);
+ RNA_define_animate_sdna(false);
+ rna_def_vertex_group(brna);
+ rna_def_face_map(brna);
+ rna_def_material_slot(brna);
+ rna_def_object_display(brna);
+ RNA_define_animate_sdna(true);
}
#endif