48efee411bcf129e7bcfdad20fb8a39f450f6050
[blender.git] / source / blender / makesrna / intern / rna_scene.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributor(s): Blender Foundation (2008).
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 /** \file blender/makesrna/intern/rna_scene.c
24  *  \ingroup RNA
25  */
26
27 #include <stdlib.h>
28
29 #include "DNA_brush_types.h"
30 #include "DNA_group_types.h"
31 #include "DNA_modifier_types.h"
32 #include "DNA_particle_types.h"
33 #include "DNA_rigidbody_types.h"
34 #include "DNA_scene_types.h"
35 #include "DNA_layer_types.h"
36 #include "DNA_linestyle_types.h"
37 #include "DNA_userdef_types.h"
38 #include "DNA_world_types.h"
39 #include "DNA_gpencil_types.h"
40
41 #include "IMB_imbuf_types.h"
42
43 #include "BLI_math.h"
44 #include "BLI_string_utils.h"
45
46 #include "BLT_translation.h"
47
48 #include "BKE_editmesh.h"
49 #include "BKE_paint.h"
50
51 #include "ED_object.h"
52
53 #include "GPU_extensions.h"
54
55 #include "DRW_engine.h"
56
57 #include "RNA_define.h"
58 #include "RNA_enum_types.h"
59
60 #include "rna_internal.h"
61
62 /* Include for Bake Options */
63 #include "RE_engine.h"
64 #include "RE_pipeline.h"
65
66 #ifdef WITH_QUICKTIME
67 #  include "quicktime_export.h"
68 #  include AUD_TYPES_H
69 #endif
70
71 #ifdef WITH_FFMPEG
72 #  include "BKE_writeffmpeg.h"
73 #  include <libavcodec/avcodec.h>
74 #  include <libavformat/avformat.h>
75 #  include "ffmpeg_compat.h"
76 #endif
77
78 #include "ED_render.h"
79
80 #include "WM_api.h"
81 #include "WM_types.h"
82
83 #include "BLI_threads.h"
84
85 #define NO_ENGINE "NO_ENGINE"
86
87 #ifdef WITH_OPENEXR
88 EnumPropertyItem rna_enum_exr_codec_items[] = {
89         {R_IMF_EXR_CODEC_NONE, "NONE", 0, "None", ""},
90         {R_IMF_EXR_CODEC_PXR24, "PXR24", 0, "Pxr24 (lossy)", ""},
91         {R_IMF_EXR_CODEC_ZIP, "ZIP", 0, "ZIP (lossless)", ""},
92         {R_IMF_EXR_CODEC_PIZ, "PIZ", 0, "PIZ (lossless)", ""},
93         {R_IMF_EXR_CODEC_RLE, "RLE", 0, "RLE (lossless)", ""},
94         {R_IMF_EXR_CODEC_ZIPS, "ZIPS", 0, "ZIPS (lossless)", ""},
95         {R_IMF_EXR_CODEC_B44, "B44", 0, "B44 (lossy)", ""},
96         {R_IMF_EXR_CODEC_B44A, "B44A", 0, "B44A (lossy)", ""},
97         {R_IMF_EXR_CODEC_DWAA, "DWAA", 0, "DWAA (lossy)", ""},
98         {R_IMF_EXR_CODEC_DWAB, "DWAB", 0, "DWAB (lossy)", ""},
99         {0, NULL, 0, NULL, NULL}
100 };
101 #endif
102
103 EnumPropertyItem uv_sculpt_relaxation_items[] = {
104         {UV_SCULPT_TOOL_RELAX_LAPLACIAN, "LAPLACIAN", 0, "Laplacian", "Use Laplacian method for relaxation"},
105         {UV_SCULPT_TOOL_RELAX_HC, "HC", 0, "HC", "Use HC method for relaxation"},
106         {0, NULL, 0, NULL, NULL}
107 };
108
109 EnumPropertyItem uv_sculpt_tool_items[] = {
110         {UV_SCULPT_TOOL_PINCH, "PINCH", 0, "Pinch", "Pinch UVs"},
111         {UV_SCULPT_TOOL_RELAX, "RELAX", 0, "Relax", "Relax UVs"},
112         {UV_SCULPT_TOOL_GRAB, "GRAB", 0, "Grab", "Grab UVs"},
113         {0, NULL, 0, NULL, NULL}
114 };
115
116
117 EnumPropertyItem rna_enum_snap_target_items[] = {
118         {SCE_SNAP_TARGET_CLOSEST, "CLOSEST", 0, "Closest", "Snap closest point onto target"},
119         {SCE_SNAP_TARGET_CENTER, "CENTER", 0, "Center", "Snap center onto target"},
120         {SCE_SNAP_TARGET_MEDIAN, "MEDIAN", 0, "Median", "Snap median onto target"},
121         {SCE_SNAP_TARGET_ACTIVE, "ACTIVE", 0, "Active", "Snap active onto target"},
122         {0, NULL, 0, NULL, NULL}
123 };
124         
125 EnumPropertyItem rna_enum_proportional_falloff_items[] = {
126         {PROP_SMOOTH, "SMOOTH", ICON_SMOOTHCURVE, "Smooth", "Smooth falloff"},
127         {PROP_SPHERE, "SPHERE", ICON_SPHERECURVE, "Sphere", "Spherical falloff"},
128         {PROP_ROOT, "ROOT", ICON_ROOTCURVE, "Root", "Root falloff"},
129         {PROP_INVSQUARE, "INVERSE_SQUARE", ICON_ROOTCURVE, "Inverse Square", "Inverse Square falloff"},
130         {PROP_SHARP, "SHARP", ICON_SHARPCURVE, "Sharp", "Sharp falloff"},
131         {PROP_LIN, "LINEAR", ICON_LINCURVE, "Linear", "Linear falloff"},
132         {PROP_CONST, "CONSTANT", ICON_NOCURVE, "Constant", "Constant falloff"},
133         {PROP_RANDOM, "RANDOM", ICON_RNDCURVE, "Random", "Random falloff"},
134         {0, NULL, 0, NULL, NULL}
135 };
136
137 /* subset of the enum - only curves, missing random and const */
138 EnumPropertyItem rna_enum_proportional_falloff_curve_only_items[] = {
139         {PROP_SMOOTH, "SMOOTH", ICON_SMOOTHCURVE, "Smooth", "Smooth falloff"},
140         {PROP_SPHERE, "SPHERE", ICON_SPHERECURVE, "Sphere", "Spherical falloff"},
141         {PROP_ROOT, "ROOT", ICON_ROOTCURVE, "Root", "Root falloff"},
142         {PROP_INVSQUARE, "INVERSE_SQUARE", ICON_ROOTCURVE, "Inverse Square", "Inverse Square falloff"},
143         {PROP_SHARP, "SHARP", ICON_SHARPCURVE, "Sharp", "Sharp falloff"},
144         {PROP_LIN, "LINEAR", ICON_LINCURVE, "Linear", "Linear falloff"},
145         {0, NULL, 0, NULL, NULL}
146 };
147
148
149 EnumPropertyItem rna_enum_proportional_editing_items[] = {
150         {PROP_EDIT_OFF, "DISABLED", ICON_PROP_OFF, "Disable", "Proportional Editing disabled"},
151         {PROP_EDIT_ON, "ENABLED", ICON_PROP_ON, "Enable", "Proportional Editing enabled"},
152         {PROP_EDIT_PROJECTED, "PROJECTED", ICON_PROP_ON, "Projected (2D)",
153                               "Proportional Editing using screen space locations"},
154         {PROP_EDIT_CONNECTED, "CONNECTED", ICON_PROP_CON, "Connected",
155                               "Proportional Editing using connected geometry only"},
156         {0, NULL, 0, NULL, NULL}
157 };
158
159 /* keep for operators, not used here */
160 EnumPropertyItem rna_enum_mesh_select_mode_items[] = {
161         {SCE_SELECT_VERTEX, "VERTEX", ICON_VERTEXSEL, "Vertex", "Vertex selection mode"},
162         {SCE_SELECT_EDGE, "EDGE", ICON_EDGESEL, "Edge", "Edge selection mode"},
163         {SCE_SELECT_FACE, "FACE", ICON_FACESEL, "Face", "Face selection mode"},
164         {0, NULL, 0, NULL, NULL}
165 };
166
167 EnumPropertyItem rna_enum_snap_element_items[] = {
168         {SCE_SNAP_MODE_INCREMENT, "INCREMENT", ICON_SNAP_INCREMENT, "Increment", "Snap to increments of grid"},
169         {SCE_SNAP_MODE_VERTEX, "VERTEX", ICON_SNAP_VERTEX, "Vertex", "Snap to vertices"},
170         {SCE_SNAP_MODE_EDGE, "EDGE", ICON_SNAP_EDGE, "Edge", "Snap to edges"},
171         {SCE_SNAP_MODE_FACE, "FACE", ICON_SNAP_FACE, "Face", "Snap to faces"},
172         {SCE_SNAP_MODE_VOLUME, "VOLUME", ICON_SNAP_VOLUME, "Volume", "Snap to volume"},
173         {0, NULL, 0, NULL, NULL}
174 };
175
176 EnumPropertyItem rna_enum_snap_node_element_items[] = {
177         {SCE_SNAP_MODE_GRID, "GRID", ICON_SNAP_GRID, "Grid", "Snap to grid"},
178         {SCE_SNAP_MODE_NODE_X, "NODE_X", ICON_SNAP_EDGE, "Node X", "Snap to left/right node border"},
179         {SCE_SNAP_MODE_NODE_Y, "NODE_Y", ICON_SNAP_EDGE, "Node Y", "Snap to top/bottom node border"},
180         {SCE_SNAP_MODE_NODE_XY, "NODE_XY", ICON_SNAP_EDGE, "Node X / Y", "Snap to any node border"},
181         {0, NULL, 0, NULL, NULL}
182 };
183
184 EnumPropertyItem snap_uv_element_items[] = {
185         {SCE_SNAP_MODE_INCREMENT, "INCREMENT", ICON_SNAP_INCREMENT, "Increment", "Snap to increments of grid"},
186         {SCE_SNAP_MODE_VERTEX, "VERTEX", ICON_SNAP_VERTEX, "Vertex", "Snap to vertices"},
187         {0, NULL, 0, NULL, NULL}
188 };
189
190 EnumPropertyItem rna_enum_curve_fit_method_items[] = {
191         {CURVE_PAINT_FIT_METHOD_REFIT, "REFIT", 0, "Refit", "Incrementally re-fit the curve (high quality)"},
192         {CURVE_PAINT_FIT_METHOD_SPLIT, "SPLIT", 0, "Split", "Split the curve until the tolerance is met (fast)"},
193         {0, NULL, 0, NULL, NULL}};
194
195 /* workaround for duplicate enums,
196  * have each enum line as a define then conditionally set it or not
197  */
198
199 #define R_IMF_ENUM_BMP      {R_IMF_IMTYPE_BMP, "BMP", ICON_FILE_IMAGE, "BMP", "Output image in bitmap format"},
200 #define R_IMF_ENUM_IRIS     {R_IMF_IMTYPE_IRIS, "IRIS", ICON_FILE_IMAGE, "Iris", \
201                                                 "Output image in (old!) SGI IRIS format"},
202 #define R_IMF_ENUM_PNG      {R_IMF_IMTYPE_PNG, "PNG", ICON_FILE_IMAGE, "PNG", "Output image in PNG format"},
203 #define R_IMF_ENUM_JPEG     {R_IMF_IMTYPE_JPEG90, "JPEG", ICON_FILE_IMAGE, "JPEG", "Output image in JPEG format"},
204 #define R_IMF_ENUM_TAGA     {R_IMF_IMTYPE_TARGA, "TARGA", ICON_FILE_IMAGE, "Targa", "Output image in Targa format"},
205 #define R_IMF_ENUM_TAGA_RAW {R_IMF_IMTYPE_RAWTGA, "TARGA_RAW", ICON_FILE_IMAGE, "Targa Raw", \
206                                                   "Output image in uncompressed Targa format"},
207
208 #if 0 /* UNUSED (so far) */
209 #ifdef WITH_DDS
210 #  define R_IMF_ENUM_DDS {R_IMF_IMTYPE_DDS, "DDS", ICON_FILE_IMAGE, "DDS", "Output image in DDS format"},
211 #else
212 #  define R_IMF_ENUM_DDS
213 #endif
214 #endif
215
216 #ifdef WITH_OPENJPEG
217 #  define R_IMF_ENUM_JPEG2K {R_IMF_IMTYPE_JP2, "JPEG2000", ICON_FILE_IMAGE, "JPEG 2000", \
218                                                "Output image in JPEG 2000 format"},
219 #else
220 #  define R_IMF_ENUM_JPEG2K
221 #endif
222
223 #ifdef WITH_CINEON
224 #  define R_IMF_ENUM_CINEON {R_IMF_IMTYPE_CINEON, "CINEON", ICON_FILE_IMAGE, "Cineon", \
225                                                   "Output image in Cineon format"},
226 #  define R_IMF_ENUM_DPX    {R_IMF_IMTYPE_DPX, "DPX", ICON_FILE_IMAGE, "DPX", "Output image in DPX format"},
227 #else
228 #  define R_IMF_ENUM_CINEON
229 #  define R_IMF_ENUM_DPX
230 #endif
231
232 #ifdef WITH_OPENEXR
233 #  define R_IMF_ENUM_EXR_MULTILAYER  {R_IMF_IMTYPE_MULTILAYER, "OPEN_EXR_MULTILAYER", ICON_FILE_IMAGE, \
234                                                           "OpenEXR MultiLayer", \
235                                                           "Output image in multilayer OpenEXR format"},
236 #  define R_IMF_ENUM_EXR        {R_IMF_IMTYPE_OPENEXR, "OPEN_EXR", ICON_FILE_IMAGE, "OpenEXR", \
237                                                        "Output image in OpenEXR format"},
238 #else
239 #  define R_IMF_ENUM_EXR_MULTILAYER
240 #  define R_IMF_ENUM_EXR
241 #endif
242
243 #ifdef WITH_HDR
244 #  define R_IMF_ENUM_HDR  {R_IMF_IMTYPE_RADHDR, "HDR", ICON_FILE_IMAGE, "Radiance HDR", \
245                                                 "Output image in Radiance HDR format"},
246 #else
247 #  define R_IMF_ENUM_HDR
248 #endif
249
250 #ifdef WITH_TIFF
251 #  define R_IMF_ENUM_TIFF {R_IMF_IMTYPE_TIFF, "TIFF", ICON_FILE_IMAGE, "TIFF", "Output image in TIFF format"},
252 #else
253 #  define R_IMF_ENUM_TIFF
254 #endif
255
256 #define IMAGE_TYPE_ITEMS_IMAGE_ONLY                                           \
257         R_IMF_ENUM_BMP                                                            \
258         /* DDS save not supported yet R_IMF_ENUM_DDS */                           \
259         R_IMF_ENUM_IRIS                                                           \
260         R_IMF_ENUM_PNG                                                            \
261         R_IMF_ENUM_JPEG                                                           \
262         R_IMF_ENUM_JPEG2K                                                         \
263         R_IMF_ENUM_TAGA                                                           \
264         R_IMF_ENUM_TAGA_RAW                                                       \
265         {0, "", 0, " ", NULL},                                                    \
266         R_IMF_ENUM_CINEON                                                         \
267         R_IMF_ENUM_DPX                                                            \
268         R_IMF_ENUM_EXR_MULTILAYER                                                 \
269         R_IMF_ENUM_EXR                                                            \
270         R_IMF_ENUM_HDR                                                            \
271         R_IMF_ENUM_TIFF                                                           \
272
273
274 EnumPropertyItem image_only_type_items[] = {
275
276         IMAGE_TYPE_ITEMS_IMAGE_ONLY
277
278         {0, NULL, 0, NULL, NULL}
279 };
280
281 EnumPropertyItem rna_enum_image_type_items[] = {
282         {0, "", 0, N_("Image"), NULL},
283
284         IMAGE_TYPE_ITEMS_IMAGE_ONLY
285
286         {0, "", 0, N_("Movie"), NULL},
287         {R_IMF_IMTYPE_AVIJPEG, "AVI_JPEG", ICON_FILE_MOVIE, "AVI JPEG", "Output video in AVI JPEG format"},
288         {R_IMF_IMTYPE_AVIRAW, "AVI_RAW", ICON_FILE_MOVIE, "AVI Raw", "Output video in AVI Raw format"},
289 #ifdef WITH_FRAMESERVER
290         {R_IMF_IMTYPE_FRAMESERVER, "FRAMESERVER", ICON_FILE_SCRIPT, "Frame Server", "Output image to a frameserver"},
291 #endif
292 #ifdef WITH_FFMPEG
293         {R_IMF_IMTYPE_FFMPEG, "FFMPEG", ICON_FILE_MOVIE, "FFmpeg video", "The most versatile way to output video files"},
294 #endif
295 #ifdef WITH_QUICKTIME
296         {R_IMF_IMTYPE_QUICKTIME, "QUICKTIME", ICON_FILE_MOVIE, "QuickTime", "Output video in Quicktime format"},
297 #endif
298         {0, NULL, 0, NULL, NULL}
299 };
300
301 EnumPropertyItem rna_enum_image_color_mode_items[] = {
302         {R_IMF_PLANES_BW, "BW", 0, "BW", "Images get saved in 8 bits grayscale (only PNG, JPEG, TGA, TIF)"},
303         {R_IMF_PLANES_RGB, "RGB", 0, "RGB", "Images are saved with RGB (color) data"},
304         {R_IMF_PLANES_RGBA, "RGBA", 0, "RGBA", "Images are saved with RGB and Alpha data (if supported)"},
305         {0, NULL, 0, NULL, NULL}
306 };
307
308 #ifdef RNA_RUNTIME
309 #define IMAGE_COLOR_MODE_BW   rna_enum_image_color_mode_items[0]
310 #define IMAGE_COLOR_MODE_RGB  rna_enum_image_color_mode_items[1]
311 #define IMAGE_COLOR_MODE_RGBA rna_enum_image_color_mode_items[2]
312 #endif
313
314 EnumPropertyItem rna_enum_image_color_depth_items[] = {
315         /* 1 (monochrome) not used */
316         {R_IMF_CHAN_DEPTH_8,   "8", 0, "8",  "8 bit color channels"},
317         {R_IMF_CHAN_DEPTH_10, "10", 0, "10", "10 bit color channels"},
318         {R_IMF_CHAN_DEPTH_12, "12", 0, "12", "12 bit color channels"},
319         {R_IMF_CHAN_DEPTH_16, "16", 0, "16", "16 bit color channels"},
320         /* 24 not used */
321         {R_IMF_CHAN_DEPTH_32, "32", 0, "32", "32 bit color channels"},
322         {0, NULL, 0, NULL, NULL}
323 };
324
325 EnumPropertyItem rna_enum_normal_space_items[] = {
326         {R_BAKE_SPACE_OBJECT, "OBJECT", 0, "Object", "Bake the normals in object space"},
327         {R_BAKE_SPACE_TANGENT, "TANGENT", 0, "Tangent", "Bake the normals in tangent space"},
328         {0, NULL, 0, NULL, NULL}
329 };
330
331 EnumPropertyItem rna_enum_normal_swizzle_items[] = {
332         {R_BAKE_POSX, "POS_X", 0, "+X", ""},
333         {R_BAKE_POSY, "POS_Y", 0, "+Y", ""},
334         {R_BAKE_POSZ, "POS_Z", 0, "+Z", ""},
335         {R_BAKE_NEGX, "NEG_X", 0, "-X", ""},
336         {R_BAKE_NEGY, "NEG_Y", 0, "-Y", ""},
337         {R_BAKE_NEGZ, "NEG_Z", 0, "-Z", ""},
338         {0, NULL, 0, NULL, NULL}
339 };
340
341 EnumPropertyItem rna_enum_bake_save_mode_items[] = {
342         {R_BAKE_SAVE_INTERNAL, "INTERNAL", 0, "Internal", "Save the baking map in an internal image data-block"},
343         {R_BAKE_SAVE_EXTERNAL, "EXTERNAL", 0, "External", "Save the baking map in an external file"},
344         {0, NULL, 0, NULL, NULL}
345 };
346
347 #define R_IMF_VIEWS_ENUM_IND      {R_IMF_VIEWS_INDIVIDUAL, "INDIVIDUAL", 0, "Individual", \
348                                    "Individual files for each view with the prefix as defined by the scene views"},
349 #define R_IMF_VIEWS_ENUM_S3D      {R_IMF_VIEWS_STEREO_3D, "STEREO_3D", 0, "Stereo 3D", \
350                                    "Single file with an encoded stereo pair"},
351 #define R_IMF_VIEWS_ENUM_MV       {R_IMF_VIEWS_MULTIVIEW, "MULTIVIEW", 0, "Multi-View", "Single file with all the views"},
352
353 EnumPropertyItem rna_enum_views_format_items[] = {
354         R_IMF_VIEWS_ENUM_IND
355         R_IMF_VIEWS_ENUM_S3D
356         {0, NULL, 0, NULL, NULL}
357 };
358
359 EnumPropertyItem rna_enum_views_format_multilayer_items[] = {
360         R_IMF_VIEWS_ENUM_IND
361         R_IMF_VIEWS_ENUM_MV
362         {0, NULL, 0, NULL, NULL}
363 };
364
365 EnumPropertyItem rna_enum_views_format_multiview_items[] = {
366         R_IMF_VIEWS_ENUM_IND
367         R_IMF_VIEWS_ENUM_S3D
368         R_IMF_VIEWS_ENUM_MV
369         {0, NULL, 0, NULL, NULL}
370 };
371
372 #undef R_IMF_VIEWS_ENUM_IND
373 #undef R_IMF_VIEWS_ENUM_S3D
374 #undef R_IMF_VIEWS_ENUM_MV
375
376 EnumPropertyItem rna_enum_stereo3d_display_items[] = {
377         {S3D_DISPLAY_ANAGLYPH, "ANAGLYPH", 0, "Anaglyph",
378          "Render views for left and right eyes as two differently filtered colors in a single image "
379          "(anaglyph glasses are required)"},
380         {S3D_DISPLAY_INTERLACE, "INTERLACE", 0, "Interlace",
381          "Render views for left and right eyes interlaced in a single image (3D-ready monitor is required)"},
382         {S3D_DISPLAY_PAGEFLIP, "TIMESEQUENTIAL", 0, "Time Sequential",
383          "Render alternate eyes (also known as page flip, quad buffer support in the graphic card is required)"},
384         {S3D_DISPLAY_SIDEBYSIDE, "SIDEBYSIDE", 0, "Side-by-Side", "Render views for left and right eyes side-by-side"},
385         {S3D_DISPLAY_TOPBOTTOM, "TOPBOTTOM", 0, "Top-Bottom", "Render views for left and right eyes one above another"},
386         {0, NULL, 0, NULL, NULL}
387 };
388
389 EnumPropertyItem rna_enum_stereo3d_anaglyph_type_items[] = {
390         {S3D_ANAGLYPH_REDCYAN, "RED_CYAN", 0, "Red-Cyan", ""},
391         {S3D_ANAGLYPH_GREENMAGENTA, "GREEN_MAGENTA", 0, "Green-Magenta", ""},
392         {S3D_ANAGLYPH_YELLOWBLUE, "YELLOW_BLUE", 0, "Yellow-Blue", ""},
393         {0, NULL, 0, NULL, NULL}
394 };
395
396 EnumPropertyItem rna_enum_stereo3d_interlace_type_items[] = {
397         {S3D_INTERLACE_ROW, "ROW_INTERLEAVED", 0, "Row Interleaved", ""},
398         {S3D_INTERLACE_COLUMN, "COLUMN_INTERLEAVED", 0, "Column Interleaved", ""},
399         {S3D_INTERLACE_CHECKERBOARD, "CHECKERBOARD_INTERLEAVED", 0, "Checkerboard Interleaved", ""},
400         {0, NULL, 0, NULL, NULL}
401 };
402
403 EnumPropertyItem rna_enum_bake_pass_filter_type_items[] = {
404         {R_BAKE_PASS_FILTER_NONE, "NONE", 0, "None", ""},
405         {R_BAKE_PASS_FILTER_AO, "AO", 0, "AO", ""},
406         {R_BAKE_PASS_FILTER_EMIT, "EMIT", 0, "Emit", ""},
407         {R_BAKE_PASS_FILTER_DIRECT, "DIRECT", 0, "Direct", ""},
408         {R_BAKE_PASS_FILTER_INDIRECT, "INDIRECT", 0, "Indirect", ""},
409         {R_BAKE_PASS_FILTER_COLOR, "COLOR", 0, "Color", ""},
410         {R_BAKE_PASS_FILTER_DIFFUSE, "DIFFUSE", 0, "Diffuse", ""},
411         {R_BAKE_PASS_FILTER_GLOSSY, "GLOSSY", 0, "Glossy", ""},
412         {R_BAKE_PASS_FILTER_TRANSM, "TRANSMISSION", 0, "Transmission", ""},
413         {R_BAKE_PASS_FILTER_SUBSURFACE, "SUBSURFACE", 0, "Subsurface", ""},
414         {0, NULL, 0, NULL, NULL}
415 };
416
417 EnumPropertyItem rna_enum_gpencil_interpolation_mode_items[] = {
418         /* interpolation */
419         {0, "", 0, N_("Interpolation"), "Standard transitions between keyframes"},
420         {GP_IPO_LINEAR,   "LINEAR", ICON_IPO_LINEAR, "Linear", "Straight-line interpolation between A and B (i.e. no ease in/out)"},
421         {GP_IPO_CURVEMAP, "CUSTOM", ICON_IPO_BEZIER, "Custom", "Custom interpolation defined using a curvemap"},
422         
423         /* easing */
424         {0, "", 0, N_("Easing (by strength)"), "Predefined inertial transitions, useful for motion graphics (from least to most ''dramatic'')"},
425         {GP_IPO_SINE, "SINE", ICON_IPO_SINE, "Sinusoidal", "Sinusoidal easing (weakest, almost linear but with a slight curvature)"},
426         {GP_IPO_QUAD, "QUAD", ICON_IPO_QUAD, "Quadratic", "Quadratic easing"},
427         {GP_IPO_CUBIC, "CUBIC", ICON_IPO_CUBIC, "Cubic", "Cubic easing"},
428         {GP_IPO_QUART, "QUART", ICON_IPO_QUART, "Quartic", "Quartic easing"},
429         {GP_IPO_QUINT, "QUINT", ICON_IPO_QUINT, "Quintic", "Quintic easing"},
430         {GP_IPO_EXPO, "EXPO", ICON_IPO_EXPO, "Exponential", "Exponential easing (dramatic)"},
431         {GP_IPO_CIRC, "CIRC", ICON_IPO_CIRC, "Circular", "Circular easing (strongest and most dynamic)"},
432         
433         {0, "", 0, N_("Dynamic Effects"), "Simple physics-inspired easing effects"},
434         {GP_IPO_BACK, "BACK", ICON_IPO_BACK, "Back", "Cubic easing with overshoot and settle"},
435         {GP_IPO_BOUNCE, "BOUNCE", ICON_IPO_BOUNCE, "Bounce", "Exponentially decaying parabolic bounce, like when objects collide"},
436         {GP_IPO_ELASTIC, "ELASTIC", ICON_IPO_ELASTIC, "Elastic", "Exponentially decaying sine wave, like an elastic band"},
437         
438         {0, NULL, 0, NULL, NULL}
439 };
440
441 #ifdef RNA_RUNTIME
442
443 #include "DNA_anim_types.h"
444 #include "DNA_color_types.h"
445 #include "DNA_node_types.h"
446 #include "DNA_object_types.h"
447 #include "DNA_mesh_types.h"
448 #include "DNA_text_types.h"
449
450 #include "RNA_access.h"
451
452 #include "MEM_guardedalloc.h"
453
454 #include "BKE_brush.h"
455 #include "BKE_collection.h"
456 #include "BKE_colortools.h"
457 #include "BKE_context.h"
458 #include "BKE_global.h"
459 #include "BKE_image.h"
460 #include "BKE_layer.h"
461 #include "BKE_main.h"
462 #include "BKE_node.h"
463 #include "BKE_pointcache.h"
464 #include "BKE_scene.h"
465 #include "BKE_depsgraph.h"
466 #include "BKE_mesh.h"
467 #include "BKE_sound.h"
468 #include "BKE_screen.h"
469 #include "BKE_sequencer.h"
470 #include "BKE_animsys.h"
471 #include "BKE_freestyle.h"
472 #include "BKE_gpencil.h"
473
474 #include "ED_info.h"
475 #include "ED_node.h"
476 #include "ED_view3d.h"
477 #include "ED_mesh.h"
478 #include "ED_keyframing.h"
479 #include "ED_image.h"
480
481 #ifdef WITH_FREESTYLE
482 #include "FRS_freestyle.h"
483 #endif
484
485 /* Grease Pencil Interpolation settings */
486 static char *rna_GPencilInterpolateSettings_path(PointerRNA *UNUSED(ptr))
487 {
488         return BLI_strdup("tool_settings.gpencil_interpolate");
489 }
490
491 static void rna_GPencilInterpolateSettings_type_set(PointerRNA *ptr, int value)
492 {
493         GP_Interpolate_Settings *settings = (GP_Interpolate_Settings *)ptr->data;
494         
495         /* NOTE: This cast should be fine, as we have a small + finite set of values (eGP_Interpolate_Type)
496          * that should fit well within a char
497          */
498         settings->type = (char)value;
499         
500         /* init custom interpolation curve here now the first time it's used */
501         if ((settings->type == GP_IPO_CURVEMAP) &&
502             (settings->custom_ipo == NULL))
503         {
504                 settings->custom_ipo = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
505         }
506 }
507
508 /* Grease pencil Drawing Brushes */
509 static bGPDbrush *rna_GPencil_brush_new(ToolSettings *ts, const char *name, int setactive)
510 {
511         bGPDbrush *brush = BKE_gpencil_brush_addnew(ts, name, setactive != 0);
512
513         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
514
515         return brush;
516 }
517
518 static void rna_GPencil_brush_remove(ToolSettings *ts, ReportList *reports, PointerRNA *brush_ptr)
519 {
520         bGPDbrush *brush = brush_ptr->data;
521         if (BLI_findindex(&ts->gp_brushes, brush) == -1) {
522                 BKE_report(reports, RPT_ERROR, "Brush not found in grease pencil data");
523                 return;
524         }
525
526         BKE_gpencil_brush_delete(ts, brush);
527         RNA_POINTER_INVALIDATE(brush_ptr);
528
529         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
530 }
531
532 static PointerRNA rna_GPencilBrushes_active_get(PointerRNA *ptr)
533 {
534         ToolSettings *ts = (ToolSettings *) ptr->data;
535
536         bGPDbrush *brush;
537
538         for (brush = ts->gp_brushes.first; brush; brush = brush->next) {
539                 if (brush->flag & GP_BRUSH_ACTIVE) {
540                         break;
541                 }
542         }
543
544         if (brush) {
545                 return rna_pointer_inherit_refine(ptr, &RNA_GPencilBrush, brush);
546         }
547
548         return rna_pointer_inherit_refine(ptr, NULL, NULL);
549 }
550
551 static void rna_GPencilBrushes_active_set(PointerRNA *ptr, PointerRNA value)
552 {
553         ToolSettings *ts = (ToolSettings *) ptr->data;
554
555         bGPDbrush *brush;
556
557         for (brush = ts->gp_brushes.first; brush; brush = brush->next) {
558                 if (brush == value.data) {
559                         brush->flag |= GP_BRUSH_ACTIVE;
560                 }
561                 else {
562                         brush->flag &= ~GP_BRUSH_ACTIVE;
563                 }
564         }
565         WM_main_add_notifier(NC_GPENCIL | NA_EDITED, NULL);
566 }
567
568 static int rna_GPencilBrushes_index_get(PointerRNA *ptr)
569 {
570         ToolSettings *ts = (ToolSettings *) ptr->data;
571         bGPDbrush *brush = BKE_gpencil_brush_getactive(ts);
572
573         return BLI_findindex(&ts->gp_brushes, brush);
574 }
575
576 static void rna_GPencilBrushes_index_set(PointerRNA *ptr, int value)
577 {
578         ToolSettings *ts = (ToolSettings *) ptr->data;
579
580         bGPDbrush *brush = BLI_findlink(&ts->gp_brushes, value);
581
582         BKE_gpencil_brush_setactive(ts, brush);
583         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
584 }
585
586 static void rna_GPencilBrushes_index_range(PointerRNA *ptr, int *min, int *max, int *softmin, int *softmax)
587 {
588         ToolSettings *ts = (ToolSettings *) ptr->data;
589
590         *min = 0;
591         *max = max_ii(0, BLI_listbase_count(&ts->gp_brushes) - 1);
592
593         *softmin = *min;
594         *softmax = *max;
595 }
596
597 static void rna_GPencilBrush_name_set(PointerRNA *ptr, const char *value)
598 {
599         ToolSettings *ts = ((Scene *) ptr->id.data)->toolsettings;
600         bGPDbrush *brush = ptr->data;
601
602         /* copy the new name into the name slot */
603         BLI_strncpy_utf8(brush->info, value, sizeof(brush->info));
604
605         BLI_uniquename(&ts->gp_brushes, brush, DATA_("GP_Brush"), '.', offsetof(bGPDbrush, info), sizeof(brush->info));
606 }
607
608 /* ----------------- end of Grease pencil drawing brushes ------------*/
609
610 static void rna_SpaceImageEditor_uv_sculpt_update(Main *bmain, Scene *scene, PointerRNA *UNUSED(ptr))
611 {
612         ED_space_image_uv_sculpt_update(bmain->wm.first, scene);
613 }
614
615 static int rna_Scene_object_bases_lookup_string(PointerRNA *ptr, const char *key, PointerRNA *r_ptr)
616 {
617         Scene *scene = (Scene *)ptr->data;
618         Base *base;
619
620         for (base = scene->base.first; base; base = base->next) {
621                 if (STREQLEN(base->object->id.name + 2, key, sizeof(base->object->id.name) - 2)) {
622                         *r_ptr = rna_pointer_inherit_refine(ptr, &RNA_ObjectBaseLegacy, base);
623                         return true;
624                 }
625         }
626
627         return false;
628 }
629
630 static PointerRNA rna_Scene_objects_get(CollectionPropertyIterator *iter)
631 {
632         ListBaseIterator *internal = &iter->internal.listbase;
633
634         /* we are actually iterating a Base list, so override get */
635         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, ((Base *)internal->link)->object);
636 }
637
638 static Base *rna_Scene_object_link(Scene *scene, bContext *C, ReportList *reports, Object *ob)
639 {
640         Scene *scene_act = CTX_data_scene(C);
641         Base *base;
642
643         if (BKE_scene_base_find(scene, ob)) {
644                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is already in scene '%s'", ob->id.name + 2, scene->id.name + 2);
645                 return NULL;
646         }
647
648         base = BKE_scene_base_add(scene, ob);
649         id_us_plus(&ob->id);
650
651         /* this is similar to what object_add_type and BKE_object_add do */
652         base->lay = scene->lay;
653
654         /* when linking to an inactive scene don't touch the layer */
655         if (scene == scene_act)
656                 ob->lay = base->lay;
657
658         /* TODO(sergey): Only update relations for the current scene. */
659         DAG_relations_tag_update(CTX_data_main(C));
660         DAG_id_tag_update(&ob->id, OB_RECALC_OB | OB_RECALC_DATA | OB_RECALC_TIME);
661
662         /* slows down importers too much, run scene.update() */
663         /* DAG_srelations_tag_update(G.main); */
664
665         WM_main_add_notifier(NC_SCENE | ND_OB_ACTIVE, scene);
666
667         return base;
668 }
669
670 static void rna_Scene_object_unlink(Scene *scene, ReportList *reports, Object *ob)
671 {
672         Base *base = BKE_scene_base_find(scene, ob);
673         if (!base) {
674                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is not in this scene '%s'", ob->id.name + 2, scene->id.name + 2);
675                 return;
676         }
677         if (base == scene->basact && ob->mode != OB_MODE_OBJECT) {
678                 BKE_reportf(reports, RPT_ERROR, "Object '%s' must be in object mode to unlink", ob->id.name + 2);
679                 return;
680         }
681         if (scene->basact == base) {
682                 scene->basact = NULL;
683         }
684
685         BKE_scene_base_unlink(scene, base);
686         MEM_freeN(base);
687
688         id_us_min(&ob->id);
689
690         /* needed otherwise the depgraph will contain freed objects which can crash, see [#20958] */
691         DAG_relations_tag_update(G.main);
692
693         WM_main_add_notifier(NC_SCENE | ND_OB_ACTIVE, scene);
694 }
695
696 static void rna_Scene_skgen_etch_template_set(PointerRNA *ptr, PointerRNA value)
697 {
698         ToolSettings *ts = (ToolSettings *)ptr->data;
699         if (value.data && ((Object *)value.data)->type == OB_ARMATURE)
700                 ts->skgen_template = value.data;
701         else
702                 ts->skgen_template = NULL;
703 }
704
705 static PointerRNA rna_Scene_active_object_get(PointerRNA *ptr)
706 {
707         Scene *scene = (Scene *)ptr->data;
708         return rna_pointer_inherit_refine(ptr, &RNA_Object, scene->basact ? scene->basact->object : NULL);
709 }
710
711 static void rna_Scene_active_object_set(PointerRNA *ptr, PointerRNA value)
712 {
713         Scene *scene = (Scene *)ptr->data;
714         if (value.data)
715                 scene->basact = BKE_scene_base_find(scene, (Object *)value.data);
716         else
717                 scene->basact = NULL;
718 }
719
720 static void rna_Scene_set_set(PointerRNA *ptr, PointerRNA value)
721 {
722         Scene *scene = (Scene *)ptr->data;
723         Scene *set = (Scene *)value.data;
724         Scene *nested_set;
725
726         for (nested_set = set; nested_set; nested_set = nested_set->set) {
727                 if (nested_set == scene)
728                         return;
729                 /* prevent eternal loops, set can point to next, and next to set, without problems usually */
730                 if (nested_set->set == set)
731                         return;
732         }
733
734         id_lib_extern((ID *)set);
735         scene->set = set;
736 }
737
738 static void rna_Scene_layer_set(PointerRNA *ptr, const int *values)
739 {
740         Scene *scene = (Scene *)ptr->data;
741
742         scene->lay = ED_view3d_scene_layer_set(scene->lay, values, &scene->layact);
743 }
744
745 static int rna_Scene_active_layer_get(PointerRNA *ptr)
746 {
747         Scene *scene = (Scene *)ptr->data;
748
749         return (int)(log(scene->layact) / M_LN2);
750 }
751
752 static void rna_Scene_view3d_update(Main *bmain, Scene *UNUSED(scene_unused), PointerRNA *ptr)
753 {
754         Scene *scene = (Scene *)ptr->data;
755
756         BKE_screen_view3d_main_sync(&bmain->screen, scene);
757 }
758
759 static void rna_Scene_layer_update(Main *bmain, Scene *scene, PointerRNA *ptr)
760 {
761         rna_Scene_view3d_update(bmain, scene, ptr);
762         /* XXX We would need do_time=true here, else we can have update issues like [#36289]...
763          *     However, this has too much drawbacks (like slower layer switch, undesired updates...).
764          *     That's TODO for future DAG updates.
765          */
766         DAG_on_visible_update(bmain, false);
767 }
768
769 static void rna_Scene_fps_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
770 {
771         BKE_sound_update_fps(scene);
772         BKE_sequencer_update_sound_bounds_all(scene);
773 }
774
775 static void rna_Scene_listener_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
776 {
777         BKE_sound_update_scene_listener(scene);
778 }
779
780 static void rna_Scene_volume_set(PointerRNA *ptr, float value)
781 {
782         Scene *scene = (Scene *)(ptr->data);
783
784         scene->audio.volume = value;
785         if (scene->sound_scene)
786                 BKE_sound_set_scene_volume(scene, value);
787 }
788
789 static void rna_Scene_framelen_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
790 {
791         scene->r.framelen = (float)scene->r.framapto / (float)scene->r.images;
792 }
793
794
795 static void rna_Scene_frame_current_set(PointerRNA *ptr, int value)
796 {
797         Scene *data = (Scene *)ptr->data;
798         
799         /* if negative frames aren't allowed, then we can't use them */
800         FRAMENUMBER_MIN_CLAMP(value);
801         data->r.cfra = value;
802 }
803
804 static float rna_Scene_frame_current_final_get(PointerRNA *ptr)
805 {
806         Scene *scene = (Scene *)ptr->data;
807
808         return BKE_scene_frame_get_from_ctime(scene, (float)scene->r.cfra);
809 }
810
811 static void rna_Scene_start_frame_set(PointerRNA *ptr, int value)
812 {
813         Scene *data = (Scene *)ptr->data;
814         /* MINFRAME not MINAFRAME, since some output formats can't taken negative frames */
815         CLAMP(value, MINFRAME, MAXFRAME);
816         data->r.sfra = value;
817
818         if (data->r.sfra >= data->r.efra) {
819                 data->r.efra = MIN2(data->r.sfra, MAXFRAME);
820         }
821 }
822
823 static void rna_Scene_end_frame_set(PointerRNA *ptr, int value)
824 {
825         Scene *data = (Scene *)ptr->data;
826         CLAMP(value, MINFRAME, MAXFRAME);
827         data->r.efra = value;
828
829         if (data->r.sfra >= data->r.efra) {
830                 data->r.sfra = MAX2(data->r.efra, MINFRAME);
831         }
832 }
833
834 static void rna_Scene_use_preview_range_set(PointerRNA *ptr, int value)
835 {
836         Scene *data = (Scene *)ptr->data;
837         
838         if (value) {
839                 /* copy range from scene if not set before */
840                 if ((data->r.psfra == data->r.pefra) && (data->r.psfra == 0)) {
841                         data->r.psfra = data->r.sfra;
842                         data->r.pefra = data->r.efra;
843                 }
844                 
845                 data->r.flag |= SCER_PRV_RANGE;
846         }
847         else
848                 data->r.flag &= ~SCER_PRV_RANGE;
849 }
850
851
852 static void rna_Scene_preview_range_start_frame_set(PointerRNA *ptr, int value)
853 {
854         Scene *data = (Scene *)ptr->data;
855         
856         /* check if enabled already */
857         if ((data->r.flag & SCER_PRV_RANGE) == 0) {
858                 /* set end of preview range to end frame, then clamp as per normal */
859                 /* TODO: or just refuse to set instead? */
860                 data->r.pefra = data->r.efra;
861         }
862         
863         /* now set normally */
864         CLAMP(value, MINAFRAME, data->r.pefra);
865         data->r.psfra = value;
866 }
867
868 static void rna_Scene_preview_range_end_frame_set(PointerRNA *ptr, int value)
869 {
870         Scene *data = (Scene *)ptr->data;
871         
872         /* check if enabled already */
873         if ((data->r.flag & SCER_PRV_RANGE) == 0) {
874                 /* set start of preview range to start frame, then clamp as per normal */
875                 /* TODO: or just refuse to set instead? */
876                 data->r.psfra = data->r.sfra;
877         }
878         
879         /* now set normally */
880         CLAMP(value, data->r.psfra, MAXFRAME);
881         data->r.pefra = value;
882 }
883
884 static void rna_Scene_frame_update(Main *bmain, Scene *UNUSED(current_scene), PointerRNA *ptr)
885 {
886         Scene *scene = (Scene *)ptr->id.data;
887         BKE_sound_seek_scene(bmain, scene);
888 }
889
890 static PointerRNA rna_Scene_active_keying_set_get(PointerRNA *ptr)
891 {
892         Scene *scene = (Scene *)ptr->data;
893         return rna_pointer_inherit_refine(ptr, &RNA_KeyingSet, ANIM_scene_get_active_keyingset(scene));
894 }
895
896 static void rna_Scene_active_keying_set_set(PointerRNA *ptr, PointerRNA value)
897 {
898         Scene *scene = (Scene *)ptr->data;
899         KeyingSet *ks = (KeyingSet *)value.data;
900         
901         scene->active_keyingset = ANIM_scene_get_keyingset_index(scene, ks);
902 }
903
904 /* get KeyingSet index stuff for list of Keying Sets editing UI
905  *      - active_keyingset-1 since 0 is reserved for 'none'
906  *      - don't clamp, otherwise can never set builtins types as active...
907  */
908 static int rna_Scene_active_keying_set_index_get(PointerRNA *ptr)
909 {
910         Scene *scene = (Scene *)ptr->data;
911         return scene->active_keyingset - 1;
912 }
913
914 /* get KeyingSet index stuff for list of Keying Sets editing UI
915  *      - value+1 since 0 is reserved for 'none'
916  */
917 static void rna_Scene_active_keying_set_index_set(PointerRNA *ptr, int value)
918 {
919         Scene *scene = (Scene *)ptr->data;
920         scene->active_keyingset = value + 1;
921 }
922
923 /* XXX: evil... builtin_keyingsets is defined in keyingsets.c! */
924 /* TODO: make API function to retrieve this... */
925 extern ListBase builtin_keyingsets;
926
927 static void rna_Scene_all_keyingsets_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
928 {
929         Scene *scene = (Scene *)ptr->data;
930         
931         /* start going over the scene KeyingSets first, while we still have pointer to it
932          * but only if we have any Keying Sets to use...
933          */
934         if (scene->keyingsets.first)
935                 rna_iterator_listbase_begin(iter, &scene->keyingsets, NULL);
936         else
937                 rna_iterator_listbase_begin(iter, &builtin_keyingsets, NULL);
938 }
939
940 static void rna_Scene_all_keyingsets_next(CollectionPropertyIterator *iter)
941 {
942         ListBaseIterator *internal = &iter->internal.listbase;
943         KeyingSet *ks = (KeyingSet *)internal->link;
944         
945         /* if we've run out of links in Scene list, jump over to the builtins list unless we're there already */
946         if ((ks->next == NULL) && (ks != builtin_keyingsets.last))
947                 internal->link = (Link *)builtin_keyingsets.first;
948         else
949                 internal->link = (Link *)ks->next;
950                 
951         iter->valid = (internal->link != NULL);
952 }
953
954 static int rna_RenderSettings_stereoViews_skip(CollectionPropertyIterator *iter, void *UNUSED(data))
955 {
956         ListBaseIterator *internal = &iter->internal.listbase;
957         SceneRenderView *srv = (SceneRenderView *)internal->link;
958
959         if ((STREQ(srv->name, STEREO_LEFT_NAME)) ||
960             (STREQ(srv->name, STEREO_RIGHT_NAME)))
961         {
962                 return 0;
963         }
964
965         return 1;
966 };
967
968 static void rna_RenderSettings_stereoViews_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
969 {
970         RenderData *rd = (RenderData *)ptr->data;
971         rna_iterator_listbase_begin(iter, &rd->views, rna_RenderSettings_stereoViews_skip);
972 }
973
974 static char *rna_RenderSettings_path(PointerRNA *UNUSED(ptr))
975 {
976         return BLI_sprintfN("render");
977 }
978
979 static char *rna_ImageFormatSettings_path(PointerRNA *ptr)
980 {
981         ImageFormatData *imf = (ImageFormatData *)ptr->data;
982         ID *id = ptr->id.data;
983
984         switch (GS(id->name)) {
985                 case ID_SCE:
986                 {
987                         Scene *scene = (Scene *)id;
988
989                         if (&scene->r.im_format == imf) {
990                                 return BLI_sprintfN("render.image_settings");
991                         }
992                         else if (&scene->r.bake.im_format == imf) {
993                                 return BLI_sprintfN("render.bake.image_settings");
994                         }
995                         return BLI_sprintfN("..");
996                 }
997                 case ID_NT:
998                 {
999                         bNodeTree *ntree = (bNodeTree *)id;
1000                         bNode *node;
1001
1002                         for (node = ntree->nodes.first; node; node = node->next) {
1003                                 if (node->type == CMP_NODE_OUTPUT_FILE) {
1004                                         if (&((NodeImageMultiFile *)node->storage)->format == imf) {
1005                                                 return BLI_sprintfN("nodes['%s'].format", node->name);
1006                                         }
1007                                         else {
1008                                                 bNodeSocket *sock;
1009
1010                                                 for (sock = node->inputs.first; sock; sock = sock->next) {
1011                                                         NodeImageMultiFileSocket *sockdata = sock->storage;
1012                                                         if (&sockdata->format == imf) {
1013                                                                 return BLI_sprintfN("nodes['%s'].file_slots['%s'].format", node->name, sockdata->path);
1014                                                         }
1015                                                 }
1016                                         }
1017                                 }
1018                         }
1019                         return BLI_sprintfN("..");
1020                 }
1021                 default:
1022                         return BLI_sprintfN("..");
1023         }
1024 }
1025
1026 static int rna_RenderSettings_threads_get(PointerRNA *ptr)
1027 {
1028         RenderData *rd = (RenderData *)ptr->data;
1029         return BKE_render_num_threads(rd);
1030 }
1031
1032 static int rna_RenderSettings_threads_mode_get(PointerRNA *ptr)
1033 {
1034         RenderData *rd = (RenderData *)ptr->data;
1035         int override = BLI_system_num_threads_override_get();
1036
1037         if (override > 0)
1038                 return R_FIXED_THREADS;
1039         else
1040                 return (rd->mode & R_FIXED_THREADS);
1041 }
1042
1043 static int rna_RenderSettings_is_movie_format_get(PointerRNA *ptr)
1044 {
1045         RenderData *rd = (RenderData *)ptr->data;
1046         return BKE_imtype_is_movie(rd->im_format.imtype);
1047 }
1048
1049 static int rna_RenderSettings_save_buffers_get(PointerRNA *ptr)
1050 {
1051         RenderData *rd = (RenderData *)ptr->data;
1052         Scene *scene = (Scene *)ptr->id.data;
1053         
1054         if (!BKE_scene_use_new_shading_nodes(scene))
1055                 return (rd->scemode & (R_EXR_TILE_FILE | R_FULL_SAMPLE)) != 0;
1056         else 
1057                 return (rd->scemode & R_EXR_TILE_FILE) != 0;
1058 }
1059
1060 static void rna_ImageFormatSettings_file_format_set(PointerRNA *ptr, int value)
1061 {
1062         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1063         ID *id = ptr->id.data;
1064         const bool is_render = (id && GS(id->name) == ID_SCE);
1065         /* see note below on why this is */
1066         const char chan_flag = BKE_imtype_valid_channels(imf->imtype, true) | (is_render ? IMA_CHAN_FLAG_BW : 0);
1067
1068         imf->imtype = value;
1069
1070         /* ensure depth and color settings match */
1071         if ( ((imf->planes == R_IMF_PLANES_BW) &&   !(chan_flag & IMA_CHAN_FLAG_BW)) ||
1072              ((imf->planes == R_IMF_PLANES_RGBA) && !(chan_flag & IMA_CHAN_FLAG_ALPHA)))
1073         {
1074                 imf->planes = R_IMF_PLANES_RGB;
1075         }
1076
1077         /* ensure usable depth */
1078         {
1079                 const int depth_ok = BKE_imtype_valid_depths(imf->imtype);
1080                 if ((imf->depth & depth_ok) == 0) {
1081                         /* set first available depth */
1082                         char depth_ls[] = {R_IMF_CHAN_DEPTH_32,
1083                                            R_IMF_CHAN_DEPTH_24,
1084                                            R_IMF_CHAN_DEPTH_16,
1085                                            R_IMF_CHAN_DEPTH_12,
1086                                            R_IMF_CHAN_DEPTH_10,
1087                                            R_IMF_CHAN_DEPTH_8,
1088                                            R_IMF_CHAN_DEPTH_1,
1089                                            0};
1090                         int i;
1091
1092                         for (i = 0; depth_ls[i]; i++) {
1093                                 if (depth_ok & depth_ls[i]) {
1094                                         imf->depth = depth_ls[i];
1095                                         break;
1096                                 }
1097                         }
1098                 }
1099         }
1100
1101         if (id && GS(id->name) == ID_SCE) {
1102                 Scene *scene = ptr->id.data;
1103                 RenderData *rd = &scene->r;
1104 #ifdef WITH_FFMPEG
1105                 BKE_ffmpeg_image_type_verify(rd, imf);
1106 #endif
1107 #ifdef WITH_QUICKTIME
1108                 quicktime_verify_image_type(rd, imf);
1109 #endif
1110                 (void)rd;
1111         }
1112 }
1113
1114 static EnumPropertyItem *rna_ImageFormatSettings_file_format_itemf(
1115         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
1116 {
1117         ID *id = ptr->id.data;
1118         if (id && GS(id->name) == ID_SCE) {
1119                 return rna_enum_image_type_items;
1120         }
1121         else {
1122                 return image_only_type_items;
1123         }
1124 }
1125
1126 static EnumPropertyItem *rna_ImageFormatSettings_color_mode_itemf(
1127         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1128 {
1129         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1130         ID *id = ptr->id.data;
1131         const bool is_render = (id && GS(id->name) == ID_SCE);
1132
1133         /* note, we need to act differently for render
1134          * where 'BW' will force grayscale even if the output format writes
1135          * as RGBA, this is age old blender convention and not sure how useful
1136          * it really is but keep it for now - campbell */
1137         char chan_flag = BKE_imtype_valid_channels(imf->imtype, true) | (is_render ? IMA_CHAN_FLAG_BW : 0);
1138
1139 #ifdef WITH_FFMPEG
1140         /* a WAY more crappy case than B&W flag: depending on codec, file format MIGHT support
1141          * alpha channel. for example MPEG format with h264 codec can't do alpha channel, but
1142          * the same MPEG format with QTRLE codec can easily handle alpha channel.
1143          * not sure how to deal with such cases in a nicer way (sergey) */
1144         if (is_render) {
1145                 Scene *scene = ptr->id.data;
1146                 RenderData *rd = &scene->r;
1147
1148                 if (BKE_ffmpeg_alpha_channel_is_supported(rd))
1149                         chan_flag |= IMA_CHAN_FLAG_ALPHA;
1150         }
1151 #endif
1152
1153         if (chan_flag == (IMA_CHAN_FLAG_BW | IMA_CHAN_FLAG_RGB | IMA_CHAN_FLAG_ALPHA)) {
1154                 return rna_enum_image_color_mode_items;
1155         }
1156         else {
1157                 int totitem = 0;
1158                 EnumPropertyItem *item = NULL;
1159
1160                 if (chan_flag & IMA_CHAN_FLAG_BW)    RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_BW);
1161                 if (chan_flag & IMA_CHAN_FLAG_RGB)   RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_RGB);
1162                 if (chan_flag & IMA_CHAN_FLAG_ALPHA) RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_RGBA);
1163
1164                 RNA_enum_item_end(&item, &totitem);
1165                 *r_free = true;
1166
1167                 return item;
1168         }
1169 }
1170
1171 static EnumPropertyItem *rna_ImageFormatSettings_color_depth_itemf(
1172         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1173 {
1174         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1175
1176         if (imf == NULL) {
1177                 return rna_enum_image_color_depth_items;
1178         }
1179         else {
1180                 const int depth_ok = BKE_imtype_valid_depths(imf->imtype);
1181                 const int is_float = ELEM(imf->imtype, R_IMF_IMTYPE_RADHDR, R_IMF_IMTYPE_OPENEXR, R_IMF_IMTYPE_MULTILAYER);
1182
1183                 EnumPropertyItem *item_8bit =  &rna_enum_image_color_depth_items[0];
1184                 EnumPropertyItem *item_10bit = &rna_enum_image_color_depth_items[1];
1185                 EnumPropertyItem *item_12bit = &rna_enum_image_color_depth_items[2];
1186                 EnumPropertyItem *item_16bit = &rna_enum_image_color_depth_items[3];
1187                 EnumPropertyItem *item_32bit = &rna_enum_image_color_depth_items[4];
1188
1189                 int totitem = 0;
1190                 EnumPropertyItem *item = NULL;
1191                 EnumPropertyItem tmp = {0, "", 0, "", ""};
1192
1193                 if (depth_ok & R_IMF_CHAN_DEPTH_8) {
1194                         RNA_enum_item_add(&item, &totitem, item_8bit);
1195                 }
1196
1197                 if (depth_ok & R_IMF_CHAN_DEPTH_10) {
1198                         RNA_enum_item_add(&item, &totitem, item_10bit);
1199                 }
1200
1201                 if (depth_ok & R_IMF_CHAN_DEPTH_12) {
1202                         RNA_enum_item_add(&item, &totitem, item_12bit);
1203                 }
1204
1205                 if (depth_ok & R_IMF_CHAN_DEPTH_16) {
1206                         if (is_float) {
1207                                 tmp = *item_16bit;
1208                                 tmp.name = "Float (Half)";
1209                                 RNA_enum_item_add(&item, &totitem, &tmp);
1210                         }
1211                         else {
1212                                 RNA_enum_item_add(&item, &totitem, item_16bit);
1213                         }
1214                 }
1215
1216                 if (depth_ok & R_IMF_CHAN_DEPTH_32) {
1217                         if (is_float) {
1218                                 tmp = *item_32bit;
1219                                 tmp.name = "Float (Full)";
1220                                 RNA_enum_item_add(&item, &totitem, &tmp);
1221                         }
1222                         else {
1223                                 RNA_enum_item_add(&item, &totitem, item_32bit);
1224                         }
1225                 }
1226
1227                 RNA_enum_item_end(&item, &totitem);
1228                 *r_free = true;
1229
1230                 return item;
1231         }
1232 }
1233
1234 static EnumPropertyItem *rna_ImageFormatSettings_views_format_itemf(
1235         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
1236 {
1237         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1238
1239         if (imf == NULL) {
1240                 return rna_enum_views_format_items;
1241         }
1242         else if (imf->imtype == R_IMF_IMTYPE_OPENEXR) {
1243                 return rna_enum_views_format_multiview_items;
1244         }
1245         else if (imf->imtype == R_IMF_IMTYPE_MULTILAYER) {
1246                 return rna_enum_views_format_multilayer_items;
1247         }
1248         else {
1249                 return rna_enum_views_format_items;
1250         }
1251 }
1252
1253 #ifdef WITH_OPENEXR
1254         /* OpenEXR */
1255
1256 static EnumPropertyItem *rna_ImageFormatSettings_exr_codec_itemf(
1257         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1258 {
1259         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1260
1261         EnumPropertyItem *item = NULL;
1262         int i = 1, totitem = 0;
1263
1264         if (imf->depth == 16)
1265                 return rna_enum_exr_codec_items; /* All compression types are defined for halfs */
1266
1267         for (i = 0; i < R_IMF_EXR_CODEC_MAX; i++) {
1268                 if ((i == R_IMF_EXR_CODEC_B44 || i == R_IMF_EXR_CODEC_B44A)) {
1269                         continue; /* B44 and B44A are not defined for 32 bit floats */
1270                 }
1271
1272                 RNA_enum_item_add(&item, &totitem, &rna_enum_exr_codec_items[i]);
1273         }
1274
1275         RNA_enum_item_end(&item, &totitem);
1276         *r_free = true;
1277
1278         return item;
1279 }
1280
1281 #endif
1282 static int rna_SceneRender_file_ext_length(PointerRNA *ptr)
1283 {
1284         RenderData *rd = (RenderData *)ptr->data;
1285         char ext[8];
1286         ext[0] = '\0';
1287         BKE_image_path_ensure_ext_from_imformat(ext, &rd->im_format);
1288         return strlen(ext);
1289 }
1290
1291 static void rna_SceneRender_file_ext_get(PointerRNA *ptr, char *str)
1292 {
1293         RenderData *rd = (RenderData *)ptr->data;
1294         str[0] = '\0';
1295         BKE_image_path_ensure_ext_from_imformat(str, &rd->im_format);
1296 }
1297
1298 #ifdef WITH_QUICKTIME
1299 static int rna_RenderSettings_qtcodecsettings_codecType_get(PointerRNA *ptr)
1300 {
1301         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1302         
1303         return quicktime_rnatmpvalue_from_videocodectype(settings->codecType);
1304 }
1305
1306 static void rna_RenderSettings_qtcodecsettings_codecType_set(PointerRNA *ptr, int value)
1307 {
1308         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1309
1310         settings->codecType = quicktime_videocodecType_from_rnatmpvalue(value);
1311 }
1312
1313 static EnumPropertyItem *rna_RenderSettings_qtcodecsettings_codecType_itemf(
1314         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1315 {
1316         EnumPropertyItem *item = NULL;
1317         EnumPropertyItem tmp = {0, "", 0, "", ""};
1318         QuicktimeCodecTypeDesc *codecTypeDesc;
1319         int i = 1, totitem = 0;
1320
1321         for (i = 0; i < quicktime_get_num_videocodecs(); i++) {
1322                 codecTypeDesc = quicktime_get_videocodecType_desc(i);
1323                 if (!codecTypeDesc) break;
1324
1325                 tmp.value = codecTypeDesc->rnatmpvalue;
1326                 tmp.identifier = codecTypeDesc->codecName;
1327                 tmp.name = codecTypeDesc->codecName;
1328                 RNA_enum_item_add(&item, &totitem, &tmp);
1329         }
1330         
1331         RNA_enum_item_end(&item, &totitem);
1332         *r_free = true;
1333         
1334         return item;
1335 }
1336
1337 static int rna_RenderSettings_qtcodecsettings_audiocodecType_get(PointerRNA *ptr)
1338 {
1339         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1340         
1341         return quicktime_rnatmpvalue_from_audiocodectype(settings->audiocodecType);
1342 }
1343
1344 static void rna_RenderSettings_qtcodecsettings_audiocodecType_set(PointerRNA *ptr, int value)
1345 {
1346         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1347         
1348         settings->audiocodecType = quicktime_audiocodecType_from_rnatmpvalue(value);
1349 }
1350
1351 static EnumPropertyItem *rna_RenderSettings_qtcodecsettings_audiocodecType_itemf(
1352         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1353 {
1354         EnumPropertyItem *item = NULL;
1355         EnumPropertyItem tmp = {0, "", 0, "", ""};
1356         QuicktimeCodecTypeDesc *codecTypeDesc;
1357         int i = 1, totitem = 0;
1358         
1359         for (i = 0; i < quicktime_get_num_audiocodecs(); i++) {
1360                 codecTypeDesc = quicktime_get_audiocodecType_desc(i);
1361                 if (!codecTypeDesc) break;
1362                 
1363                 tmp.value = codecTypeDesc->rnatmpvalue;
1364                 tmp.identifier = codecTypeDesc->codecName;
1365                 tmp.name = codecTypeDesc->codecName;
1366                 RNA_enum_item_add(&item, &totitem, &tmp);
1367         }
1368         
1369         RNA_enum_item_end(&item, &totitem);
1370         *r_free = true;
1371         
1372         return item;
1373 }
1374 #endif
1375
1376 #ifdef WITH_FFMPEG
1377 static void rna_FFmpegSettings_lossless_output_set(PointerRNA *ptr, int value)
1378 {
1379         Scene *scene = (Scene *) ptr->id.data;
1380         RenderData *rd = &scene->r;
1381
1382         if (value)
1383                 rd->ffcodecdata.flags |= FFMPEG_LOSSLESS_OUTPUT;
1384         else
1385                 rd->ffcodecdata.flags &= ~FFMPEG_LOSSLESS_OUTPUT;
1386
1387         BKE_ffmpeg_codec_settings_verify(rd);
1388 }
1389
1390 static void rna_FFmpegSettings_codec_settings_update(Main *UNUSED(bmain), Scene *UNUSED(scene_unused), PointerRNA *ptr)
1391 {
1392         Scene *scene = (Scene *) ptr->id.data;
1393         RenderData *rd = &scene->r;
1394
1395         BKE_ffmpeg_codec_settings_verify(rd);
1396 }
1397 #endif
1398
1399 static int rna_RenderSettings_active_layer_index_get(PointerRNA *ptr)
1400 {
1401         RenderData *rd = (RenderData *)ptr->data;
1402         return rd->actlay;
1403 }
1404
1405 static void rna_RenderSettings_active_layer_index_set(PointerRNA *ptr, int value)
1406 {
1407         RenderData *rd = (RenderData *)ptr->data;
1408         int num_layers = BLI_listbase_count(&rd->layers);
1409         rd->actlay = min_ff(value, num_layers - 1);
1410 }
1411
1412 static void rna_RenderSettings_active_layer_index_range(
1413         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
1414 {
1415         RenderData *rd = (RenderData *)ptr->data;
1416
1417         *min = 0;
1418         *max = max_ii(0, BLI_listbase_count(&rd->layers) - 1);
1419 }
1420
1421 static PointerRNA rna_RenderSettings_active_layer_get(PointerRNA *ptr)
1422 {
1423         RenderData *rd = (RenderData *)ptr->data;
1424         SceneRenderLayer *srl = BLI_findlink(&rd->layers, rd->actlay);
1425         
1426         return rna_pointer_inherit_refine(ptr, &RNA_SceneRenderLayer, srl);
1427 }
1428
1429 static void rna_RenderSettings_active_layer_set(PointerRNA *ptr, PointerRNA value)
1430 {
1431         RenderData *rd = (RenderData *)ptr->data;
1432         SceneRenderLayer *srl = (SceneRenderLayer *)value.data;
1433         const int index = BLI_findindex(&rd->layers, srl);
1434         if (index != -1) rd->actlay = index;
1435 }
1436
1437 static SceneRenderLayer *rna_RenderLayer_new(ID *id, RenderData *UNUSED(rd), const char *name)
1438 {
1439         Scene *scene = (Scene *)id;
1440         SceneRenderLayer *srl = BKE_scene_add_render_layer(scene, name);
1441
1442         DAG_id_tag_update(&scene->id, 0);
1443         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1444
1445         return srl;
1446 }
1447
1448 static void rna_RenderLayer_remove(
1449         ID *id, RenderData *UNUSED(rd), Main *bmain, ReportList *reports, PointerRNA *srl_ptr)
1450 {
1451         SceneRenderLayer *srl = srl_ptr->data;
1452         Scene *scene = (Scene *)id;
1453
1454         if (!BKE_scene_remove_render_layer(bmain, scene, srl)) {
1455                 BKE_reportf(reports, RPT_ERROR, "Render layer '%s' could not be removed from scene '%s'",
1456                             srl->name, scene->id.name + 2);
1457                 return;
1458         }
1459
1460         RNA_POINTER_INVALIDATE(srl_ptr);
1461
1462         DAG_id_tag_update(&scene->id, 0);
1463         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1464 }
1465
1466 static int rna_RenderSettings_active_view_index_get(PointerRNA *ptr)
1467 {
1468         RenderData *rd = (RenderData *)ptr->data;
1469         return rd->actview;
1470 }
1471
1472 static void rna_RenderSettings_active_view_index_set(PointerRNA *ptr, int value)
1473 {
1474         RenderData *rd = (RenderData *)ptr->data;
1475         rd->actview = value;
1476 }
1477
1478 static void rna_RenderSettings_active_view_index_range(
1479         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
1480 {
1481         RenderData *rd = (RenderData *)ptr->data;
1482
1483         *min = 0;
1484         *max = max_ii(0, BLI_listbase_count(&rd->views) - 1);
1485 }
1486
1487 static PointerRNA rna_RenderSettings_active_view_get(PointerRNA *ptr)
1488 {
1489         RenderData *rd = (RenderData *)ptr->data;
1490         SceneRenderView *srv = BLI_findlink(&rd->views, rd->actview);
1491
1492         return rna_pointer_inherit_refine(ptr, &RNA_SceneRenderView, srv);
1493 }
1494
1495 static void rna_RenderSettings_active_view_set(PointerRNA *ptr, PointerRNA value)
1496 {
1497         RenderData *rd = (RenderData *)ptr->data;
1498         SceneRenderView *srv = (SceneRenderView *)value.data;
1499         const int index = BLI_findindex(&rd->views, srv);
1500         if (index != -1) rd->actview = index;
1501 }
1502
1503 static SceneRenderView *rna_RenderView_new(ID *id, RenderData *UNUSED(rd), const char *name)
1504 {
1505         Scene *scene = (Scene *)id;
1506         SceneRenderView *srv = BKE_scene_add_render_view(scene, name);
1507
1508         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1509
1510         return srv;
1511 }
1512
1513 static void rna_RenderView_remove(
1514         ID *id, RenderData *UNUSED(rd), Main *UNUSED(bmain), ReportList *reports, PointerRNA *srv_ptr)
1515 {
1516         SceneRenderView *srv = srv_ptr->data;
1517         Scene *scene = (Scene *)id;
1518
1519         if (!BKE_scene_remove_render_view(scene, srv)) {
1520                 BKE_reportf(reports, RPT_ERROR, "Render view '%s' could not be removed from scene '%s'",
1521                             srv->name, scene->id.name + 2);
1522                 return;
1523         }
1524
1525         RNA_POINTER_INVALIDATE(srv_ptr);
1526
1527         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1528 }
1529
1530 static void rna_RenderSettings_engine_set(PointerRNA *ptr, int value)
1531 {
1532         RenderData *rd = (RenderData *)ptr->data;
1533         RenderEngineType *type = BLI_findlink(&R_engines, value);
1534
1535         if (type)
1536                 BLI_strncpy_utf8(rd->engine, type->idname, sizeof(rd->engine));
1537 }
1538
1539 static EnumPropertyItem *rna_RenderSettings_engine_itemf(
1540         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1541 {
1542         RenderEngineType *type;
1543         EnumPropertyItem *item = NULL;
1544         EnumPropertyItem tmp = {0, "", 0, "", ""};
1545         int a = 0, totitem = 0;
1546
1547         for (type = R_engines.first; type; type = type->next, a++) {
1548                 tmp.value = a;
1549                 tmp.identifier = type->idname;
1550                 tmp.name = type->name;
1551                 RNA_enum_item_add(&item, &totitem, &tmp);
1552         }
1553         
1554         RNA_enum_item_end(&item, &totitem);
1555         *r_free = true;
1556
1557         return item;
1558 }
1559
1560 static int rna_RenderSettings_engine_get(PointerRNA *ptr)
1561 {
1562         RenderData *rd = (RenderData *)ptr->data;
1563         RenderEngineType *type;
1564         int a = 0;
1565
1566         for (type = R_engines.first; type; type = type->next, a++)
1567                 if (STREQ(type->idname, rd->engine))
1568                         return a;
1569         
1570         return 0;
1571 }
1572
1573 static void rna_RenderSettings_engine_update(Main *bmain, Scene *UNUSED(unused), PointerRNA *UNUSED(ptr))
1574 {
1575         ED_render_engine_changed(bmain);
1576 }
1577
1578 static void rna_Scene_glsl_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1579 {
1580         Scene *scene = (Scene *)ptr->id.data;
1581
1582         DAG_id_tag_update(&scene->id, 0);
1583 }
1584
1585 static void rna_Scene_freestyle_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1586 {
1587         Scene *scene = (Scene *)ptr->id.data;
1588
1589         DAG_id_tag_update(&scene->id, 0);
1590 }
1591
1592 static void rna_Scene_use_view_map_cache_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
1593 {
1594 #ifdef WITH_FREESTYLE
1595         FRS_free_view_map_cache();
1596 #endif
1597 }
1598
1599 static void rna_SceneRenderLayer_name_set(PointerRNA *ptr, const char *value)
1600 {
1601         Scene *scene = (Scene *)ptr->id.data;
1602         SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
1603         char oldname[sizeof(rl->name)];
1604
1605         BLI_strncpy(oldname, rl->name, sizeof(rl->name));
1606
1607         BLI_strncpy_utf8(rl->name, value, sizeof(rl->name));
1608         BLI_uniquename(&scene->r.layers, rl, DATA_("RenderLayer"), '.', offsetof(SceneRenderLayer, name), sizeof(rl->name));
1609
1610         if (scene->nodetree) {
1611                 bNode *node;
1612                 int index = BLI_findindex(&scene->r.layers, rl);
1613
1614                 for (node = scene->nodetree->nodes.first; node; node = node->next) {
1615                         if (node->type == CMP_NODE_R_LAYERS && node->id == NULL) {
1616                                 if (node->custom1 == index)
1617                                         BLI_strncpy(node->name, rl->name, NODE_MAXSTR);
1618                         }
1619                 }
1620         }
1621
1622         /* fix all the animation data which may link to this */
1623         BKE_animdata_fix_paths_rename_all(NULL, "render.layers", oldname, rl->name);
1624 }
1625
1626 static char *rna_SceneRenderLayer_path(PointerRNA *ptr)
1627 {
1628         SceneRenderLayer *srl = (SceneRenderLayer *)ptr->data;
1629         char name_esc[sizeof(srl->name) * 2];
1630
1631         BLI_strescape(name_esc, srl->name, sizeof(name_esc));
1632         return BLI_sprintfN("render.layers[\"%s\"]", name_esc);
1633 }
1634
1635 static void rna_SceneRenderView_name_set(PointerRNA *ptr, const char *value)
1636 {
1637         Scene *scene = (Scene *)ptr->id.data;
1638         SceneRenderView *rv = (SceneRenderView *)ptr->data;
1639         BLI_strncpy_utf8(rv->name, value, sizeof(rv->name));
1640         BLI_uniquename(&scene->r.views, rv, DATA_("RenderView"), '.', offsetof(SceneRenderView, name), sizeof(rv->name));
1641 }
1642
1643 static char *rna_SceneRenderView_path(PointerRNA *ptr)
1644 {
1645         SceneRenderView *srv = (SceneRenderView *)ptr->data;
1646         return BLI_sprintfN("render.views[\"%s\"]", srv->name);
1647 }
1648
1649 static void rna_RenderSettings_views_format_set(PointerRNA *ptr, int value)
1650 {
1651         RenderData *rd = (RenderData *)ptr->data;
1652
1653         if (rd->views_format == SCE_VIEWS_FORMAT_MULTIVIEW &&
1654             value == SCE_VIEWS_FORMAT_STEREO_3D)
1655         {
1656                 /* make sure the actview is visible */
1657                 if (rd->actview > 1) rd->actview = 1;
1658         }
1659
1660         rd->views_format = value;
1661 }
1662
1663 static int rna_RenderSettings_multiple_engines_get(PointerRNA *UNUSED(ptr))
1664 {
1665         return (BLI_listbase_count(&R_engines) > 1);
1666 }
1667
1668 static int rna_RenderSettings_use_shading_nodes_get(PointerRNA *ptr)
1669 {
1670         Scene *scene = (Scene *)ptr->id.data;
1671         return BKE_scene_use_new_shading_nodes(scene);
1672 }
1673
1674 static int rna_RenderSettings_use_spherical_stereo_get(PointerRNA *ptr)
1675 {
1676         Scene *scene = (Scene *)ptr->id.data;
1677         return BKE_scene_use_spherical_stereo(scene);
1678 }
1679
1680 static int rna_RenderSettings_use_game_engine_get(PointerRNA *ptr)
1681 {
1682         RenderData *rd = (RenderData *)ptr->data;
1683         RenderEngineType *type;
1684
1685         for (type = R_engines.first; type; type = type->next)
1686                 if (STREQ(type->idname, rd->engine))
1687                         return (type->flag & RE_GAME) != 0;
1688         
1689         return 0;
1690 }
1691
1692 static void rna_SceneRenderLayer_layer_set(PointerRNA *ptr, const int *values)
1693 {
1694         SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
1695         rl->lay = ED_view3d_scene_layer_set(rl->lay, values, NULL);
1696 }
1697
1698 static void rna_SceneRenderLayer_pass_update(Main *bmain, Scene *activescene, PointerRNA *ptr)
1699 {
1700         Scene *scene = (Scene *)ptr->id.data;
1701
1702         if (scene->nodetree)
1703                 ntreeCompositForceHidden(scene->nodetree);
1704         
1705         rna_Scene_glsl_update(bmain, activescene, ptr);
1706 }
1707
1708 static void rna_Scene_use_nodes_update(bContext *C, PointerRNA *ptr)
1709 {
1710         Scene *scene = (Scene *)ptr->data;
1711
1712         if (scene->use_nodes && scene->nodetree == NULL)
1713                 ED_node_composit_default(C, scene);
1714 }
1715
1716 static void rna_Physics_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1717 {
1718         Scene *scene = (Scene *)ptr->id.data;
1719         Base *base;
1720
1721         for (base = scene->base.first; base; base = base->next)
1722                 BKE_ptcache_object_reset(scene, base->object, PTCACHE_RESET_DEPSGRAPH);
1723 }
1724
1725 static void rna_Scene_editmesh_select_mode_set(PointerRNA *ptr, const int *value)
1726 {
1727         Scene *scene = (Scene *)ptr->id.data;
1728         ToolSettings *ts = (ToolSettings *)ptr->data;
1729         int flag = (value[0] ? SCE_SELECT_VERTEX : 0) | (value[1] ? SCE_SELECT_EDGE : 0) | (value[2] ? SCE_SELECT_FACE : 0);
1730
1731         if (flag) {
1732                 ts->selectmode = flag;
1733
1734                 if (scene->basact) {
1735                         Mesh *me = BKE_mesh_from_object(scene->basact->object);
1736                         if (me && me->edit_btmesh && me->edit_btmesh->selectmode != flag) {
1737                                 me->edit_btmesh->selectmode = flag;
1738                                 EDBM_selectmode_set(me->edit_btmesh);
1739                         }
1740                 }
1741         }
1742 }
1743
1744 static void rna_Scene_editmesh_select_mode_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
1745 {
1746         Mesh *me = NULL;
1747
1748         if (scene->basact) {
1749                 me = BKE_mesh_from_object(scene->basact->object);
1750                 if (me && me->edit_btmesh == NULL)
1751                         me = NULL;
1752         }
1753
1754         WM_main_add_notifier(NC_GEOM | ND_SELECT, me);
1755         WM_main_add_notifier(NC_SCENE | ND_TOOLSETTINGS, NULL);
1756 }
1757
1758 static void object_simplify_update(Object *ob)
1759 {
1760         ModifierData *md;
1761         ParticleSystem *psys;
1762
1763         if ((ob->id.tag & LIB_TAG_DOIT) == 0) {
1764                 return;
1765         }
1766
1767         ob->id.tag &= ~LIB_TAG_DOIT;
1768
1769         for (md = ob->modifiers.first; md; md = md->next) {
1770                 if (ELEM(md->type, eModifierType_Subsurf, eModifierType_Multires, eModifierType_ParticleSystem)) {
1771                         DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
1772                 }
1773         }
1774
1775         for (psys = ob->particlesystem.first; psys; psys = psys->next)
1776                 psys->recalc |= PSYS_RECALC_CHILD;
1777         
1778         if (ob->dup_group) {
1779                 GroupObject *gob;
1780
1781                 for (gob = ob->dup_group->gobject.first; gob; gob = gob->next)
1782                         object_simplify_update(gob->ob);
1783         }
1784 }
1785
1786 static void rna_Scene_use_simplify_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
1787 {
1788         Scene *sce = ptr->id.data;
1789         Scene *sce_iter;
1790         Base *base;
1791
1792         BKE_main_id_tag_listbase(&bmain->object, LIB_TAG_DOIT, true);
1793         for (SETLOOPER(sce, sce_iter, base))
1794                 object_simplify_update(base->object);
1795         
1796         WM_main_add_notifier(NC_GEOM | ND_DATA, NULL);
1797 }
1798
1799 static void rna_Scene_simplify_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
1800 {
1801         Scene *sce = ptr->id.data;
1802
1803         if (sce->r.mode & R_SIMPLIFY)
1804                 rna_Scene_use_simplify_update(bmain, sce, ptr);
1805 }
1806
1807 static void rna_Scene_use_persistent_data_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1808 {
1809         Scene *sce = ptr->id.data;
1810
1811         if (!(sce->r.mode & R_PERSISTENT_DATA))
1812                 RE_FreePersistentData();
1813 }
1814
1815 static int rna_Scene_use_audio_get(PointerRNA *ptr)
1816 {
1817         Scene *scene = (Scene *)ptr->data;
1818         return (scene->audio.flag & AUDIO_MUTE) != 0;
1819 }
1820
1821 static void rna_Scene_use_audio_set(PointerRNA *ptr, int value)
1822 {
1823         Scene *scene = (Scene *)ptr->data;
1824
1825         if (value)
1826                 scene->audio.flag |= AUDIO_MUTE;
1827         else
1828                 scene->audio.flag &= ~AUDIO_MUTE;
1829
1830         BKE_sound_mute_scene(scene, value);
1831 }
1832
1833 static int rna_Scene_sync_mode_get(PointerRNA *ptr)
1834 {
1835         Scene *scene = (Scene *)ptr->data;
1836         if (scene->audio.flag & AUDIO_SYNC)
1837                 return AUDIO_SYNC;
1838         return scene->flag & SCE_FRAME_DROP;
1839 }
1840
1841 static void rna_Scene_sync_mode_set(PointerRNA *ptr, int value)
1842 {
1843         Scene *scene = (Scene *)ptr->data;
1844
1845         if (value == AUDIO_SYNC) {
1846                 scene->audio.flag |= AUDIO_SYNC;
1847         }
1848         else if (value == SCE_FRAME_DROP) {
1849                 scene->audio.flag &= ~AUDIO_SYNC;
1850                 scene->flag |= SCE_FRAME_DROP;
1851         }
1852         else {
1853                 scene->audio.flag &= ~AUDIO_SYNC;
1854                 scene->flag &= ~SCE_FRAME_DROP;
1855         }
1856 }
1857
1858 static int rna_GameSettings_auto_start_get(PointerRNA *UNUSED(ptr))
1859 {
1860         return (G.fileflags & G_FILE_AUTOPLAY) != 0;
1861 }
1862
1863 static void rna_GameSettings_auto_start_set(PointerRNA *UNUSED(ptr), int value)
1864 {
1865         if (value)
1866                 G.fileflags |= G_FILE_AUTOPLAY;
1867         else
1868                 G.fileflags &= ~G_FILE_AUTOPLAY;
1869 }
1870
1871 static void rna_GameSettings_exit_key_set(PointerRNA *ptr, int value)
1872 {
1873         GameData *gm = (GameData *)ptr->data;
1874
1875         if (ISKEYBOARD(value))
1876                 gm->exitkey = value;
1877 }
1878
1879 static StructRNA *rna_RenderEngineSettings_refine(PointerRNA *ptr)
1880 {
1881 #ifdef WITH_CLAY_ENGINE
1882         RenderEngineSettings *res = (RenderEngineSettings *)ptr->data;
1883
1884         if (STREQ(res->name, RE_engine_id_BLENDER_CLAY)) {
1885                 return  &RNA_RenderEngineSettingsClay;
1886         }
1887 #endif
1888         return &RNA_RenderEngineSettings;
1889 }
1890
1891 static PointerRNA rna_RenderEngineSettings_active_get(PointerRNA *ptr)
1892 {
1893         Scene *scene = (Scene *)ptr->data;
1894         RenderEngineSettings *res;
1895
1896         /* Ensure settings exists */
1897         DRW_render_settings_get(scene, scene->r.engine);
1898
1899         res = BLI_findstring(&scene->engines_settings, scene->r.engine, offsetof(RenderEngineSettings, name));
1900
1901         return rna_pointer_inherit_refine(ptr, &RNA_RenderEngineSettings, res);
1902 }
1903
1904 static void rna_RenderEngineSettings_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1905 {
1906         Scene *sce = (Scene *)ptr->id.data;
1907         MaterialEngineSettingsClay *res;
1908
1909         res = (MaterialEngineSettingsClay *)DRW_render_settings_get(sce, sce->r.engine);
1910
1911         res->flag = CLAY_OUTDATED;
1912
1913         WM_main_add_notifier(NC_SPACE | ND_SPACE_VIEW3D, NULL);
1914 }
1915
1916 static TimeMarker *rna_TimeLine_add(Scene *scene, const char name[], int frame)
1917 {
1918         TimeMarker *marker = MEM_callocN(sizeof(TimeMarker), "TimeMarker");
1919         marker->flag = SELECT;
1920         marker->frame = frame;
1921         BLI_strncpy_utf8(marker->name, name, sizeof(marker->name));
1922         BLI_addtail(&scene->markers, marker);
1923
1924         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1925         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1926
1927         return marker;
1928 }
1929
1930 static void rna_TimeLine_remove(Scene *scene, ReportList *reports, PointerRNA *marker_ptr)
1931 {
1932         TimeMarker *marker = marker_ptr->data;
1933         if (BLI_remlink_safe(&scene->markers, marker) == false) {
1934                 BKE_reportf(reports, RPT_ERROR, "Timeline marker '%s' not found in scene '%s'",
1935                             marker->name, scene->id.name + 2);
1936                 return;
1937         }
1938
1939         MEM_freeN(marker);
1940         RNA_POINTER_INVALIDATE(marker_ptr);
1941
1942         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1943         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1944 }
1945
1946 static void rna_TimeLine_clear(Scene *scene)
1947 {
1948         BLI_freelistN(&scene->markers);
1949
1950         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1951         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1952 }
1953
1954 static KeyingSet *rna_Scene_keying_set_new(Scene *sce, ReportList *reports, const char idname[], const char name[])
1955 {
1956         KeyingSet *ks = NULL;
1957
1958         /* call the API func, and set the active keyingset index */
1959         ks = BKE_keyingset_add(&sce->keyingsets, idname, name, KEYINGSET_ABSOLUTE, 0);
1960         
1961         if (ks) {
1962                 sce->active_keyingset = BLI_listbase_count(&sce->keyingsets);
1963                 return ks;
1964         }
1965         else {
1966                 BKE_report(reports, RPT_ERROR, "Keying set could not be added");
1967                 return NULL;
1968         }
1969 }
1970
1971 static void rna_UnifiedPaintSettings_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
1972 {
1973         Brush *br = BKE_paint_brush(BKE_paint_get_active(scene));
1974         WM_main_add_notifier(NC_BRUSH | NA_EDITED, br);
1975 }
1976
1977 static void rna_UnifiedPaintSettings_size_set(PointerRNA *ptr, int value)
1978 {
1979         UnifiedPaintSettings *ups = ptr->data;
1980
1981         /* scale unprojected radius so it stays consistent with brush size */
1982         BKE_brush_scale_unprojected_radius(&ups->unprojected_radius,
1983                                            value, ups->size);
1984         ups->size = value;
1985 }
1986
1987 static void rna_UnifiedPaintSettings_unprojected_radius_set(PointerRNA *ptr, float value)
1988 {
1989         UnifiedPaintSettings *ups = ptr->data;
1990
1991         /* scale brush size so it stays consistent with unprojected_radius */
1992         BKE_brush_scale_size(&ups->size, value, ups->unprojected_radius);
1993         ups->unprojected_radius = value;
1994 }
1995
1996 static void rna_UnifiedPaintSettings_radius_update(Main *bmain, Scene *scene, PointerRNA *ptr)
1997 {
1998         /* changing the unified size should invalidate the overlay but also update the brush */
1999         BKE_paint_invalidate_overlay_all();
2000         rna_UnifiedPaintSettings_update(bmain, scene, ptr);
2001 }
2002
2003 static char *rna_UnifiedPaintSettings_path(PointerRNA *UNUSED(ptr))
2004 {
2005         return BLI_strdup("tool_settings.unified_paint_settings");
2006 }
2007
2008 static char *rna_CurvePaintSettings_path(PointerRNA *UNUSED(ptr))
2009 {
2010         return BLI_strdup("tool_settings.curve_paint_settings");
2011 }
2012
2013 /* generic function to recalc geometry */
2014 static void rna_EditMesh_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
2015 {
2016         Mesh *me = NULL;
2017
2018         if (scene->basact) {
2019                 me = BKE_mesh_from_object(scene->basact->object);
2020                 if (me && me->edit_btmesh == NULL)
2021                         me = NULL;
2022         }
2023
2024         if (me) {
2025                 DAG_id_tag_update(&me->id, OB_RECALC_DATA);
2026                 WM_main_add_notifier(NC_GEOM | ND_DATA, me);
2027         }
2028 }
2029
2030 static char *rna_MeshStatVis_path(PointerRNA *UNUSED(ptr))
2031 {
2032         return BLI_strdup("tool_settings.statvis");
2033 }
2034
2035 /* note: without this, when Multi-Paint is activated/deactivated, the colors
2036  * will not change right away when multiple bones are selected, this function
2037  * is not for general use and only for the few cases where changing scene
2038  * settings and NOT for general purpose updates, possibly this should be
2039  * given its own notifier. */
2040 static void rna_Scene_update_active_object_data(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
2041 {
2042         Object *ob = OBACT;
2043         if (ob) {
2044                 DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
2045                 WM_main_add_notifier(NC_OBJECT | ND_DRAW, &ob->id);
2046         }
2047 }
2048
2049 static void rna_SceneCamera_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2050 {
2051         Scene *scene = (Scene *)ptr->id.data;
2052         Object *camera = scene->camera;
2053
2054         if (camera)
2055                 DAG_id_tag_update(&camera->id, 0);
2056 }
2057
2058 static void rna_SceneSequencer_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
2059 {
2060         BKE_sequencer_cache_cleanup();
2061         BKE_sequencer_preprocessed_cache_cleanup();
2062 }
2063
2064 static char *rna_ToolSettings_path(PointerRNA *UNUSED(ptr))
2065 {
2066         return BLI_strdup("tool_settings");
2067 }
2068
2069 static PointerRNA rna_FreestyleLineSet_linestyle_get(PointerRNA *ptr)
2070 {
2071         FreestyleLineSet *lineset = (FreestyleLineSet *)ptr->data;
2072
2073         return rna_pointer_inherit_refine(ptr, &RNA_FreestyleLineStyle, lineset->linestyle);
2074 }
2075
2076 static void rna_FreestyleLineSet_linestyle_set(PointerRNA *ptr, PointerRNA value)
2077 {
2078         FreestyleLineSet *lineset = (FreestyleLineSet *)ptr->data;
2079
2080         if (lineset->linestyle)
2081                 id_us_min(&lineset->linestyle->id);
2082         lineset->linestyle = (FreestyleLineStyle *)value.data;
2083         id_us_plus(&lineset->linestyle->id);
2084 }
2085
2086 static FreestyleLineSet *rna_FreestyleSettings_lineset_add(
2087         ID *id, FreestyleSettings *config, Main *bmain, const char *name)
2088 {
2089         Scene *scene = (Scene *)id;
2090         FreestyleLineSet *lineset = BKE_freestyle_lineset_add(bmain, (FreestyleConfig *)config, name);
2091
2092         DAG_id_tag_update(&scene->id, 0);
2093         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2094
2095         return lineset;
2096 }
2097
2098 static void rna_FreestyleSettings_lineset_remove(
2099         ID *id, FreestyleSettings *config, ReportList *reports, PointerRNA *lineset_ptr)
2100 {
2101         FreestyleLineSet *lineset = lineset_ptr->data;
2102         Scene *scene = (Scene *)id;
2103
2104         if (!BKE_freestyle_lineset_delete((FreestyleConfig *)config, lineset)) {
2105                 BKE_reportf(reports, RPT_ERROR, "Line set '%s' could not be removed", lineset->name);
2106                 return;
2107         }
2108
2109         RNA_POINTER_INVALIDATE(lineset_ptr);
2110
2111         DAG_id_tag_update(&scene->id, 0);
2112         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2113 }
2114
2115 static PointerRNA rna_FreestyleSettings_active_lineset_get(PointerRNA *ptr)
2116 {
2117         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2118         FreestyleLineSet *lineset = BKE_freestyle_lineset_get_active(config);
2119         return rna_pointer_inherit_refine(ptr, &RNA_FreestyleLineSet, lineset);
2120 }
2121
2122 static void rna_FreestyleSettings_active_lineset_index_range(
2123         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2124 {
2125         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2126
2127         *min = 0;
2128         *max = max_ii(0, BLI_listbase_count(&config->linesets) - 1);
2129 }
2130
2131 static int rna_FreestyleSettings_active_lineset_index_get(PointerRNA *ptr)
2132 {
2133         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2134         return BKE_freestyle_lineset_get_active_index(config);
2135 }
2136
2137 static void rna_FreestyleSettings_active_lineset_index_set(PointerRNA *ptr, int value)
2138 {
2139         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2140         BKE_freestyle_lineset_set_active_index(config, value);
2141 }
2142
2143 static FreestyleModuleConfig *rna_FreestyleSettings_module_add(ID *id, FreestyleSettings *config)
2144 {
2145         Scene *scene = (Scene *)id;
2146         FreestyleModuleConfig *module = BKE_freestyle_module_add((FreestyleConfig *)config);
2147
2148         DAG_id_tag_update(&scene->id, 0);
2149         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2150
2151         return module;
2152 }
2153
2154 static void rna_FreestyleSettings_module_remove(
2155         ID *id, FreestyleSettings *config, ReportList *reports, PointerRNA *module_ptr)
2156 {
2157         Scene *scene = (Scene *)id;
2158         FreestyleModuleConfig *module = module_ptr->data;
2159
2160         if (!BKE_freestyle_module_delete((FreestyleConfig *)config, module)) {
2161                 if (module->script)
2162                         BKE_reportf(reports, RPT_ERROR, "Style module '%s' could not be removed", module->script->id.name + 2);
2163                 else
2164                         BKE_report(reports, RPT_ERROR, "Style module could not be removed");
2165                 return;
2166         }
2167
2168         RNA_POINTER_INVALIDATE(module_ptr);
2169
2170         DAG_id_tag_update(&scene->id, 0);
2171         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2172 }
2173
2174 char *rna_GPUDOF_path(PointerRNA *ptr)
2175 {
2176         /* if there is ID-data, resolve the path using the index instead of by name,
2177          * since the name used is the name of the texture assigned, but the texture
2178          * may be used multiple times in the same stack
2179          */
2180         if (ptr->id.data) {
2181                 if (GS(((ID *)ptr->id.data)->name) == ID_CA) {
2182                         return BLI_strdup("gpu_dof");
2183                 }
2184         }
2185
2186         return BLI_strdup("");
2187 }
2188
2189 static void rna_GPUFXSettings_fx_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2190 {
2191         GPUFXSettings *fx_settings = ptr->data;
2192
2193         BKE_screen_gpu_fx_validate(fx_settings);
2194 }
2195
2196 static void rna_GPUDOFSettings_blades_set(PointerRNA *ptr, const int value)
2197 {
2198         GPUDOFSettings *dofsettings = (GPUDOFSettings *)ptr->data;
2199
2200         if (value < 3 && dofsettings->num_blades > 2)
2201                 dofsettings->num_blades = 0;
2202         else if (value > 0 && dofsettings->num_blades == 0)
2203                 dofsettings->num_blades = 3;
2204         else
2205                 dofsettings->num_blades = value;
2206 }
2207
2208 static void rna_Stereo3dFormat_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2209 {
2210         ID *id = ptr->id.data;
2211
2212         if (id && GS(id->name) == ID_IM) {
2213                 Image *ima = (Image *)id;
2214                 ImBuf *ibuf;
2215                 void *lock;
2216
2217                 if (!BKE_image_is_stereo(ima))
2218                         return;
2219
2220                 ibuf = BKE_image_acquire_ibuf(ima, NULL, &lock);
2221
2222                 if (ibuf) {
2223                         BKE_image_signal(ima, NULL, IMA_SIGNAL_FREE);
2224                 }
2225                 BKE_image_release_ibuf(ima, ibuf, lock);
2226         }
2227 }
2228
2229 static int rna_gpu_is_hq_supported_get(PointerRNA *UNUSED(ptr))
2230 {
2231         return GPU_instanced_drawing_support() && GPU_geometry_shader_support();
2232 }
2233
2234 static void rna_SceneCollection_name_set(PointerRNA *ptr, const char *value)
2235 {
2236         Scene *scene = (Scene *)ptr->id.data;
2237         SceneCollection *sc = (SceneCollection *)ptr->data;
2238         SceneCollection *sc_master = BKE_collection_master(scene);
2239
2240         BLI_strncpy_utf8(sc->name, value, sizeof(sc->name));
2241         BLI_uniquename(&sc_master->scene_collections, sc, DATA_("SceneCollection"), '.', offsetof(SceneCollection, name), sizeof(sc->name));
2242 }
2243
2244 static void rna_SceneCollection_filter_set(PointerRNA *ptr, const char *value)
2245 {
2246         Scene *scene = (Scene *)ptr->id.data;
2247         SceneCollection *sc = (SceneCollection *)ptr->data;
2248         BLI_strncpy_utf8(sc->filter, value, sizeof(sc->filter));
2249
2250         TODO_LAYER_SYNC_FILTER;
2251         (void)scene;
2252 }
2253
2254 static PointerRNA rna_SceneCollection_objects_get(CollectionPropertyIterator *iter)
2255 {
2256         ListBaseIterator *internal = &iter->internal.listbase;
2257
2258         /* we are actually iterating a LinkData list, so override get */
2259         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, ((LinkData *)internal->link)->data);
2260 }
2261
2262 static SceneCollection *rna_SceneCollection_new(ID *id, SceneCollection *sc_parent, const char *name)
2263 {
2264         Scene *scene = (Scene *)id;
2265         SceneCollection *sc = BKE_collection_add(scene, sc_parent, name);
2266
2267         DAG_id_tag_update(&scene->id, 0);
2268         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2269
2270         return sc;
2271 }
2272
2273 static void rna_SceneCollection_remove(
2274         ID *id, SceneCollection *sc_parent, ReportList *reports, PointerRNA *sc_ptr)
2275 {
2276         Scene *scene = (Scene *)id;
2277         SceneCollection *sc = sc_ptr->data;
2278
2279         const int index = BLI_findindex(&sc_parent->scene_collections, sc);
2280         if (index == -1) {
2281                 BKE_reportf(reports, RPT_ERROR, "Collection '%s' is not a sub-collection of '%s'",
2282                             sc->name, sc_parent->name);
2283                 return;
2284         }
2285
2286         if (!BKE_collection_remove(scene, sc)) {
2287                 BKE_reportf(reports, RPT_ERROR, "Collection '%s' could not be removed from collection '%s'",
2288                             sc->name, sc_parent->name);
2289                 return;
2290         }
2291
2292         RNA_POINTER_INVALIDATE(sc_ptr);
2293
2294         DAG_id_tag_update(&scene->id, 0);
2295         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2296 }
2297
2298 static int rna_SceneCollection_objects_active_index_get(PointerRNA *ptr)
2299 {
2300         SceneCollection *sc = (SceneCollection *)ptr->data;
2301         return sc->active_object_index;
2302 }
2303
2304 static void rna_SceneCollection_objects_active_index_set(PointerRNA *ptr, int value)
2305 {
2306         SceneCollection *sc = (SceneCollection *)ptr->data;
2307         sc->active_object_index = value;
2308 }
2309
2310 static void rna_SceneCollection_objects_active_index_range(
2311         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2312 {
2313         SceneCollection *sc = (SceneCollection *)ptr->data;
2314         *min = 0;
2315         *max = max_ii(0, BLI_listbase_count(&sc->objects) - 1);
2316 }
2317
2318 void rna_SceneCollection_object_link(
2319         ID *id, SceneCollection *sc, Main *bmain, ReportList *reports, Object *ob)
2320 {
2321         Scene *scene = (Scene *)id;
2322
2323         if (BLI_findptr(&sc->objects, ob, offsetof(LinkData, data))) {
2324                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is already in collection '%s'", ob->id.name + 2, sc->name);
2325                 return;
2326         }
2327
2328         BKE_collection_object_add(scene, sc, ob);
2329
2330         /* TODO(sergey): Only update relations for the current scene. */
2331         DAG_relations_tag_update(bmain);
2332         DAG_id_tag_update(&ob->id, OB_RECALC_OB | OB_RECALC_DATA | OB_RECALC_TIME);
2333
2334         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2335 }
2336
2337 static void rna_SceneCollection_object_unlink(
2338         ID *id, SceneCollection *sc, Main *bmain, ReportList *reports, Object *ob)
2339 {
2340         Scene *scene = (Scene *)id;
2341
2342         if (!BLI_findptr(&sc->objects, ob, offsetof(LinkData, data))) {
2343                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is not in collection '%s'", ob->id.name + 2, sc->name);
2344                 return;
2345         }
2346
2347         BKE_collection_object_remove(bmain, scene, sc, ob, false);
2348
2349         /* needed otherwise the depgraph will contain freed objects which can crash, see [#20958] */
2350         DAG_relations_tag_update(bmain);
2351
2352         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2353 }
2354
2355 /****** layer collection engine settings *******/
2356
2357 static StructRNA *rna_CollectionEngineSettings_refine(struct PointerRNA *ptr)
2358 {
2359         CollectionEngineSettings *ces = (CollectionEngineSettings *)ptr->data;
2360
2361         if (STREQ(ces->name, "BLENDER_CLAY")) {
2362                 return &RNA_CollectionEngineSettingsClay;
2363         }
2364
2365         /* TODO - handle other engines */
2366         TODO_LAYER;
2367         (void) ces;
2368
2369         return &RNA_CollectionEngineSettings;
2370 }
2371
2372 /****** clay engine settings *******/
2373
2374 #define RNA_LAYER_ENGINE_USE_GET_SET(_NAME_)                                           \
2375         static int rna_LayerEngineSettings_##_NAME_##_use_get(PointerRNA *ptr)             \
2376     {                                                                                  \
2377             CollectionEngineSettings *ces = (CollectionEngineSettings *)ptr->data;         \
2378             return BKE_collection_engine_property_use_get(ces, #_NAME_) ? 1 : 0;           \
2379         }                                                                                  \
2380                                                                                            \
2381         static void rna_LayerEngineSettings_##_NAME_##_use_set(PointerRNA *ptr, int value) \
2382     {                                                                                  \
2383             CollectionEngineSettings *ces = (CollectionEngineSettings *)ptr->data;         \
2384             BKE_collection_engine_property_use_set(ces, #_NAME_, value? true : false);     \
2385         }
2386
2387 #define RNA_LAYER_ENGINE_GET_SET(_TYPE_, _NAME_)                                   \
2388 static _TYPE_ rna_LayerEngineSettings_##_NAME_##_get(PointerRNA *ptr)              \
2389 {                                                                                  \
2390         CollectionEngineSettings *ces = (CollectionEngineSettings *)ptr->data;         \
2391         return BKE_collection_engine_property_value_get_##_TYPE_(ces, #_NAME_);        \
2392 }                                                                                  \
2393                                                                                        \
2394 static void rna_LayerEngineSettings_##_NAME_##_set(PointerRNA *ptr, _TYPE_ value)  \
2395 {                                                                                  \
2396         CollectionEngineSettings *ces = (CollectionEngineSettings *)ptr->data;         \
2397         BKE_collection_engine_property_value_set_##_TYPE_(ces, #_NAME_, value);        \
2398 }                                                                                  \
2399         RNA_LAYER_ENGINE_USE_GET_SET(_NAME_)
2400
2401 #define RNA_LAYER_ENGINE_GET_SET_FLOAT(_NAME_) \
2402         RNA_LAYER_ENGINE_GET_SET(float, _NAME_)
2403
2404 #define RNA_LAYER_ENGINE_GET_SET_INT(_NAME_) \
2405         RNA_LAYER_ENGINE_GET_SET(int, _NAME_)
2406
2407
2408 RNA_LAYER_ENGINE_GET_SET_INT(type)
2409 RNA_LAYER_ENGINE_GET_SET_INT(matcap_icon)
2410 RNA_LAYER_ENGINE_GET_SET_FLOAT(matcap_rotation)
2411 RNA_LAYER_ENGINE_GET_SET_FLOAT(matcap_hue)
2412 RNA_LAYER_ENGINE_GET_SET_FLOAT(matcap_saturation)
2413 RNA_LAYER_ENGINE_GET_SET_FLOAT(matcap_value)
2414 RNA_LAYER_ENGINE_GET_SET_FLOAT(ssao_factor_cavity)
2415 RNA_LAYER_ENGINE_GET_SET_FLOAT(ssao_factor_edge)
2416 RNA_LAYER_ENGINE_GET_SET_FLOAT(ssao_distance)
2417 RNA_LAYER_ENGINE_GET_SET_FLOAT(ssao_attenuation)
2418
2419 #undef RNA_LAYER_ENGINE_GET_SET_INT
2420 #undef RNA_LAYER_ENGINE_GET_SET_FLOAT
2421 #undef RNA_LAYER_ENGINE_GET_SET
2422 #undef RNA_LAYER_ENGINE_USE_GET_SET
2423
2424 static void rna_CollectionEngineSettings_update(bContext *C, PointerRNA *UNUSED(ptr))
2425 {
2426         SceneLayer *sl = CTX_data_scene_layer(C);
2427         BKE_scene_layer_engine_settings_recalculate(sl);
2428 }
2429
2430 /***********************************/
2431
2432 static void rna_LayerCollection_name_get(PointerRNA *ptr, char *value)
2433 {
2434         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2435         strcpy(value, sc->name);
2436 }
2437
2438 static int rna_LayerCollection_name_length(PointerRNA *ptr)
2439 {
2440         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2441         return strnlen(sc->name, sizeof(sc->name));
2442 }
2443
2444 static void rna_LayerCollection_name_set(PointerRNA *ptr, const char *value)
2445 {
2446         Scene *scene = (Scene *)ptr->id.data;
2447         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2448         SceneCollection *sc_master = BKE_collection_master(scene);
2449
2450         BLI_strncpy_utf8(sc->name, value, sizeof(sc->name));
2451         BLI_uniquename(&sc_master->scene_collections, sc, DATA_("SceneCollection"), '.', offsetof(SceneCollection, name), sizeof(sc->name));
2452 }
2453
2454 static PointerRNA rna_LayerCollection_objects_get(CollectionPropertyIterator *iter)
2455 {
2456         ListBaseIterator *internal = &iter->internal.listbase;
2457         ObjectBase *base = ((LinkData *)internal->link)->data;
2458         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, base->object);
2459 }
2460
2461 static PointerRNA rna_LayerCollection_engine_settings_get(ID *UNUSED(id), LayerCollection *lc, bContext *C, const char *engine)
2462 {
2463         Scene *scene = CTX_data_scene(C);
2464         const char *engine_name;
2465
2466         if (STREQ(engine, NO_ENGINE)) {
2467                 RenderData *rd = &scene->r;
2468                 engine_name = rd->engine;
2469         }
2470         else {
2471                 engine_name = engine;
2472         }
2473
2474         PointerRNA ptr;
2475         CollectionEngineSettings *ces = BKE_layer_collection_engine_get(lc, engine_name);
2476         RNA_pointer_create(NULL, &RNA_CollectionEngineSettings, ces, &ptr);
2477         return rna_pointer_inherit_refine(&ptr, &RNA_CollectionEngineSettings, ces);
2478 }
2479
2480 static void rna_LayerCollection_hide_update(bContext *C, PointerRNA *ptr)
2481 {
2482         Scene *scene = CTX_data_scene(C);
2483         LayerCollection *lc = ptr->data;
2484         SceneLayer *sl = BKE_scene_layer_find_from_collection(scene, lc);
2485
2486         /* hide and deselect bases that are directly influenced by this LayerCollection */
2487         BKE_scene_layer_base_flag_recalculate(sl);
2488         WM_event_add_notifier(C, NC_SCENE | ND_OB_SELECT, scene);
2489 }
2490
2491 static void rna_LayerCollection_hide_select_update(bContext *C, PointerRNA *ptr)
2492 {
2493         LayerCollection *lc = ptr->data;
2494
2495         if ((lc->flag & COLLECTION_SELECTABLE) == 0) {
2496                 Scene *scene = CTX_data_scene(C);
2497                 SceneLayer *sl = BKE_scene_layer_find_from_collection(scene, lc);
2498
2499                 /* deselect bases that are directly influenced by this LayerCollection */
2500                 BKE_scene_layer_base_flag_recalculate(sl);
2501                 WM_event_add_notifier(C, NC_SCENE | ND_OB_SELECT, CTX_data_scene(C));
2502         }
2503 }
2504
2505 static int rna_LayerCollections_active_collection_index_get(PointerRNA *ptr)
2506 {
2507         SceneLayer *sl = (SceneLayer *)ptr->data;
2508         return sl->active_collection;
2509 }
2510
2511 static void rna_LayerCollections_active_collection_index_set(PointerRNA *ptr, int value)
2512 {
2513         SceneLayer *sl = (SceneLayer *)ptr->data;
2514         int num_collections = BKE_layer_collection_count(sl);
2515         sl->active_collection = min_ff(value, num_collections - 1);
2516 }
2517
2518 static void rna_LayerCollections_active_collection_index_range(
2519         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2520 {
2521         SceneLayer *sl = (SceneLayer *)ptr->data;
2522         *min = 0;
2523         *max = max_ii(0, BKE_layer_collection_count(sl) - 1);
2524 }
2525
2526 static PointerRNA rna_LayerCollections_active_collection_get(PointerRNA *ptr)
2527 {
2528         SceneLayer *sl = (SceneLayer *)ptr->data;
2529         LayerCollection *lc = BKE_layer_collection_active(sl);
2530         return rna_pointer_inherit_refine(ptr, &RNA_LayerCollection, lc);
2531 }
2532
2533 static void rna_LayerCollections_active_collection_set(PointerRNA *ptr, PointerRNA value)
2534 {
2535         SceneLayer *sl = (SceneLayer *)ptr->data;
2536         LayerCollection *lc = (LayerCollection *)value.data;
2537         const int index = BKE_layer_collection_findindex(sl, lc);
2538         if (index != -1) sl->active_collection = index;
2539 }
2540
2541 LayerCollection * rna_SceneLayer_collection_link(
2542         ID *id, SceneLayer *sl, Main *bmain, SceneCollection *sc)
2543 {
2544         Scene *scene = (Scene *)id;
2545         LayerCollection *lc = BKE_collection_link(sl, sc);
2546
2547         /* TODO(sergey/dfelinto): Only update relations for the current scenelayer. */
2548         DAG_relations_tag_update(bmain);
2549         WM_main_add_notifier(NC_SCENE | ND_LAYER, scene);
2550
2551         return lc;
2552 }
2553
2554 static void rna_SceneLayer_collection_unlink(
2555         ID *id, SceneLayer *sl, Main *bmain, ReportList *reports, LayerCollection *lc)
2556 {
2557         Scene *scene = (Scene *)id;
2558
2559         if (BLI_findindex(&sl->layer_collections, lc) == -1) {
2560                 BKE_reportf(reports, RPT_ERROR, "Layer collection '%s' is not in '%s'", lc->scene_collection->name, sl->name);
2561                 return;
2562         }
2563
2564         BKE_collection_unlink(sl, lc);
2565
2566         /* needed otherwise the depgraph will contain freed objects which can crash, see [#20958] */
2567         /* TODO(sergey/dfelinto): Only update relations for the current scenelayer. */
2568         DAG_relations_tag_update(bmain);
2569
2570         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2571 }
2572
2573 static PointerRNA rna_LayerObjects_active_object_get(PointerRNA *ptr)
2574 {
2575         SceneLayer *sl = (SceneLayer *)ptr->data;
2576         return rna_pointer_inherit_refine(ptr, &RNA_Object, sl->basact ? sl->basact->object : NULL);
2577 }
2578
2579 static void rna_LayerObjects_active_object_set(PointerRNA *ptr, PointerRNA value)
2580 {
2581         SceneLayer *sl = (SceneLayer *)ptr->data;
2582         if (value.data)
2583                 sl->basact = BKE_scene_layer_base_find(sl, (Object *)value.data);
2584         else
2585                 sl->basact = NULL;
2586 }
2587
2588 static void rna_SceneLayer_name_set(PointerRNA *ptr, const char *value)
2589 {
2590         Scene *scene = (Scene *)ptr->id.data;
2591         SceneLayer *sl = (SceneLayer *)ptr->data;
2592         char oldname[sizeof(sl->name)];
2593
2594         BLI_strncpy(oldname, sl->name, sizeof(sl->name));
2595
2596         BLI_strncpy_utf8(sl->name, value, sizeof(sl->name));
2597         BLI_uniquename(&scene->render_layers, sl, DATA_("SceneLayer"), '.', offsetof(SceneLayer, name), sizeof(sl->name));
2598
2599         if (scene->nodetree) {
2600                 bNode *node;
2601                 int index = BLI_findindex(&scene->render_layers, sl);
2602
2603                 for (node = scene->nodetree->nodes.first; node; node = node->next) {
2604                         if (node->type == CMP_NODE_R_LAYERS && node->id == NULL) {
2605                                 if (node->custom1 == index)
2606                                         BLI_strncpy(node->name, sl->name, NODE_MAXSTR);
2607                         }
2608                 }
2609         }
2610 }
2611
2612 static PointerRNA rna_SceneLayer_objects_get(CollectionPropertyIterator *iter)
2613 {
2614         ListBaseIterator *internal = &iter->internal.listbase;
2615
2616         /* we are actually iterating a ObjectBase list, so override get */
2617         ObjectBase *base = (ObjectBase *)internal->link;
2618         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, base->object);
2619 }
2620
2621 static int rna_SceneLayer_objects_selected_skip(CollectionPropertyIterator *iter, void *UNUSED(data))
2622 {
2623         ListBaseIterator *internal = &iter->internal.listbase;
2624         ObjectBase *base = (ObjectBase *)internal->link;
2625
2626         if ((base->flag & BASE_SELECTED) != 0) {
2627                         return 0;
2628         }
2629
2630         return 1;
2631 };
2632
2633 static void rna_LayerObjects_selected_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
2634 {
2635         SceneLayer *sl = (SceneLayer *)ptr->data;
2636         rna_iterator_listbase_begin(iter, &sl->object_bases, rna_SceneLayer_objects_selected_skip);
2637 }
2638
2639 static void rna_SceneLayer_engine_set(PointerRNA *ptr, int value)
2640 {
2641         SceneLayer *sl = (SceneLayer *)ptr->data;
2642         RenderEngineType *type = BLI_findlink(&R_engines, value);
2643
2644         if (type)
2645                 BKE_scene_layer_engine_set(sl, type->idname);
2646 }
2647
2648 static EnumPropertyItem *rna_SceneLayer_engine_itemf(
2649         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
2650 {
2651         RenderEngineType *type;
2652         EnumPropertyItem *item = NULL;
2653         EnumPropertyItem tmp = {0, "", 0, "", ""};
2654         int a = 0, totitem = 0;
2655
2656         for (type = R_engines.first; type; type = type->next, a++) {
2657                 tmp.value = a;
2658                 tmp.identifier = type->idname;
2659                 tmp.name = type->name;
2660                 RNA_enum_item_add(&item, &totitem, &tmp);
2661         }
2662
2663         RNA_enum_item_end(&item, &totitem);
2664         *r_free = true;
2665
2666         return item;
2667 }
2668
2669 static int rna_SceneLayer_engine_get(PointerRNA *ptr)
2670 {
2671         SceneLayer *sl = (SceneLayer *)ptr->data;
2672         RenderEngineType *type;
2673         int a = 0;
2674
2675         for (type = R_engines.first; type; type = type->next, a++)
2676                 if (STREQ(type->idname, sl->engine))
2677                         return a;
2678
2679         return 0;
2680 }
2681
2682 static void rna_SceneLayer_engine_update(Main *bmain, Scene *UNUSED(unused), PointerRNA *UNUSED(ptr))
2683 {
2684         ED_render_engine_changed(bmain);
2685 }
2686
2687 static int rna_SceneLayer_multiple_engines_get(PointerRNA *UNUSED(ptr))
2688 {
2689         return (BLI_listbase_count(&R_engines) > 1);
2690 }
2691
2692 static int rna_SceneLayer_active_layer_index_get(PointerRNA *ptr)
2693 {
2694         Scene *scene = (Scene *)ptr->data;
2695         return scene->active_layer;
2696 }
2697
2698 static void rna_SceneLayer_active_layer_index_set(PointerRNA *ptr, int value)
2699 {
2700         Scene *scene = (Scene *)ptr->data;
2701         int num_layers = BLI_listbase_count(&scene->render_layers);
2702         scene->active_layer = min_ff(value, num_layers - 1);
2703 }
2704
2705 static void rna_SceneLayer_active_layer_index_range(
2706         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2707 {
2708         Scene *scene = (Scene *)ptr->data;
2709
2710         *min = 0;
2711         *max = max_ii(0, BLI_listbase_count(&scene->render_layers) - 1);
2712 }
2713
2714 static PointerRNA rna_SceneLayer_active_layer_get(PointerRNA *ptr)
2715 {
2716         Scene *scene = (Scene *)ptr->data;
2717         SceneLayer *sl = BLI_findlink(&scene->render_layers, scene->active_layer);
2718
2719         return rna_pointer_inherit_refine(ptr, &RNA_SceneLayer, sl);
2720 }
2721
2722 static void rna_SceneLayer_active_layer_set(PointerRNA *ptr, PointerRNA value)
2723 {
2724         Scene *scene = (Scene *)ptr->data;
2725         SceneLayer *sl = (SceneLayer *)value.data;
2726         const int index = BLI_findindex(&scene->render_layers, sl);
2727         if (index != -1) scene->active_layer = index;
2728 }
2729
2730 static SceneLayer *rna_SceneLayer_new(ID *id, Scene *UNUSED(sce), const char *name)
2731 {
2732         Scene *scene = (Scene *)id;
2733         SceneLayer *sl = BKE_scene_layer_add(scene, name);
2734
2735         DAG_id_tag_update(&scene->id, 0);
2736         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2737
2738         return sl;
2739 }
2740
2741 static void rna_SceneLayer_remove(
2742         ID *id, Scene *UNUSED(sce), Main *bmain, ReportList *reports, PointerRNA *sl_ptr)
2743 {
2744         Scene *scene = (Scene *)id;
2745         SceneLayer *sl = sl_ptr->data;
2746
2747         if (!BKE_scene_layer_remove(bmain, scene, sl)) {
2748                 BKE_reportf(reports, RPT_ERROR, "Render layer '%s' could not be removed from scene '%s'",
2749                             sl->name, scene->id.name + 2);
2750                 return;
2751         }
2752
2753         RNA_POINTER_INVALIDATE(sl_ptr);
2754
2755         DAG_id_tag_update(&scene->id, 0);
2756         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2757 }
2758
2759 static void rna_ObjectBase_select_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2760 {
2761         ObjectBase *base = (ObjectBase *)ptr->data;
2762         short mode = (base->flag & BASE_SELECTED) ? BA_SELECT : BA_DESELECT;
2763         ED_object_base_select(base, mode);
2764 }
2765
2766 #else
2767
2768 /* Grease Pencil Interpolation tool settings */
2769 static void rna_def_gpencil_interpolate(BlenderRNA *brna)
2770 {
2771         StructRNA *srna;
2772         PropertyRNA *prop;
2773         
2774         srna = RNA_def_struct(brna, "GPencilInterpolateSettings", NULL);
2775         RNA_def_struct_sdna(srna, "GP_Interpolate_Settings");
2776         RNA_def_struct_path_func(srna, "rna_GPencilInterpolateSettings_path");
2777         RNA_def_struct_ui_text(srna, "Grease Pencil Interpolate Settings",
2778                                "Settings for Grease Pencil interpolation tools");
2779         
2780         /* flags */
2781         prop = RNA_def_property(srna, "interpolate_all_layers", PROP_BOOLEAN, PROP_NONE);
2782         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ALL_LAYERS);
2783         RNA_def_property_ui_text(prop, "Interpolate All Layers", "Interpolate all layers, not only active");
2784         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2785
2786         prop = RNA_def_property(srna, "interpolate_selected_only", PROP_BOOLEAN, PROP_NONE);
2787         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ONLY_SELECTED);
2788         RNA_def_property_ui_text(prop, "Interpolate Selected Strokes", "Interpolate only selected strokes in the original frame");
2789         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2790         
2791         /* interpolation type */
2792         prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
2793         RNA_def_property_enum_sdna(prop, NULL, "type");
2794         RNA_def_property_enum_items(prop, rna_enum_gpencil_interpolation_mode_items);
2795         RNA_def_property_enum_funcs(prop, NULL, "rna_GPencilInterpolateSettings_type_set", NULL);
2796         RNA_def_property_ui_text(prop, "Type",
2797                                  "Interpolation method to use the next time 'Interpolate Sequence' is run");
2798         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2799         
2800         /* easing */
2801         prop = RNA_def_property(srna, "easing", PROP_ENUM, PROP_NONE);
2802         RNA_def_property_enum_sdna(prop, NULL, "easing");
2803         RNA_def_property_enum_items(prop, rna_enum_beztriple_interpolation_easing_items);
2804         RNA_def_property_ui_text(prop, "Easing", 
2805                                  "Which ends of the segment between the preceding and following grease pencil frames "
2806                                  "easing interpolation is applied to");
2807         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2808         
2809         /* easing options */
2810         prop = RNA_def_property(srna, "back", PROP_FLOAT, PROP_NONE);
2811         RNA_def_property_float_sdna(prop, NULL, "back");
2812         RNA_def_property_ui_text(prop, "Back", "Amount of overshoot for 'back' easing");
2813         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2814         
2815         prop = RNA_def_property(srna, "amplitude", PROP_FLOAT, PROP_NONE);
2816         RNA_def_property_float_sdna(prop, NULL, "amplitude");
2817         RNA_def_property_range(prop, 0.0f, FLT_MAX); /* only positive values... */
2818         RNA_def_property_ui_text(prop, "Amplitude", "Amount to boost elastic bounces for 'elastic' easing");
2819         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2820         
2821         prop = RNA_def_property(srna, "period", PROP_FLOAT, PROP_NONE);
2822         RNA_def_property_float_sdna(prop, NULL, "period");
2823         RNA_def_property_ui_text(prop, "Period", "Time between bounces for elastic easing");
2824         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2825         
2826         /* custom curvemap */
2827         prop = RNA_def_property(srna, "interpolation_curve", PROP_POINTER, PROP_NONE);
2828         RNA_def_property_pointer_sdna(prop, NULL, "custom_ipo");
2829         RNA_def_property_struct_type(prop, "CurveMapping");
2830         RNA_def_property_ui_text(prop, "Interpolation Curve", 
2831                                  "Custom curve to control 'sequence' interpolation between Grease Pencil frames");
2832         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2833 }
2834
2835 /* Grease Pencil Drawing Brushes */
2836 static void rna_def_gpencil_brush(BlenderRNA *brna)
2837 {
2838         StructRNA *srna;
2839         PropertyRNA *prop;
2840
2841         srna = RNA_def_struct(brna, "GPencilBrush", NULL);
2842         RNA_def_struct_sdna(srna, "bGPDbrush");
2843         RNA_def_struct_ui_text(srna, "Grease Pencil Brush",
2844                                "Collection of brushes being used to control the line style of new strokes");
2845         RNA_def_struct_ui_icon(srna, ICON_BRUSH_DATA);
2846
2847         /* Name */
2848         prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
2849         RNA_def_property_string_sdna(prop, NULL, "info");
2850         RNA_def_property_ui_text(prop, "Name", "Brush name");
2851         RNA_def_property_string_funcs(prop, NULL, NULL, "rna_GPencilBrush_name_set");
2852         RNA_def_struct_name_property(srna, prop);
2853         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2854
2855         /* Line Thickness */
2856         prop = RNA_def_property(srna, "line_width", PROP_INT, PROP_PIXEL);
2857         RNA_def_property_int_sdna(prop, NULL, "thickness");
2858         RNA_def_property_range(prop, 1, 300);
2859         RNA_def_property_ui_range(prop, 1, 10, 1, 0);
2860         RNA_def_property_ui_text(prop, "Thickness", "Thickness of strokes (in pixels)");
2861         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2862
2863         /* Sensitivity factor for new strokes */
2864         prop = RNA_def_property(srna, "pen_sensitivity_factor", PROP_FLOAT, PROP_NONE);
2865         RNA_def_property_float_sdna(prop, NULL, "draw_sensitivity");
2866         RNA_def_property_range(prop, 0.1f, 3.0f);
2867         RNA_def_property_ui_text(prop, "Sensitivity", "Pressure sensitivity factor for new strokes");
2868         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2869
2870         /* Strength factor for new strokes */
2871         prop = RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
2872         RNA_def_property_float_sdna(prop, NULL, "draw_strength");
2873         RNA_def_property_range(prop, 0.0f, 1.0f);
2874         RNA_def_property_ui_text(prop, "Strength", "Color strength for new strokes (affect alpha factor of color)");
2875         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2876
2877         /* Jitter factor for new strokes */
2878         prop = RNA_def_property(srna, "jitter", PROP_FLOAT, PROP_NONE);
2879         RNA_def_property_float_sdna(prop, NULL, "draw_jitter");
2880         RNA_def_property_range(prop, 0.0f, 1.0f);
2881         RNA_def_property_ui_text(prop, "Jitter", "Jitter factor for new strokes");
2882         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2883
2884         /* Randomnes factor for sensitivity and strength */
2885         prop = RNA_def_property(srna, "random_press", PROP_FLOAT, PROP_NONE);
2886         RNA_def_property_float_sdna(prop, NULL, "draw_random_press");
2887         RNA_def_property_range(prop, 0.0f, 1.0f);
2888         RNA_def_property_ui_text(prop, "Randomness", "Randomness factor for pressure and strength in new strokes");
2889         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2890
2891         /* Randomnes factor for subdivision */
2892         prop = RNA_def_property(srna, "random_subdiv", PROP_FLOAT, PROP_NONE);
2893         RNA_def_property_float_sdna(prop, NULL, "draw_random_sub");
2894         RNA_def_property_range(prop, 0.0f, 1.0f);
2895         RNA_def_property_ui_text(prop, "Random Subdivision", "Randomness factor for new strokes after subdivision");
2896         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2897
2898         /* Angle when brush is full size */
2899         prop = RNA_def_property(srna, "angle", PROP_FLOAT, PROP_ANGLE);
2900         RNA_def_property_float_sdna(prop, NULL, "draw_angle");
2901         RNA_def_property_range(prop, -M_PI_2, M_PI_2);
2902         RNA_def_property_ui_text(prop, "Angle",
2903                                  "Direction of the stroke at which brush gives maximal thickness "
2904                                  "(0° for horizontal)");
2905         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2906
2907         /* Factor to change brush size depending of angle */
2908         prop = RNA_def_property(srna, "angle_factor", PROP_FLOAT, PROP_NONE);
2909         RNA_def_property_float_sdna(prop, NULL, "draw_angle_factor");
2910         RNA_def_property_range(prop, 0.0f, 1.0f);
2911         RNA_def_property_ui_text(prop, "Angle Factor",
2912                                  "Reduce brush thickness by this factor when stroke is perpendicular to 'Angle' direction");
2913         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2914
2915         /* Smoothing factor for new strokes */
2916         prop = RNA_def_property(srna, "pen_smooth_factor", PROP_FLOAT, PROP_NONE);
2917         RNA_def_property_float_sdna(prop, NULL, "draw_smoothfac");
2918         RNA_def_property_range(prop, 0.0, 2.0f);
2919         RNA_def_property_ui_text(prop, "Smooth",
2920                                  "Amount of smoothing to apply to newly created strokes, to reduce jitter/noise");
2921         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2922
2923         /* Iterations of the Smoothing factor */
2924         prop = RNA_def_property(srna, "pen_smooth_steps", PROP_INT, PROP_NONE);
2925         RNA_def_property_int_sdna(prop, NULL, "draw_smoothlvl");
2926         RNA_def_property_range(prop, 1, 3);
2927         RNA_def_property_ui_text(prop, "Iterations",
2928                                  "Number of times to smooth newly created strokes");
2929         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2930
2931         /* Subdivision level for new strokes */
2932         prop = RNA_def_property(srna, "pen_subdivision_steps", PROP_INT, PROP_NONE);
2933         RNA_def_property_int_sdna(prop, NULL, "sublevel");
2934         RNA_def_property_range(prop, 0, 3);
2935         RNA_def_property_ui_text(prop, "Subdivision Steps",
2936                                  "Number of times to subdivide newly created strokes, for less jagged strokes");
2937         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2938
2939         /* Curves for pressure */
2940         prop = RNA_def_property(srna, "curve_sensitivity", PROP_POINTER, PROP_NONE);
2941         RNA_def_property_pointer_sdna(prop, NULL, "cur_sensitivity");
2942         RNA_def_property_struct_type(prop, "CurveMapping");
2943         RNA_def_property_ui_text(prop, "Curve Sensitivity", "Curve used for the sensitivity");
2944         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2945
2946         prop = RNA_def_property(srna, "curve_strength", PROP_POINTER, PROP_NONE);
2947         RNA_def_property_pointer_sdna(prop, NULL, "cur_strength");
2948         RNA_def_property_struct_type(prop, "CurveMapping");
2949         RNA_def_property_ui_text(prop, "Curve Strength", "Curve used for the strength");
2950         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2951
2952         prop = RNA_def_property(srna, "curve_jitter", PROP_POINTER, PROP_NONE);
2953         RNA_def_property_pointer_sdna(prop, NULL, "cur_jitter");
2954         RNA_def_property_struct_type(prop, "CurveMapping");
2955         RNA_def_property_ui_text(prop, "Curve Jitter", "Curve used for the jitter effect");
2956         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2957
2958         /* Flags */
2959         prop = RNA_def_property(srna, "use_pressure", PROP_BOOLEAN, PROP_NONE);
2960         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_PRESSURE);
2961         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
2962         RNA_def_property_ui_text(prop, "Use Pressure", "Use tablet pressure");
2963         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2964
2965         prop = RNA_def_property(srna, "use_strength_pressure", PROP_BOOLEAN, PROP_NONE);
2966         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_STENGTH_PRESSURE);
2967         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
2968         RNA_def_property_ui_text(prop, "Use Pressure Strength", "Use tablet pressure for color strength");
2969         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2970
2971         prop = RNA_def_property(srna, "use_jitter_pressure", PROP_BOOLEAN, PROP_NONE);
2972         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_JITTER_PRESSURE);
2973         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
2974         RNA_def_property_ui_text(prop, "Use Pressure Jitter", "Use tablet pressure for jitter");
2975         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2976
2977         prop = RNA_def_property(srna, "use_random_pressure", PROP_BOOLEAN, PROP_NONE);
2978         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_RANDOM_PRESSURE);
2979         RNA_def_property_ui_icon(prop, ICON_PARTICLES, 0);
2980         RNA_def_property_ui_text(prop, "Random Pressure", "Use random value for pressure");
2981         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2982
2983         prop = RNA_def_property(srna, "use_random_strength", PROP_BOOLEAN, PROP_NONE);
2984         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_RANDOM_STRENGTH);
2985         RNA_def_property_ui_icon(prop, ICON_PARTICLES, 0);
2986         RNA_def_property_ui_text(prop, "Random Strength", "Use random value for strength");
2987         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
2988
2989 }
2990
2991 /* Grease Pencil Drawing Brushes API */
2992 static void rna_def_gpencil_brushes(BlenderRNA *brna, PropertyRNA *cprop)
2993 {
2994         StructRNA *srna;
2995         PropertyRNA *prop;
2996
2997         FunctionRNA *func;
2998         PropertyRNA *parm;
2999
3000         RNA_def_property_srna(cprop, "GreasePencilBrushes");
3001         srna = RNA_def_struct(brna, "GreasePencilBrushes", NULL);
3002         RNA_def_struct_sdna(srna, "ToolSettings");
3003         RNA_def_struct_ui_text(srna, "Grease Pencil Brushes", "Collection of grease pencil brushes");
3004
3005         func = RNA_def_function(srna, "new", "rna_GPencil_brush_new");
3006         RNA_def_function_ui_description(func, "Add a new grease pencil brush");
3007         parm = RNA_def_string(func, "name", "GPencilBrush", MAX_NAME, "Name", "Name of the brush");
3008         RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
3009         RNA_def_boolean(func, "set_active", 0, "Set Active", "Set the newly created brush to the active brush");
3010         parm = RNA_def_pointer(func, "palette", "GPencilBrush", "", "The newly created brush");
3011         RNA_def_function_return(func, parm);
3012
3013         func = RNA_def_function(srna, "remove", "rna_GPencil_brush_remove");
3014         RNA_def_function_ui_description(func, "Remove a grease pencil brush");
3015         RNA_def_function_flag(func, FUNC_USE_REPORTS);
3016         parm = RNA_def_pointer(func, "brush", "GPencilBrush", "", "The brush to remove");
3017         RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
3018         RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
3019
3020         prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
3021         RNA_def_property_struct_type(prop, "GPencilBrush");
3022         RNA_def_property_pointer_funcs(prop, "rna_GPencilBrushes_active_get", "rna_GPencilBrushes_active_set", NULL, NULL);
3023         RNA_def_property_flag(prop, PROP_EDITABLE);
3024         RNA_def_property_ui_text(prop, "Active Brush", "Current active brush");
3025
3026         prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
3027         RNA_def_property_int_funcs(prop,
3028                 "rna_GPencilBrushes_index_get",
3029                 "rna_GPencilBrushes_index_set",
3030                 "rna_GPencilBrushes_index_range");
3031         RNA_def_property_ui_text(prop, "Active Brush Index", "Index of active brush");
3032 }
3033
3034 static void rna_def_transform_orientation(BlenderRNA *brna)
3035 {
3036         StructRNA *srna;
3037         PropertyRNA *prop;
3038         
3039         srna = RNA_def_struct(brna, "TransformOrientation", NULL);
3040         
3041         prop = RNA_def_property(srna, "matrix", PROP_FLOAT, PROP_MATRIX);
3042         RNA_def_property_float_sdna(prop, NULL, "mat");
3043         RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_3x3);
3044         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_VIEW3D, NULL);
3045         
3046         prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
3047         RNA_def_struct_name_property(srna, prop);
3048         RNA_def_property_ui_text(prop, "Name", "Name of the custom transform orientation");
3049         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_VIEW3D, NULL);
3050 }
3051
3052 static void rna_def_tool_settings(BlenderRNA  *brna)
3053 {
3054         StructRNA *srna;
3055         PropertyRNA *prop;
3056
3057         static EnumPropertyItem uv_select_mode_items[] = {
3058                 {UV_SELECT_VERTEX, "VERTEX", ICON_UV_VERTEXSEL, "Vertex", "Vertex selection mode"},
3059                 {UV_SELECT_EDGE, "EDGE", ICON_UV_EDGESEL, "Edge", "Edge selection mode"},
3060                 {UV_SELECT_FACE, "FACE", ICON_UV_FACESEL, "Face", "Face selection mode"},
3061                 {UV_SELECT_ISLAND, "ISLAND", ICON_UV_ISLANDSEL, "Island", "Island selection mode"},
3062                 {0, NULL, 0, NULL, NULL}
3063         };
3064         
3065         /* the construction of this enum is quite special - everything is stored as bitflags,
3066          * with 1st position only for for on/off (and exposed as boolean), while others are mutually
3067          * exclusive options but which will only have any effect when autokey is enabled
3068          */
3069         static EnumPropertyItem auto_key_items[] = {
3070                 {AUTOKEY_MODE_NORMAL & ~AUTOKEY_ON, "ADD_REPLACE_KEYS", 0, "Add & Replace", ""},
3071                 {AUTOKEY_MODE_EDITKEYS & ~AUTOKEY_ON, "REPLACE_KEYS", 0, "Replace", ""},
3072                 {0, NULL, 0, NULL, NULL}
3073         };
3074
3075         static EnumPropertyItem retarget_roll_items[] = {
3076                 {SK_RETARGET_ROLL_NONE, "NONE", 0, "None", "Don't adjust roll"},
3077                 {SK_RETARGET_ROLL_VIEW, "VIEW", 0, "View", "Roll bones to face the view"},
3078                 {SK_RETARGET_ROLL_JOINT, "JOINT", 0, "Joint", "Roll bone to original joint plane offset"},
3079                 {0, NULL, 0, NULL, NULL}
3080         };
3081         
3082         static EnumPropertyItem sketch_convert_items[] = {
3083                 {SK_CONVERT_CUT_FIXED, "FIXED", 0, "Fixed", "Subdivide stroke in fixed number of bones"},
3084                 {SK_CONVERT_CUT_LENGTH, "LENGTH", 0, "Length", "Subdivide stroke in bones of specific length"},
3085                 {SK_CONVERT_CUT_ADAPTATIVE, "ADAPTIVE", 0, "Adaptive",
3086                  "Subdivide stroke adaptively, with more subdivision in curvier parts"},
3087                 {SK_CONVERT_RETARGET, "RETARGET", 0, "Retarget", "Retarget template bone chain to stroke"},
3088                 {0, NULL, 0, NULL, NULL}
3089         };
3090
3091         static EnumPropertyItem edge_tag_items[] = {
3092                 {EDGE_MODE_SELECT, "SELECT", 0, "Select", ""},
3093                 {EDGE_MODE_TAG_SEAM, "SEAM", 0, "Tag Seam", ""},
3094                 {EDGE_MODE_TAG_SHARP, "SHARP", 0, "Tag Sharp", ""},
3095                 {EDGE_MODE_TAG_CREASE, "CREASE", 0, "Tag Crease", ""},
3096                 {EDGE_MODE_TAG_BEVEL, "BEVEL", 0, "Tag Bevel", ""},
3097                 {EDGE_MODE_TAG_FREESTYLE, "FREESTYLE", 0, "Tag Freestyle Edge Mark", ""},
3098                 {0, NULL, 0, NULL, NULL}
3099         };
3100
3101         static EnumPropertyItem draw_groupuser_items[] = {
3102                 {OB_DRAW_GROUPUSER_NONE, "NONE", 0, "None", ""},
3103                 {OB_DRAW_GROUPUSER_ACTIVE, "ACTIVE", 0, "Active", "Show vertices with no weights in the active group"},
3104                 {OB_DRAW_GROUPUSER_ALL, "ALL", 0, "All", "Show vertices with no weights in any group"},
3105                 {0, NULL, 0, NULL, NULL}
3106         };
3107
3108         static EnumPropertyItem vertex_group_select_items[] = {
3109                 {WT_VGROUP_ALL, "ALL", 0, "All", "All Vertex Groups"},
3110                 {WT_VGROUP_BONE_DEFORM, "BONE_DEFORM", 0, "Deform", "Vertex Groups assigned to Deform Bones"},
3111                 {WT_VGROUP_BONE_DEFORM_OFF, "OTHER_DEFORM", 0, "Other", "Vertex Groups assigned to non Deform Bones"},
3112                 {0, NULL, 0, NULL, NULL}
3113         };
3114         
3115         static EnumPropertyItem gpencil_source_3d_items[] = {
3116                 {GP_TOOL_SOURCE_SCENE, "SCENE", 0, "Scene",
3117                  "Grease Pencil data attached to the current scene is used, "
3118                  "unless the active object already has Grease Pencil data (i.e. for old files)"},
3119                 {GP_TOOL_SOURCE_OBJECT, "OBJECT", 0, "Object",
3120                  "Grease Pencil data-blocks attached to the active object are used "
3121                  "(required when using pre 2.73 add-ons, e.g. BSurfaces)"},
3122                 {0, NULL, 0, NULL, NULL}
3123         };
3124         
3125         static EnumPropertyItem gpencil_stroke_placement_items[] = {
3126                 {GP_PROJECT_VIEWSPACE, "CURSOR", 0, "Cursor", "Draw stroke at the 3D cursor"},
3127                 {0, "VIEW", 0, "View", "Stick stroke to the view "}, /* weird, GP_PROJECT_VIEWALIGN is inverted */
3128                 {GP_PROJECT_VIEWSPACE | GP_PROJECT_DEPTH_VIEW, "SURFACE", 0, "Surface", "Stick stroke to surfaces"},
3129                 {GP_PROJECT_VIEWSPACE | GP_PROJECT_DEPTH_STROKE, "STROKE", 0, "Stroke", "Stick stroke to other strokes"},
3130                 {0, NULL, 0, NULL, NULL}
3131         };
3132         
3133         
3134         srna = RNA_def_struct(brna, "ToolSettings", NULL);
3135         RNA_def_struct_path_func(srna, "rna_ToolSettings_path");
3136         RNA_def_struct_ui_text(srna, "Tool Settings", "");
3137         
3138         prop = RNA_def_property(srna, "sculpt", PROP_POINTER, PROP_NONE);
3139         RNA_def_property_struct_type(prop, "Sculpt");
3140         RNA_def_property_ui_text(prop, "Sculpt", "");
3141         
3142         prop = RNA_def_property(srna, "use_auto_normalize", PROP_BOOLEAN, PROP_NONE);
3143         RNA_def_property_boolean_sdna(prop, NULL, "auto_normalize", 1);
3144         RNA_def_property_ui_text(prop, "WPaint Auto-Normalize",
3145                                  "Ensure all bone-deforming vertex groups add up "
3146                                  "to 1.0 while weight painting");
3147         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3148
3149         prop = RNA_def_property(srna, "use_multipaint", PROP_BOOLEAN, PROP_NONE);
3150         RNA_def_property_boolean_sdna(prop, NULL, "multipaint", 1);
3151         RNA_def_property_ui_text(prop, "WPaint Multi-Paint",
3152                                  "Paint across the weights of all selected bones, "
3153                                  "maintaining their relative influence");
3154         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3155
3156         prop = RNA_def_property(srna, "vertex_group_user", PROP_ENUM, PROP_NONE);
3157         RNA_def_property_enum_sdna(prop, NULL, "weightuser");
3158         RNA_def_property_enum_items(prop, draw_groupuser_items);
3159         RNA_def_property_ui_text(prop, "Mask Non-Group Vertices", "Display unweighted vertices");
3160         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3161
3162         prop = RNA_def_property(srna, "vertex_group_subset", PROP_ENUM, PROP_NONE);
3163         RNA_def_property_enum_sdna(prop, NULL, "vgroupsubset");
3164         RNA_def_property_enum_items(prop, vertex_group_select_items);
3165         RNA_def_property_ui_text(prop, "Subset", "Filter Vertex groups for Display");
3166         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3167
3168         prop = RNA_def_property(srna, "vertex_paint", PROP_POINTER, PROP_NONE);
3169         RNA_def_property_pointer_sdna(prop, NULL, "vpaint");    RNA_def_property_ui_text(prop, "Vertex Paint", "");
3170
3171         prop = RNA_def_property(srna, "weight_paint", PROP_POINTER, PROP_NONE);
3172         RNA_def_property_pointer_sdna(prop, NULL, "wpaint");
3173         RNA_def_property_ui_text(prop, "Weight Paint", "");
3174
3175         prop = RNA_def_property(srna, "image_paint", PROP_POINTER, PROP_NONE);
3176         RNA_def_property_pointer_sdna(prop, NULL, "imapaint");
3177         RNA_def_property_ui_text(prop, "Image Paint", "");
3178
3179         prop = RNA_def_property(srna, "uv_sculpt", PROP_POINTER, PROP_NONE);
3180         RNA_def_property_pointer_sdna(prop, NULL, "uvsculpt");
3181         RNA_def_property_ui_text(prop, "UV Sculpt", "");
3182
3183         prop = RNA_def_property(srna, "particle_edit", PROP_POINTER, PROP_NONE);
3184         RNA_def_property_pointer_sdna(prop, NULL, "particle");
3185         RNA_def_property_ui_text(prop, "Particle Edit", "");
3186
3187         prop = RNA_def_property(srna, "use_uv_sculpt", PROP_BOOLEAN, PROP_NONE);
3188         RNA_def_property_boolean_sdna(prop, NULL, "use_uv_sculpt", 1);
3189         RNA_def_property_ui_text(prop, "UV Sculpt", "Enable brush for UV sculpting");
3190         RNA_def_property_ui_icon(prop, ICON_TPAINT_HLT, 0);
3191         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_IMAGE, "rna_SpaceImageEditor_uv_sculpt_update");
3192
3193         prop = RNA_def_property(srna, "uv_sculpt_lock_borders", PROP_BOOLEAN, PROP_NONE);
3194         RNA_def_property_boolean_sdna(prop, NULL, "uv_sculpt_settings", UV_SCULPT_LOCK_BORDERS);
3195         RNA_def_property_ui_text(prop, "Lock Borders", "Disable editing of boundary edges");
3196
3197         prop = RNA_def_property(srna, "uv_sculpt_all_islands", PROP_BOOLEAN, PROP_NONE);
3198         RNA_def_property_boolean_sdna(prop, NULL, "uv_sculpt_settings", UV_SCULPT_ALL_ISLANDS);
3199         RNA_def_property_ui_text(prop, "Sculpt All Islands", "Brush operates on all islands");
3200
3201         prop = RNA_def_property(srna, "uv_sculpt_tool", PROP_ENUM, PROP_NONE);
3202         RNA_def_property_enum_sdna(prop, NULL, "uv_sculpt_tool");
3203         RNA_def_property_enum_items(prop, uv_sculpt_tool_items);
3204         RNA_def_property_ui_text(prop, "UV Sculpt Tools", "Select Tools for the UV sculpt brushes");
3205
3206         prop = RNA_def_property(srna, "uv_relax_method", PROP_ENUM, PROP_NONE);
3207         RNA_def_property_enum_sdna(prop, NULL, "uv_relax_method");
3208         RNA_def_property_enum_items(prop, uv_sculpt_relaxation_items);
3209         RNA_def_property_ui_text(prop, "Relaxation Method", "Algorithm used for UV relaxation");
3210
3211         /* Transform */
3212         prop = RNA_def_property(srna, "proportional_edit", PROP_ENUM, PROP_NONE);
3213         RNA_def_property_enum_sdna(prop, NULL, "proportional");
3214         RNA_def_property_enum_items(prop, rna_enum_proportional_editing_items);
3215         RNA_def_property_ui_text(prop, "Proportional Editing",
3216                                  "Proportional Editing mode, allows transforms with distance fall-off");
3217         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3218
3219         prop = RNA_def_property(srna, "use_proportional_edit_objects", PROP_BOOLEAN, PROP_NONE);
3220         RNA_def_property_boolean_sdna(prop, NULL, "proportional_objects", 0);
3221         RNA_def_property_ui_text(prop, "Proportional Editing Objects", "Proportional editing object mode");
3222         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3223         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3224
3225         prop = RNA_def_property(srna, "use_proportional_edit_mask", PROP_BOOLEAN, PROP_NONE);
3226         RNA_def_property_boolean_sdna(prop, NULL, "proportional_mask", 0);
3227         RNA_def_property_ui_text(prop, "Proportional Editing Objects", "Proportional editing mask mode");
3228         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3229         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3230
3231         prop = RNA_def_property(srna, "use_proportional_action", PROP_BOOLEAN, PROP_NONE);
3232         RNA_def_property_boolean_sdna(prop, NULL, "proportional_action", 0);
3233         RNA_def_property_ui_text(prop, "Proportional Editing Actions", "Proportional editing in action editor");
3234         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3235         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3236
3237         prop = RNA_def_property(srna, "use_proportional_fcurve", PROP_BOOLEAN, PROP_NONE);
3238         RNA_def_property_boolean_sdna(prop, NULL, "proportional_fcurve", 0);
3239         RNA_def_property_ui_text(prop, "Proportional Editing FCurves", "Proportional editing in FCurve editor");
3240         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3241         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3242
3243         prop = RNA_def_property(srna, "lock_markers", PROP_BOOLEAN, PROP_NONE);
3244         RNA_def_property_boolean_sdna(prop, NULL, "lock_markers", 0);
3245         RNA_def_property_ui_text(prop, "Lock Markers", "Prevent marker editing");
3246
3247         prop = RNA_def_property(srna, "proportional_edit_falloff", PROP_ENUM, PROP_NONE);
3248         RNA_def_property_enum_sdna(prop, NULL, "prop_mode");
3249         RNA_def_property_enum_items(prop, rna_enum_proportional_falloff_items);
3250         RNA_def_property_ui_text(prop, "Proportional Editing Falloff", "Falloff type for proportional editing mode");
3251         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3252
3253         prop = RNA_def_property(srna, "proportional_size", PROP_FLOAT, PROP_DISTANCE);
3254         RNA_def_property_float_sdna(prop, NULL, "proportional_size");
3255         RNA_def_property_ui_text(prop, "Proportional Size", "Display size for proportional editing circle");
3256         RNA_def_property_range(prop, 0.00001, 5000.0);
3257         
3258         prop = RNA_def_property(srna, "normal_size", PROP_FLOAT, PROP_DISTANCE);
3259         RNA_def_property_float_sdna(prop, NULL, "normalsize");
3260         RNA_def_property_ui_text(prop, "Normal Size", "Display size for normals in the 3D view");
3261         RNA_def_property_range(prop, 0.00001, 1000.0);
3262         RNA_def_property_ui_range(prop, 0.01, 10.0, 10.0, 2);
3263         RNA_def_property_update(prop, NC_GEOM | ND_DATA, NULL);
3264
3265         prop = RNA_def_property(srna, "double_threshold", PROP_FLOAT, PROP_DISTANCE);
3266         RNA_def_property_float_sdna(prop, NULL, "doublimit");
3267         RNA_def_property_ui_text(prop, "Double Threshold", "Limit for removing duplicates and 'Auto Merge'");
3268         RNA_def_property_range(prop, 0.0, 1.0);
3269         RNA_def_property_ui_range(prop, 0.0, 0.1, 0.01, 6);
3270
3271         prop = RNA_def_property(srna, "use_mesh_automerge", PROP_BOOLEAN, PROP_NONE);
3272         RNA_def_property_boolean_sdna(prop, NULL, "automerge", 0);
3273         RNA_def_property_ui_text(prop, "AutoMerge Editing", "Automatically merge vertices moved to the same location");
3274         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3275
3276         prop = RNA_def_property(srna, "use_snap", PROP_BOOLEAN, PROP_NONE);
3277         RNA_def_property_boolean_sdna(prop, NULL, "snap_flag", SCE_SNAP);
3278         RNA_def_property_ui_text(prop, "Snap", "Snap during transform");
3279         RNA_def_property_ui_icon(prop, ICON_SNAP_OFF, 1);
3280         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3281
3282         prop = RNA_def_property(srna, "use_snap_align_rotation", PROP_BOOLEAN, PROP_NONE);
3283         RNA_def_property_boolean_sdna(prop, NULL, "snap_flag", SCE_SNAP_ROTATE);
3284         RNA_def_property_ui_text(prop, "Snap Align Rotation", "Align rotation with the snapping target");
3285         RNA_def_property_ui_icon(prop, ICON_SNAP_NORMAL, 0);
3286         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3287
3288         prop = RNA_def_property(srna, "use_snap_grid_absolute", PROP_BOOLEAN, PROP_NONE);
3289         RNA_def_property_boolean_sdna(prop, NULL, "snap_flag", SCE_SNAP_ABS_GRID);
3290         RNA_def_property_ui_text(prop, "Absolute Grid Snap",
3291                                  "Absolute grid alignment while translating (based on the pivot center)");
3292         RNA_def_property_ui_icon(prop, ICON_SNAP_GRID, 0);
3293         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3294
3295         prop = RNA_def_property(srna, "snap_element", PROP_ENUM, PROP_NONE);
3296         RNA_def_property_enum_sdna(prop, NULL, "snap_mode");
3297         RNA_def_property_enum_items(prop, rna_enum_snap_element_items);
3298         RNA_def_property_ui_text(prop, "Snap Element", "Type of element to snap to");
3299         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3300         
3301         /* node editor uses own set of snap modes */
3302         prop = RNA_def_property(srna, "snap_node_element", PROP_ENUM, PROP_NONE);
3303         RNA_def_property_enum_sdna(prop, NULL, "snap_node_mode");
3304         RNA_def_property_enum_items(prop, rna_enum_snap_node_element_items);
3305         RNA_def_property_ui_text(prop, "Snap Node Element", "Type of element to snap to");
3306         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3307         
3308         /* image editor uses own set of snap modes */
3309         prop = RNA_def_property(srna, "snap_uv_element", PROP_ENUM, PROP_NONE);
3310         RNA_def_property_enum_sdna(prop, NULL, "snap_uv_mode");
3311         RNA_def_property_enum_items(prop, snap_uv_element_items);
3312         RNA_def_property_ui_text(prop, "Snap UV Element", "Type of element to snap to");
3313         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3314
3315         prop = RNA_def_property(srna, "snap_target", PROP_ENUM, PROP_NONE);
3316         RNA_def_property_enum_sdna(prop, NULL, "snap_target");
3317         RNA_def_property_enum_items(prop, rna_enum_snap_target_items);
3318         RNA_def_property_ui_text(prop, "Snap Target", "Which part to snap onto the target");
3319         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3320
3321         prop = RNA_def_property(srna, "use_snap_peel_object", PROP_BOOLEAN, PROP_NONE);
3322         RNA_def_property_boolean_sdna(prop, NULL, "snap_flag", SCE_SNAP_PEEL_OBJECT);
3323         RNA_def_property_ui_text(prop, "Snap Peel Object", "Consider objects as whole when finding volume center");
3324         RNA_def_property_ui_icon(prop, ICON_SNAP_PEEL_OBJECT, 0);
3325         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3326         
3327         prop = RNA_def_property(srna, "use_snap_project", PROP_BOOLEAN, PROP_NONE);
3328         RNA_def_property_boolean_sdna(prop, NULL, "snap_flag", SCE_SNAP_PROJECT);
3329         RNA_def_property_ui_text(prop, "Project Individual Elements",
3330                                  "Project individual elements on the surface of other objects");
3331         RNA_def_property_ui_icon(prop, ICON_RETOPO, 0);
3332         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3333
3334         prop = RNA_def_property(srna, "use_snap_self", PROP_BOOLEAN, PROP_NONE);
3335         RNA_def_property_boolean_negative_sdna(prop, NULL, "snap_flag", SCE_SNAP_NO_SELF);
3336         RNA_def_property_ui_text(prop, "Project to Self", "Snap onto itself (editmode)");
3337         RNA_def_property_ui_icon(prop, ICON_ORTHO, 0);
3338         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3339
3340         /* Grease Pencil */
3341         prop = RNA_def_property(srna, "use_gpencil_continuous_drawing", PROP_BOOLEAN, PROP_NONE);
3342         RNA_def_property_boolean_sdna(prop, NULL, "gpencil_flags", GP_TOOL_FLAG_PAINTSESSIONS_ON);
3343         RNA_def_property_ui_text(prop, "Use Continuous Drawing",
3344                                  "Allow drawing multiple strokes at a time with Grease Pencil");
3345         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* xxx: need toolbar to be redrawn... */
3346         
3347         prop = RNA_def_property(srna, "use_gpencil_additive_drawing", PROP_BOOLEAN, PROP_NONE);
3348         RNA_def_property_boolean_sdna(prop, NULL, "gpencil_flags", GP_TOOL_FLAG_RETAIN_LAST);
3349         RNA_def_property_ui_text(prop, "Use Additive Drawing",
3350                                  "When creating new frames, the strokes from the previous/active frame "
3351                                  "are included as the basis for the new one");
3352         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
3353         
3354         prop = RNA_def_property(srna, "use_gpencil_draw_onback", PROP_BOOLEAN, PROP_NONE);
3355         RNA_def_property_boolean_sdna(prop, NULL, "gpencil_flags", GP_TOOL_FLAG_PAINT_ONBACK);
3356         RNA_def_property_ui_text(prop, "Draw Strokes on Back",
3357                 "When draw new strokes, the new stroke is drawn below of all strokes in the layer");
3358         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
3359
3360         prop = RNA_def_property(srna, "grease_pencil_source", PROP_ENUM, PROP_NONE);
3361         RNA_def_property_enum_bitflag_sdna(prop, NULL, "gpencil_src");
3362         RNA_def_property_enum_items(prop, gpencil_source_3d_items);
3363         RNA_def_property_ui_text(prop, "Grease Pencil Source",
3364                                  "Data-block where active Grease Pencil data is found from");
3365         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3366         
3367         prop = RNA_def_property(srna, "gpencil_sculpt", PROP_POINTER, PROP_NONE);
3368         RNA_def_property_pointer_sdna(prop, NULL, "gp_sculpt");
3369         RNA_def_property_struct_type(prop, "GPencilSculptSettings");
3370         RNA_def_property_ui_text(prop, "Grease Pencil Sculpt",
3371                                  "Settings for stroke sculpting tools and brushes");
3372         
3373         prop = RNA_def_property(srna, "gpencil_interpolate", PROP_POINTER, PROP_NONE);
3374         RNA_def_property_pointer_sdna(prop, NULL, "gp_interpolate");