Correct over-alloc struct declaration
[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 curve map"},
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 EnumPropertyItem rna_enum_layer_collection_mode_settings_type_items[] = {
442         {COLLECTION_MODE_OBJECT, "OBJECT", 0, "Object", ""},
443         {COLLECTION_MODE_EDIT, "EDIT", 0, "Edit", ""},
444         {0, NULL, 0, NULL, NULL}
445 };
446
447 #ifdef RNA_RUNTIME
448
449 #include "DNA_anim_types.h"
450 #include "DNA_color_types.h"
451 #include "DNA_node_types.h"
452 #include "DNA_object_types.h"
453 #include "DNA_mesh_types.h"
454 #include "DNA_text_types.h"
455
456 #include "RNA_access.h"
457
458 #include "MEM_guardedalloc.h"
459
460 #include "BKE_brush.h"
461 #include "BKE_collection.h"
462 #include "BKE_colortools.h"
463 #include "BKE_context.h"
464 #include "BKE_global.h"
465 #include "BKE_image.h"
466 #include "BKE_layer.h"
467 #include "BKE_main.h"
468 #include "BKE_node.h"
469 #include "BKE_pointcache.h"
470 #include "BKE_scene.h"
471 #include "BKE_depsgraph.h"
472 #include "BKE_idprop.h"
473 #include "BKE_mesh.h"
474 #include "BKE_sound.h"
475 #include "BKE_screen.h"
476 #include "BKE_sequencer.h"
477 #include "BKE_animsys.h"
478 #include "BKE_freestyle.h"
479 #include "BKE_gpencil.h"
480
481 #include "ED_info.h"
482 #include "ED_node.h"
483 #include "ED_view3d.h"
484 #include "ED_mesh.h"
485 #include "ED_keyframing.h"
486 #include "ED_image.h"
487
488 #include "DEG_depsgraph.h"
489 #include "DEG_depsgraph_query.h"
490
491 #ifdef WITH_FREESTYLE
492 #include "FRS_freestyle.h"
493 #endif
494
495 /* Grease Pencil Interpolation settings */
496 static char *rna_GPencilInterpolateSettings_path(PointerRNA *UNUSED(ptr))
497 {
498         return BLI_strdup("tool_settings.gpencil_interpolate");
499 }
500
501 static void rna_GPencilInterpolateSettings_type_set(PointerRNA *ptr, int value)
502 {
503         GP_Interpolate_Settings *settings = (GP_Interpolate_Settings *)ptr->data;
504         
505         /* NOTE: This cast should be fine, as we have a small + finite set of values (eGP_Interpolate_Type)
506          * that should fit well within a char
507          */
508         settings->type = (char)value;
509         
510         /* init custom interpolation curve here now the first time it's used */
511         if ((settings->type == GP_IPO_CURVEMAP) &&
512             (settings->custom_ipo == NULL))
513         {
514                 settings->custom_ipo = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
515         }
516 }
517
518 /* Grease pencil Drawing Brushes */
519 static bGPDbrush *rna_GPencil_brush_new(ToolSettings *ts, const char *name, int setactive)
520 {
521         bGPDbrush *brush = BKE_gpencil_brush_addnew(ts, name, setactive != 0);
522
523         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
524
525         return brush;
526 }
527
528 static void rna_GPencil_brush_remove(ToolSettings *ts, ReportList *reports, PointerRNA *brush_ptr)
529 {
530         bGPDbrush *brush = brush_ptr->data;
531         if (BLI_findindex(&ts->gp_brushes, brush) == -1) {
532                 BKE_report(reports, RPT_ERROR, "Brush not found in grease pencil data");
533                 return;
534         }
535
536         BKE_gpencil_brush_delete(ts, brush);
537         RNA_POINTER_INVALIDATE(brush_ptr);
538
539         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
540 }
541
542 static PointerRNA rna_GPencilBrushes_active_get(PointerRNA *ptr)
543 {
544         ToolSettings *ts = (ToolSettings *) ptr->data;
545
546         bGPDbrush *brush;
547
548         for (brush = ts->gp_brushes.first; brush; brush = brush->next) {
549                 if (brush->flag & GP_BRUSH_ACTIVE) {
550                         break;
551                 }
552         }
553
554         if (brush) {
555                 return rna_pointer_inherit_refine(ptr, &RNA_GPencilBrush, brush);
556         }
557
558         return rna_pointer_inherit_refine(ptr, NULL, NULL);
559 }
560
561 static void rna_GPencilBrushes_active_set(PointerRNA *ptr, PointerRNA value)
562 {
563         ToolSettings *ts = (ToolSettings *) ptr->data;
564
565         bGPDbrush *brush;
566
567         for (brush = ts->gp_brushes.first; brush; brush = brush->next) {
568                 if (brush == value.data) {
569                         brush->flag |= GP_BRUSH_ACTIVE;
570                 }
571                 else {
572                         brush->flag &= ~GP_BRUSH_ACTIVE;
573                 }
574         }
575         WM_main_add_notifier(NC_GPENCIL | NA_EDITED, NULL);
576 }
577
578 static int rna_GPencilBrushes_index_get(PointerRNA *ptr)
579 {
580         ToolSettings *ts = (ToolSettings *) ptr->data;
581         bGPDbrush *brush = BKE_gpencil_brush_getactive(ts);
582
583         return BLI_findindex(&ts->gp_brushes, brush);
584 }
585
586 static void rna_GPencilBrushes_index_set(PointerRNA *ptr, int value)
587 {
588         ToolSettings *ts = (ToolSettings *) ptr->data;
589
590         bGPDbrush *brush = BLI_findlink(&ts->gp_brushes, value);
591
592         BKE_gpencil_brush_setactive(ts, brush);
593         WM_main_add_notifier(NC_GPENCIL | ND_DATA | NA_EDITED, NULL);
594 }
595
596 static void rna_GPencilBrushes_index_range(PointerRNA *ptr, int *min, int *max, int *softmin, int *softmax)
597 {
598         ToolSettings *ts = (ToolSettings *) ptr->data;
599
600         *min = 0;
601         *max = max_ii(0, BLI_listbase_count(&ts->gp_brushes) - 1);
602
603         *softmin = *min;
604         *softmax = *max;
605 }
606
607 static void rna_GPencilBrush_name_set(PointerRNA *ptr, const char *value)
608 {
609         ToolSettings *ts = ((Scene *) ptr->id.data)->toolsettings;
610         bGPDbrush *brush = ptr->data;
611
612         /* copy the new name into the name slot */
613         BLI_strncpy_utf8(brush->info, value, sizeof(brush->info));
614
615         BLI_uniquename(&ts->gp_brushes, brush, DATA_("GP_Brush"), '.', offsetof(bGPDbrush, info), sizeof(brush->info));
616 }
617
618 /* ----------------- end of Grease pencil drawing brushes ------------*/
619
620 static void rna_SpaceImageEditor_uv_sculpt_update(Main *bmain, Scene *scene, PointerRNA *UNUSED(ptr))
621 {
622         ED_space_image_uv_sculpt_update(bmain->wm.first, scene);
623 }
624
625 static int rna_Scene_object_bases_lookup_string(PointerRNA *ptr, const char *key, PointerRNA *r_ptr)
626 {
627         Scene *scene = (Scene *)ptr->data;
628         BaseLegacy *base;
629
630         for (base = scene->base.first; base; base = base->next) {
631                 if (STREQLEN(base->object->id.name + 2, key, sizeof(base->object->id.name) - 2)) {
632                         *r_ptr = rna_pointer_inherit_refine(ptr, &RNA_ObjectBaseLegacy, base);
633                         return true;
634                 }
635         }
636
637         return false;
638 }
639
640 static PointerRNA rna_Scene_objects_get(CollectionPropertyIterator *iter)
641 {
642         ListBaseIterator *internal = &iter->internal.listbase;
643
644         /* we are actually iterating a Base list, so override get */
645         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, ((BaseLegacy *)internal->link)->object);
646 }
647
648 static BaseLegacy *rna_Scene_object_link(Scene *scene, bContext *C, ReportList *reports, Object *ob)
649 {
650         Scene *scene_act = CTX_data_scene(C);
651         BaseLegacy *base;
652
653         if (BKE_scene_base_find(scene, ob)) {
654                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is already in scene '%s'", ob->id.name + 2, scene->id.name + 2);
655                 return NULL;
656         }
657
658         base = BKE_scene_base_add(scene, ob);
659         id_us_plus(&ob->id);
660
661         /* this is similar to what object_add_type and BKE_object_add do */
662         base->lay = scene->lay;
663
664         /* when linking to an inactive scene don't touch the layer */
665         if (scene == scene_act)
666                 ob->lay = base->lay;
667
668         /* TODO(sergey): Only update relations for the current scene. */
669         DAG_relations_tag_update(CTX_data_main(C));
670         DAG_id_tag_update(&ob->id, OB_RECALC_OB | OB_RECALC_DATA | OB_RECALC_TIME);
671
672         /* slows down importers too much, run scene.update() */
673         /* DAG_srelations_tag_update(G.main); */
674
675         WM_main_add_notifier(NC_SCENE | ND_OB_ACTIVE, scene);
676
677         return base;
678 }
679
680 static void rna_Scene_object_unlink(Scene *scene, ReportList *reports, Object *ob)
681 {
682         BaseLegacy *base = BKE_scene_base_find(scene, ob);
683         if (!base) {
684                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is not in this scene '%s'", ob->id.name + 2, scene->id.name + 2);
685                 return;
686         }
687         if (base == scene->basact && ob->mode != OB_MODE_OBJECT) {
688                 BKE_reportf(reports, RPT_ERROR, "Object '%s' must be in object mode to unlink", ob->id.name + 2);
689                 return;
690         }
691         if (scene->basact == base) {
692                 scene->basact = NULL;
693         }
694
695         BKE_scene_base_unlink(scene, base);
696         MEM_freeN(base);
697
698         id_us_min(&ob->id);
699
700         /* needed otherwise the depgraph will contain freed objects which can crash, see [#20958] */
701         DAG_relations_tag_update(G.main);
702
703         WM_main_add_notifier(NC_SCENE | ND_OB_ACTIVE, scene);
704 }
705
706 static void rna_Scene_skgen_etch_template_set(PointerRNA *ptr, PointerRNA value)
707 {
708         ToolSettings *ts = (ToolSettings *)ptr->data;
709         if (value.data && ((Object *)value.data)->type == OB_ARMATURE)
710                 ts->skgen_template = value.data;
711         else
712                 ts->skgen_template = NULL;
713 }
714
715 static PointerRNA rna_Scene_active_object_get(PointerRNA *ptr)
716 {
717         Scene *scene = (Scene *)ptr->data;
718         return rna_pointer_inherit_refine(ptr, &RNA_Object, scene->basact ? scene->basact->object : NULL);
719 }
720
721 static void rna_Scene_active_object_set(PointerRNA *ptr, PointerRNA value)
722 {
723         Scene *scene = (Scene *)ptr->data;
724         if (value.data)
725                 scene->basact = BKE_scene_base_find(scene, (Object *)value.data);
726         else
727                 scene->basact = NULL;
728 }
729
730 static void rna_Scene_set_set(PointerRNA *ptr, PointerRNA value)
731 {
732         Scene *scene = (Scene *)ptr->data;
733         Scene *set = (Scene *)value.data;
734         Scene *nested_set;
735
736         for (nested_set = set; nested_set; nested_set = nested_set->set) {
737                 if (nested_set == scene)
738                         return;
739                 /* prevent eternal loops, set can point to next, and next to set, without problems usually */
740                 if (nested_set->set == set)
741                         return;
742         }
743
744         id_lib_extern((ID *)set);
745         scene->set = set;
746 }
747
748 static void rna_Scene_layer_set(PointerRNA *ptr, const int *values)
749 {
750         Scene *scene = (Scene *)ptr->data;
751
752         scene->lay = ED_view3d_scene_layer_set(scene->lay, values, &scene->layact);
753 }
754
755 static int rna_Scene_active_layer_get(PointerRNA *ptr)
756 {
757         Scene *scene = (Scene *)ptr->data;
758
759         return (int)(log(scene->layact) / M_LN2);
760 }
761
762 static void rna_Scene_view3d_update(Main *bmain, Scene *UNUSED(scene_unused), PointerRNA *ptr)
763 {
764         Scene *scene = (Scene *)ptr->data;
765
766         BKE_screen_view3d_main_sync(&bmain->screen, scene);
767 }
768
769 static void rna_Scene_layer_update(Main *bmain, Scene *scene, PointerRNA *ptr)
770 {
771         rna_Scene_view3d_update(bmain, scene, ptr);
772         /* XXX We would need do_time=true here, else we can have update issues like [#36289]...
773          *     However, this has too much drawbacks (like slower layer switch, undesired updates...).
774          *     That's TODO for future DAG updates.
775          */
776         DAG_on_visible_update(bmain, false);
777 }
778
779 static void rna_Scene_fps_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
780 {
781         BKE_sound_update_fps(scene);
782         BKE_sequencer_update_sound_bounds_all(scene);
783 }
784
785 static void rna_Scene_listener_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
786 {
787         BKE_sound_update_scene_listener(scene);
788 }
789
790 static void rna_Scene_volume_set(PointerRNA *ptr, float value)
791 {
792         Scene *scene = (Scene *)(ptr->data);
793
794         scene->audio.volume = value;
795         if (scene->sound_scene)
796                 BKE_sound_set_scene_volume(scene, value);
797 }
798
799 static void rna_Scene_framelen_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
800 {
801         scene->r.framelen = (float)scene->r.framapto / (float)scene->r.images;
802 }
803
804
805 static void rna_Scene_frame_current_set(PointerRNA *ptr, int value)
806 {
807         Scene *data = (Scene *)ptr->data;
808         
809         /* if negative frames aren't allowed, then we can't use them */
810         FRAMENUMBER_MIN_CLAMP(value);
811         data->r.cfra = value;
812 }
813
814 static float rna_Scene_frame_float_get(PointerRNA *ptr)
815 {
816         Scene *data = (Scene *)ptr->data;
817         return (float)data->r.cfra + data->r.subframe;
818 }
819
820 static void rna_Scene_frame_float_set(PointerRNA *ptr, float value)
821 {
822         Scene *data = (Scene *)ptr->data;
823         /* if negative frames aren't allowed, then we can't use them */
824         FRAMENUMBER_MIN_CLAMP(value);
825         data->r.cfra = (int)value;
826         data->r.subframe = value - data->r.cfra;
827 }
828
829 static float rna_Scene_frame_current_final_get(PointerRNA *ptr)
830 {
831         Scene *scene = (Scene *)ptr->data;
832
833         return BKE_scene_frame_get_from_ctime(scene, (float)scene->r.cfra);
834 }
835
836 static void rna_Scene_start_frame_set(PointerRNA *ptr, int value)
837 {
838         Scene *data = (Scene *)ptr->data;
839         /* MINFRAME not MINAFRAME, since some output formats can't taken negative frames */
840         CLAMP(value, MINFRAME, MAXFRAME);
841         data->r.sfra = value;
842
843         if (data->r.sfra >= data->r.efra) {
844                 data->r.efra = MIN2(data->r.sfra, MAXFRAME);
845         }
846 }
847
848 static void rna_Scene_end_frame_set(PointerRNA *ptr, int value)
849 {
850         Scene *data = (Scene *)ptr->data;
851         CLAMP(value, MINFRAME, MAXFRAME);
852         data->r.efra = value;
853
854         if (data->r.sfra >= data->r.efra) {
855                 data->r.sfra = MAX2(data->r.efra, MINFRAME);
856         }
857 }
858
859 static void rna_Scene_use_preview_range_set(PointerRNA *ptr, int value)
860 {
861         Scene *data = (Scene *)ptr->data;
862         
863         if (value) {
864                 /* copy range from scene if not set before */
865                 if ((data->r.psfra == data->r.pefra) && (data->r.psfra == 0)) {
866                         data->r.psfra = data->r.sfra;
867                         data->r.pefra = data->r.efra;
868                 }
869                 
870                 data->r.flag |= SCER_PRV_RANGE;
871         }
872         else
873                 data->r.flag &= ~SCER_PRV_RANGE;
874 }
875
876
877 static void rna_Scene_preview_range_start_frame_set(PointerRNA *ptr, int value)
878 {
879         Scene *data = (Scene *)ptr->data;
880         
881         /* check if enabled already */
882         if ((data->r.flag & SCER_PRV_RANGE) == 0) {
883                 /* set end of preview range to end frame, then clamp as per normal */
884                 /* TODO: or just refuse to set instead? */
885                 data->r.pefra = data->r.efra;
886         }
887         
888         /* now set normally */
889         CLAMP(value, MINAFRAME, data->r.pefra);
890         data->r.psfra = value;
891 }
892
893 static void rna_Scene_preview_range_end_frame_set(PointerRNA *ptr, int value)
894 {
895         Scene *data = (Scene *)ptr->data;
896         
897         /* check if enabled already */
898         if ((data->r.flag & SCER_PRV_RANGE) == 0) {
899                 /* set start of preview range to start frame, then clamp as per normal */
900                 /* TODO: or just refuse to set instead? */
901                 data->r.psfra = data->r.sfra;
902         }
903         
904         /* now set normally */
905         CLAMP(value, data->r.psfra, MAXFRAME);
906         data->r.pefra = value;
907 }
908
909 static void rna_Scene_show_subframe_update(Main *UNUSED(bmain), Scene *UNUSED(current_scene), PointerRNA *ptr)
910 {
911         Scene *scene = (Scene *)ptr->id.data;
912         scene->r.subframe = 0.0f;
913 }
914
915 static void rna_Scene_frame_update(Main *bmain, Scene *UNUSED(current_scene), PointerRNA *ptr)
916 {
917         Scene *scene = (Scene *)ptr->id.data;
918         BKE_sound_seek_scene(bmain, scene);
919 }
920
921 static PointerRNA rna_Scene_active_keying_set_get(PointerRNA *ptr)
922 {
923         Scene *scene = (Scene *)ptr->data;
924         return rna_pointer_inherit_refine(ptr, &RNA_KeyingSet, ANIM_scene_get_active_keyingset(scene));
925 }
926
927 static void rna_Scene_active_keying_set_set(PointerRNA *ptr, PointerRNA value)
928 {
929         Scene *scene = (Scene *)ptr->data;
930         KeyingSet *ks = (KeyingSet *)value.data;
931         
932         scene->active_keyingset = ANIM_scene_get_keyingset_index(scene, ks);
933 }
934
935 /* get KeyingSet index stuff for list of Keying Sets editing UI
936  *      - active_keyingset-1 since 0 is reserved for 'none'
937  *      - don't clamp, otherwise can never set builtins types as active...
938  */
939 static int rna_Scene_active_keying_set_index_get(PointerRNA *ptr)
940 {
941         Scene *scene = (Scene *)ptr->data;
942         return scene->active_keyingset - 1;
943 }
944
945 /* get KeyingSet index stuff for list of Keying Sets editing UI
946  *      - value+1 since 0 is reserved for 'none'
947  */
948 static void rna_Scene_active_keying_set_index_set(PointerRNA *ptr, int value)
949 {
950         Scene *scene = (Scene *)ptr->data;
951         scene->active_keyingset = value + 1;
952 }
953
954 /* XXX: evil... builtin_keyingsets is defined in keyingsets.c! */
955 /* TODO: make API function to retrieve this... */
956 extern ListBase builtin_keyingsets;
957
958 static void rna_Scene_all_keyingsets_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
959 {
960         Scene *scene = (Scene *)ptr->data;
961         
962         /* start going over the scene KeyingSets first, while we still have pointer to it
963          * but only if we have any Keying Sets to use...
964          */
965         if (scene->keyingsets.first)
966                 rna_iterator_listbase_begin(iter, &scene->keyingsets, NULL);
967         else
968                 rna_iterator_listbase_begin(iter, &builtin_keyingsets, NULL);
969 }
970
971 static void rna_Scene_all_keyingsets_next(CollectionPropertyIterator *iter)
972 {
973         ListBaseIterator *internal = &iter->internal.listbase;
974         KeyingSet *ks = (KeyingSet *)internal->link;
975         
976         /* if we've run out of links in Scene list, jump over to the builtins list unless we're there already */
977         if ((ks->next == NULL) && (ks != builtin_keyingsets.last))
978                 internal->link = (Link *)builtin_keyingsets.first;
979         else
980                 internal->link = (Link *)ks->next;
981                 
982         iter->valid = (internal->link != NULL);
983 }
984
985 static int rna_RenderSettings_stereoViews_skip(CollectionPropertyIterator *iter, void *UNUSED(data))
986 {
987         ListBaseIterator *internal = &iter->internal.listbase;
988         SceneRenderView *srv = (SceneRenderView *)internal->link;
989
990         if ((STREQ(srv->name, STEREO_LEFT_NAME)) ||
991             (STREQ(srv->name, STEREO_RIGHT_NAME)))
992         {
993                 return 0;
994         }
995
996         return 1;
997 };
998
999 static void rna_RenderSettings_stereoViews_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
1000 {
1001         RenderData *rd = (RenderData *)ptr->data;
1002         rna_iterator_listbase_begin(iter, &rd->views, rna_RenderSettings_stereoViews_skip);
1003 }
1004
1005 static char *rna_RenderSettings_path(PointerRNA *UNUSED(ptr))
1006 {
1007         return BLI_sprintfN("render");
1008 }
1009
1010 static char *rna_ImageFormatSettings_path(PointerRNA *ptr)
1011 {
1012         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1013         ID *id = ptr->id.data;
1014
1015         switch (GS(id->name)) {
1016                 case ID_SCE:
1017                 {
1018                         Scene *scene = (Scene *)id;
1019
1020                         if (&scene->r.im_format == imf) {
1021                                 return BLI_sprintfN("render.image_settings");
1022                         }
1023                         else if (&scene->r.bake.im_format == imf) {
1024                                 return BLI_sprintfN("render.bake.image_settings");
1025                         }
1026                         return BLI_sprintfN("..");
1027                 }
1028                 case ID_NT:
1029                 {
1030                         bNodeTree *ntree = (bNodeTree *)id;
1031                         bNode *node;
1032
1033                         for (node = ntree->nodes.first; node; node = node->next) {
1034                                 if (node->type == CMP_NODE_OUTPUT_FILE) {
1035                                         if (&((NodeImageMultiFile *)node->storage)->format == imf) {
1036                                                 return BLI_sprintfN("nodes['%s'].format", node->name);
1037                                         }
1038                                         else {
1039                                                 bNodeSocket *sock;
1040
1041                                                 for (sock = node->inputs.first; sock; sock = sock->next) {
1042                                                         NodeImageMultiFileSocket *sockdata = sock->storage;
1043                                                         if (&sockdata->format == imf) {
1044                                                                 return BLI_sprintfN("nodes['%s'].file_slots['%s'].format", node->name, sockdata->path);
1045                                                         }
1046                                                 }
1047                                         }
1048                                 }
1049                         }
1050                         return BLI_sprintfN("..");
1051                 }
1052                 default:
1053                         return BLI_sprintfN("..");
1054         }
1055 }
1056
1057 static int rna_RenderSettings_threads_get(PointerRNA *ptr)
1058 {
1059         RenderData *rd = (RenderData *)ptr->data;
1060         return BKE_render_num_threads(rd);
1061 }
1062
1063 static int rna_RenderSettings_threads_mode_get(PointerRNA *ptr)
1064 {
1065         RenderData *rd = (RenderData *)ptr->data;
1066         int override = BLI_system_num_threads_override_get();
1067
1068         if (override > 0)
1069                 return R_FIXED_THREADS;
1070         else
1071                 return (rd->mode & R_FIXED_THREADS);
1072 }
1073
1074 static int rna_RenderSettings_is_movie_format_get(PointerRNA *ptr)
1075 {
1076         RenderData *rd = (RenderData *)ptr->data;
1077         return BKE_imtype_is_movie(rd->im_format.imtype);
1078 }
1079
1080 static int rna_RenderSettings_save_buffers_get(PointerRNA *ptr)
1081 {
1082         RenderData *rd = (RenderData *)ptr->data;
1083         Scene *scene = (Scene *)ptr->id.data;
1084         
1085         if (!BKE_scene_use_new_shading_nodes(scene))
1086                 return (rd->scemode & (R_EXR_TILE_FILE | R_FULL_SAMPLE)) != 0;
1087         else 
1088                 return (rd->scemode & R_EXR_TILE_FILE) != 0;
1089 }
1090
1091 static void rna_ImageFormatSettings_file_format_set(PointerRNA *ptr, int value)
1092 {
1093         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1094         ID *id = ptr->id.data;
1095         const bool is_render = (id && GS(id->name) == ID_SCE);
1096         /* see note below on why this is */
1097         const char chan_flag = BKE_imtype_valid_channels(imf->imtype, true) | (is_render ? IMA_CHAN_FLAG_BW : 0);
1098
1099         imf->imtype = value;
1100
1101         /* ensure depth and color settings match */
1102         if ( ((imf->planes == R_IMF_PLANES_BW) &&   !(chan_flag & IMA_CHAN_FLAG_BW)) ||
1103              ((imf->planes == R_IMF_PLANES_RGBA) && !(chan_flag & IMA_CHAN_FLAG_ALPHA)))
1104         {
1105                 imf->planes = R_IMF_PLANES_RGB;
1106         }
1107
1108         /* ensure usable depth */
1109         {
1110                 const int depth_ok = BKE_imtype_valid_depths(imf->imtype);
1111                 if ((imf->depth & depth_ok) == 0) {
1112                         /* set first available depth */
1113                         char depth_ls[] = {R_IMF_CHAN_DEPTH_32,
1114                                            R_IMF_CHAN_DEPTH_24,
1115                                            R_IMF_CHAN_DEPTH_16,
1116                                            R_IMF_CHAN_DEPTH_12,
1117                                            R_IMF_CHAN_DEPTH_10,
1118                                            R_IMF_CHAN_DEPTH_8,
1119                                            R_IMF_CHAN_DEPTH_1,
1120                                            0};
1121                         int i;
1122
1123                         for (i = 0; depth_ls[i]; i++) {
1124                                 if (depth_ok & depth_ls[i]) {
1125                                         imf->depth = depth_ls[i];
1126                                         break;
1127                                 }
1128                         }
1129                 }
1130         }
1131
1132         if (id && GS(id->name) == ID_SCE) {
1133                 Scene *scene = ptr->id.data;
1134                 RenderData *rd = &scene->r;
1135 #ifdef WITH_FFMPEG
1136                 BKE_ffmpeg_image_type_verify(rd, imf);
1137 #endif
1138 #ifdef WITH_QUICKTIME
1139                 quicktime_verify_image_type(rd, imf);
1140 #endif
1141                 (void)rd;
1142         }
1143 }
1144
1145 static EnumPropertyItem *rna_ImageFormatSettings_file_format_itemf(
1146         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
1147 {
1148         ID *id = ptr->id.data;
1149         if (id && GS(id->name) == ID_SCE) {
1150                 return rna_enum_image_type_items;
1151         }
1152         else {
1153                 return image_only_type_items;
1154         }
1155 }
1156
1157 static EnumPropertyItem *rna_ImageFormatSettings_color_mode_itemf(
1158         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1159 {
1160         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1161         ID *id = ptr->id.data;
1162         const bool is_render = (id && GS(id->name) == ID_SCE);
1163
1164         /* note, we need to act differently for render
1165          * where 'BW' will force grayscale even if the output format writes
1166          * as RGBA, this is age old blender convention and not sure how useful
1167          * it really is but keep it for now - campbell */
1168         char chan_flag = BKE_imtype_valid_channels(imf->imtype, true) | (is_render ? IMA_CHAN_FLAG_BW : 0);
1169
1170 #ifdef WITH_FFMPEG
1171         /* a WAY more crappy case than B&W flag: depending on codec, file format MIGHT support
1172          * alpha channel. for example MPEG format with h264 codec can't do alpha channel, but
1173          * the same MPEG format with QTRLE codec can easily handle alpha channel.
1174          * not sure how to deal with such cases in a nicer way (sergey) */
1175         if (is_render) {
1176                 Scene *scene = ptr->id.data;
1177                 RenderData *rd = &scene->r;
1178
1179                 if (BKE_ffmpeg_alpha_channel_is_supported(rd))
1180                         chan_flag |= IMA_CHAN_FLAG_ALPHA;
1181         }
1182 #endif
1183
1184         if (chan_flag == (IMA_CHAN_FLAG_BW | IMA_CHAN_FLAG_RGB | IMA_CHAN_FLAG_ALPHA)) {
1185                 return rna_enum_image_color_mode_items;
1186         }
1187         else {
1188                 int totitem = 0;
1189                 EnumPropertyItem *item = NULL;
1190
1191                 if (chan_flag & IMA_CHAN_FLAG_BW)    RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_BW);
1192                 if (chan_flag & IMA_CHAN_FLAG_RGB)   RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_RGB);
1193                 if (chan_flag & IMA_CHAN_FLAG_ALPHA) RNA_enum_item_add(&item, &totitem, &IMAGE_COLOR_MODE_RGBA);
1194
1195                 RNA_enum_item_end(&item, &totitem);
1196                 *r_free = true;
1197
1198                 return item;
1199         }
1200 }
1201
1202 static EnumPropertyItem *rna_ImageFormatSettings_color_depth_itemf(
1203         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1204 {
1205         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1206
1207         if (imf == NULL) {
1208                 return rna_enum_image_color_depth_items;
1209         }
1210         else {
1211                 const int depth_ok = BKE_imtype_valid_depths(imf->imtype);
1212                 const int is_float = ELEM(imf->imtype, R_IMF_IMTYPE_RADHDR, R_IMF_IMTYPE_OPENEXR, R_IMF_IMTYPE_MULTILAYER);
1213
1214                 EnumPropertyItem *item_8bit =  &rna_enum_image_color_depth_items[0];
1215                 EnumPropertyItem *item_10bit = &rna_enum_image_color_depth_items[1];
1216                 EnumPropertyItem *item_12bit = &rna_enum_image_color_depth_items[2];
1217                 EnumPropertyItem *item_16bit = &rna_enum_image_color_depth_items[3];
1218                 EnumPropertyItem *item_32bit = &rna_enum_image_color_depth_items[4];
1219
1220                 int totitem = 0;
1221                 EnumPropertyItem *item = NULL;
1222                 EnumPropertyItem tmp = {0, "", 0, "", ""};
1223
1224                 if (depth_ok & R_IMF_CHAN_DEPTH_8) {
1225                         RNA_enum_item_add(&item, &totitem, item_8bit);
1226                 }
1227
1228                 if (depth_ok & R_IMF_CHAN_DEPTH_10) {
1229                         RNA_enum_item_add(&item, &totitem, item_10bit);
1230                 }
1231
1232                 if (depth_ok & R_IMF_CHAN_DEPTH_12) {
1233                         RNA_enum_item_add(&item, &totitem, item_12bit);
1234                 }
1235
1236                 if (depth_ok & R_IMF_CHAN_DEPTH_16) {
1237                         if (is_float) {
1238                                 tmp = *item_16bit;
1239                                 tmp.name = "Float (Half)";
1240                                 RNA_enum_item_add(&item, &totitem, &tmp);
1241                         }
1242                         else {
1243                                 RNA_enum_item_add(&item, &totitem, item_16bit);
1244                         }
1245                 }
1246
1247                 if (depth_ok & R_IMF_CHAN_DEPTH_32) {
1248                         if (is_float) {
1249                                 tmp = *item_32bit;
1250                                 tmp.name = "Float (Full)";
1251                                 RNA_enum_item_add(&item, &totitem, &tmp);
1252                         }
1253                         else {
1254                                 RNA_enum_item_add(&item, &totitem, item_32bit);
1255                         }
1256                 }
1257
1258                 RNA_enum_item_end(&item, &totitem);
1259                 *r_free = true;
1260
1261                 return item;
1262         }
1263 }
1264
1265 static EnumPropertyItem *rna_ImageFormatSettings_views_format_itemf(
1266         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
1267 {
1268         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1269
1270         if (imf == NULL) {
1271                 return rna_enum_views_format_items;
1272         }
1273         else if (imf->imtype == R_IMF_IMTYPE_OPENEXR) {
1274                 return rna_enum_views_format_multiview_items;
1275         }
1276         else if (imf->imtype == R_IMF_IMTYPE_MULTILAYER) {
1277                 return rna_enum_views_format_multilayer_items;
1278         }
1279         else {
1280                 return rna_enum_views_format_items;
1281         }
1282 }
1283
1284 #ifdef WITH_OPENEXR
1285         /* OpenEXR */
1286
1287 static EnumPropertyItem *rna_ImageFormatSettings_exr_codec_itemf(
1288         bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
1289 {
1290         ImageFormatData *imf = (ImageFormatData *)ptr->data;
1291
1292         EnumPropertyItem *item = NULL;
1293         int i = 1, totitem = 0;
1294
1295         if (imf->depth == 16)
1296                 return rna_enum_exr_codec_items; /* All compression types are defined for halfs */
1297
1298         for (i = 0; i < R_IMF_EXR_CODEC_MAX; i++) {
1299                 if ((i == R_IMF_EXR_CODEC_B44 || i == R_IMF_EXR_CODEC_B44A)) {
1300                         continue; /* B44 and B44A are not defined for 32 bit floats */
1301                 }
1302
1303                 RNA_enum_item_add(&item, &totitem, &rna_enum_exr_codec_items[i]);
1304         }
1305
1306         RNA_enum_item_end(&item, &totitem);
1307         *r_free = true;
1308
1309         return item;
1310 }
1311
1312 #endif
1313 static int rna_SceneRender_file_ext_length(PointerRNA *ptr)
1314 {
1315         RenderData *rd = (RenderData *)ptr->data;
1316         char ext[8];
1317         ext[0] = '\0';
1318         BKE_image_path_ensure_ext_from_imformat(ext, &rd->im_format);
1319         return strlen(ext);
1320 }
1321
1322 static void rna_SceneRender_file_ext_get(PointerRNA *ptr, char *str)
1323 {
1324         RenderData *rd = (RenderData *)ptr->data;
1325         str[0] = '\0';
1326         BKE_image_path_ensure_ext_from_imformat(str, &rd->im_format);
1327 }
1328
1329 #ifdef WITH_QUICKTIME
1330 static int rna_RenderSettings_qtcodecsettings_codecType_get(PointerRNA *ptr)
1331 {
1332         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1333         
1334         return quicktime_rnatmpvalue_from_videocodectype(settings->codecType);
1335 }
1336
1337 static void rna_RenderSettings_qtcodecsettings_codecType_set(PointerRNA *ptr, int value)
1338 {
1339         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1340
1341         settings->codecType = quicktime_videocodecType_from_rnatmpvalue(value);
1342 }
1343
1344 static EnumPropertyItem *rna_RenderSettings_qtcodecsettings_codecType_itemf(
1345         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1346 {
1347         EnumPropertyItem *item = NULL;
1348         EnumPropertyItem tmp = {0, "", 0, "", ""};
1349         QuicktimeCodecTypeDesc *codecTypeDesc;
1350         int i = 1, totitem = 0;
1351
1352         for (i = 0; i < quicktime_get_num_videocodecs(); i++) {
1353                 codecTypeDesc = quicktime_get_videocodecType_desc(i);
1354                 if (!codecTypeDesc) break;
1355
1356                 tmp.value = codecTypeDesc->rnatmpvalue;
1357                 tmp.identifier = codecTypeDesc->codecName;
1358                 tmp.name = codecTypeDesc->codecName;
1359                 RNA_enum_item_add(&item, &totitem, &tmp);
1360         }
1361         
1362         RNA_enum_item_end(&item, &totitem);
1363         *r_free = true;
1364         
1365         return item;
1366 }
1367
1368 static int rna_RenderSettings_qtcodecsettings_audiocodecType_get(PointerRNA *ptr)
1369 {
1370         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1371         
1372         return quicktime_rnatmpvalue_from_audiocodectype(settings->audiocodecType);
1373 }
1374
1375 static void rna_RenderSettings_qtcodecsettings_audiocodecType_set(PointerRNA *ptr, int value)
1376 {
1377         QuicktimeCodecSettings *settings = (QuicktimeCodecSettings *)ptr->data;
1378         
1379         settings->audiocodecType = quicktime_audiocodecType_from_rnatmpvalue(value);
1380 }
1381
1382 static EnumPropertyItem *rna_RenderSettings_qtcodecsettings_audiocodecType_itemf(
1383         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1384 {
1385         EnumPropertyItem *item = NULL;
1386         EnumPropertyItem tmp = {0, "", 0, "", ""};
1387         QuicktimeCodecTypeDesc *codecTypeDesc;
1388         int i = 1, totitem = 0;
1389         
1390         for (i = 0; i < quicktime_get_num_audiocodecs(); i++) {
1391                 codecTypeDesc = quicktime_get_audiocodecType_desc(i);
1392                 if (!codecTypeDesc) break;
1393                 
1394                 tmp.value = codecTypeDesc->rnatmpvalue;
1395                 tmp.identifier = codecTypeDesc->codecName;
1396                 tmp.name = codecTypeDesc->codecName;
1397                 RNA_enum_item_add(&item, &totitem, &tmp);
1398         }
1399         
1400         RNA_enum_item_end(&item, &totitem);
1401         *r_free = true;
1402         
1403         return item;
1404 }
1405 #endif
1406
1407 #ifdef WITH_FFMPEG
1408 static void rna_FFmpegSettings_lossless_output_set(PointerRNA *ptr, int value)
1409 {
1410         Scene *scene = (Scene *) ptr->id.data;
1411         RenderData *rd = &scene->r;
1412
1413         if (value)
1414                 rd->ffcodecdata.flags |= FFMPEG_LOSSLESS_OUTPUT;
1415         else
1416                 rd->ffcodecdata.flags &= ~FFMPEG_LOSSLESS_OUTPUT;
1417
1418         BKE_ffmpeg_codec_settings_verify(rd);
1419 }
1420
1421 static void rna_FFmpegSettings_codec_settings_update(Main *UNUSED(bmain), Scene *UNUSED(scene_unused), PointerRNA *ptr)
1422 {
1423         Scene *scene = (Scene *) ptr->id.data;
1424         RenderData *rd = &scene->r;
1425
1426         BKE_ffmpeg_codec_settings_verify(rd);
1427 }
1428 #endif
1429
1430 static int rna_RenderSettings_active_layer_index_get(PointerRNA *ptr)
1431 {
1432         RenderData *rd = (RenderData *)ptr->data;
1433         return rd->actlay;
1434 }
1435
1436 static void rna_RenderSettings_active_layer_index_set(PointerRNA *ptr, int value)
1437 {
1438         RenderData *rd = (RenderData *)ptr->data;
1439         int num_layers = BLI_listbase_count(&rd->layers);
1440         rd->actlay = min_ff(value, num_layers - 1);
1441 }
1442
1443 static void rna_RenderSettings_active_layer_index_range(
1444         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
1445 {
1446         RenderData *rd = (RenderData *)ptr->data;
1447
1448         *min = 0;
1449         *max = max_ii(0, BLI_listbase_count(&rd->layers) - 1);
1450 }
1451
1452 static PointerRNA rna_RenderSettings_active_layer_get(PointerRNA *ptr)
1453 {
1454         RenderData *rd = (RenderData *)ptr->data;
1455         SceneRenderLayer *srl = BLI_findlink(&rd->layers, rd->actlay);
1456         
1457         return rna_pointer_inherit_refine(ptr, &RNA_SceneRenderLayer, srl);
1458 }
1459
1460 static void rna_RenderSettings_active_layer_set(PointerRNA *ptr, PointerRNA value)
1461 {
1462         RenderData *rd = (RenderData *)ptr->data;
1463         SceneRenderLayer *srl = (SceneRenderLayer *)value.data;
1464         const int index = BLI_findindex(&rd->layers, srl);
1465         if (index != -1) rd->actlay = index;
1466 }
1467
1468 static SceneRenderLayer *rna_RenderLayer_new(ID *id, RenderData *UNUSED(rd), const char *name)
1469 {
1470         Scene *scene = (Scene *)id;
1471         SceneRenderLayer *srl = BKE_scene_add_render_layer(scene, name);
1472
1473         DAG_id_tag_update(&scene->id, 0);
1474         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1475
1476         return srl;
1477 }
1478
1479 static void rna_RenderLayer_remove(
1480         ID *id, RenderData *UNUSED(rd), Main *bmain, ReportList *reports, PointerRNA *srl_ptr)
1481 {
1482         SceneRenderLayer *srl = srl_ptr->data;
1483         Scene *scene = (Scene *)id;
1484
1485         if (!BKE_scene_remove_render_layer(bmain, scene, srl)) {
1486                 BKE_reportf(reports, RPT_ERROR, "Render layer '%s' could not be removed from scene '%s'",
1487                             srl->name, scene->id.name + 2);
1488                 return;
1489         }
1490
1491         RNA_POINTER_INVALIDATE(srl_ptr);
1492
1493         DAG_id_tag_update(&scene->id, 0);
1494         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1495 }
1496
1497 static int rna_RenderSettings_active_view_index_get(PointerRNA *ptr)
1498 {
1499         RenderData *rd = (RenderData *)ptr->data;
1500         return rd->actview;
1501 }
1502
1503 static void rna_RenderSettings_active_view_index_set(PointerRNA *ptr, int value)
1504 {
1505         RenderData *rd = (RenderData *)ptr->data;
1506         rd->actview = value;
1507 }
1508
1509 static void rna_RenderSettings_active_view_index_range(
1510         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
1511 {
1512         RenderData *rd = (RenderData *)ptr->data;
1513
1514         *min = 0;
1515         *max = max_ii(0, BLI_listbase_count(&rd->views) - 1);
1516 }
1517
1518 static PointerRNA rna_RenderSettings_active_view_get(PointerRNA *ptr)
1519 {
1520         RenderData *rd = (RenderData *)ptr->data;
1521         SceneRenderView *srv = BLI_findlink(&rd->views, rd->actview);
1522
1523         return rna_pointer_inherit_refine(ptr, &RNA_SceneRenderView, srv);
1524 }
1525
1526 static void rna_RenderSettings_active_view_set(PointerRNA *ptr, PointerRNA value)
1527 {
1528         RenderData *rd = (RenderData *)ptr->data;
1529         SceneRenderView *srv = (SceneRenderView *)value.data;
1530         const int index = BLI_findindex(&rd->views, srv);
1531         if (index != -1) rd->actview = index;
1532 }
1533
1534 static SceneRenderView *rna_RenderView_new(ID *id, RenderData *UNUSED(rd), const char *name)
1535 {
1536         Scene *scene = (Scene *)id;
1537         SceneRenderView *srv = BKE_scene_add_render_view(scene, name);
1538
1539         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1540
1541         return srv;
1542 }
1543
1544 static void rna_RenderView_remove(
1545         ID *id, RenderData *UNUSED(rd), Main *UNUSED(bmain), ReportList *reports, PointerRNA *srv_ptr)
1546 {
1547         SceneRenderView *srv = srv_ptr->data;
1548         Scene *scene = (Scene *)id;
1549
1550         if (!BKE_scene_remove_render_view(scene, srv)) {
1551                 BKE_reportf(reports, RPT_ERROR, "Render view '%s' could not be removed from scene '%s'",
1552                             srv->name, scene->id.name + 2);
1553                 return;
1554         }
1555
1556         RNA_POINTER_INVALIDATE(srv_ptr);
1557
1558         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
1559 }
1560
1561 static void rna_RenderSettings_engine_set(PointerRNA *ptr, int value)
1562 {
1563         RenderData *rd = (RenderData *)ptr->data;
1564         RenderEngineType *type = BLI_findlink(&R_engines, value);
1565
1566         if (type)
1567                 BLI_strncpy_utf8(rd->engine, type->idname, sizeof(rd->engine));
1568 }
1569
1570 static EnumPropertyItem *rna_RenderSettings_engine_itemf(
1571         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
1572 {
1573         RenderEngineType *type;
1574         EnumPropertyItem *item = NULL;
1575         EnumPropertyItem tmp = {0, "", 0, "", ""};
1576         int a = 0, totitem = 0;
1577
1578         for (type = R_engines.first; type; type = type->next, a++) {
1579                 tmp.value = a;
1580                 tmp.identifier = type->idname;
1581                 tmp.name = type->name;
1582                 RNA_enum_item_add(&item, &totitem, &tmp);
1583         }
1584         
1585         RNA_enum_item_end(&item, &totitem);
1586         *r_free = true;
1587
1588         return item;
1589 }
1590
1591 static int rna_RenderSettings_engine_get(PointerRNA *ptr)
1592 {
1593         RenderData *rd = (RenderData *)ptr->data;
1594         RenderEngineType *type;
1595         int a = 0;
1596
1597         for (type = R_engines.first; type; type = type->next, a++)
1598                 if (STREQ(type->idname, rd->engine))
1599                         return a;
1600         
1601         return 0;
1602 }
1603
1604 static void rna_RenderSettings_engine_update(Main *bmain, Scene *UNUSED(unused), PointerRNA *UNUSED(ptr))
1605 {
1606         ED_render_engine_changed(bmain);
1607 }
1608
1609 static void rna_Scene_glsl_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1610 {
1611         Scene *scene = (Scene *)ptr->id.data;
1612
1613         DAG_id_tag_update(&scene->id, 0);
1614 }
1615
1616 static void rna_Scene_freestyle_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1617 {
1618         Scene *scene = (Scene *)ptr->id.data;
1619
1620         DAG_id_tag_update(&scene->id, 0);
1621 }
1622
1623 static void rna_Scene_use_view_map_cache_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
1624 {
1625 #ifdef WITH_FREESTYLE
1626         FRS_free_view_map_cache();
1627 #endif
1628 }
1629
1630 static void rna_SceneRenderLayer_name_set(PointerRNA *ptr, const char *value)
1631 {
1632         Scene *scene = (Scene *)ptr->id.data;
1633         SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
1634         char oldname[sizeof(rl->name)];
1635
1636         BLI_strncpy(oldname, rl->name, sizeof(rl->name));
1637
1638         BLI_strncpy_utf8(rl->name, value, sizeof(rl->name));
1639         BLI_uniquename(&scene->r.layers, rl, DATA_("RenderLayer"), '.', offsetof(SceneRenderLayer, name), sizeof(rl->name));
1640
1641         if (scene->nodetree) {
1642                 bNode *node;
1643                 int index = BLI_findindex(&scene->r.layers, rl);
1644
1645                 for (node = scene->nodetree->nodes.first; node; node = node->next) {
1646                         if (node->type == CMP_NODE_R_LAYERS && node->id == NULL) {
1647                                 if (node->custom1 == index)
1648                                         BLI_strncpy(node->name, rl->name, NODE_MAXSTR);
1649                         }
1650                 }
1651         }
1652
1653         /* fix all the animation data which may link to this */
1654         BKE_animdata_fix_paths_rename_all(NULL, "render.layers", oldname, rl->name);
1655 }
1656
1657 static char *rna_SceneRenderLayer_path(PointerRNA *ptr)
1658 {
1659         SceneRenderLayer *srl = (SceneRenderLayer *)ptr->data;
1660         char name_esc[sizeof(srl->name) * 2];
1661
1662         BLI_strescape(name_esc, srl->name, sizeof(name_esc));
1663         return BLI_sprintfN("render.layers[\"%s\"]", name_esc);
1664 }
1665
1666 static void rna_SceneRenderView_name_set(PointerRNA *ptr, const char *value)
1667 {
1668         Scene *scene = (Scene *)ptr->id.data;
1669         SceneRenderView *rv = (SceneRenderView *)ptr->data;
1670         BLI_strncpy_utf8(rv->name, value, sizeof(rv->name));
1671         BLI_uniquename(&scene->r.views, rv, DATA_("RenderView"), '.', offsetof(SceneRenderView, name), sizeof(rv->name));
1672 }
1673
1674 static char *rna_SceneRenderView_path(PointerRNA *ptr)
1675 {
1676         SceneRenderView *srv = (SceneRenderView *)ptr->data;
1677         return BLI_sprintfN("render.views[\"%s\"]", srv->name);
1678 }
1679
1680 static void rna_RenderSettings_views_format_set(PointerRNA *ptr, int value)
1681 {
1682         RenderData *rd = (RenderData *)ptr->data;
1683
1684         if (rd->views_format == SCE_VIEWS_FORMAT_MULTIVIEW &&
1685             value == SCE_VIEWS_FORMAT_STEREO_3D)
1686         {
1687                 /* make sure the actview is visible */
1688                 if (rd->actview > 1) rd->actview = 1;
1689         }
1690
1691         rd->views_format = value;
1692 }
1693
1694 static int rna_RenderSettings_multiple_engines_get(PointerRNA *UNUSED(ptr))
1695 {
1696         return (BLI_listbase_count(&R_engines) > 1);
1697 }
1698
1699 static int rna_RenderSettings_use_shading_nodes_get(PointerRNA *ptr)
1700 {
1701         Scene *scene = (Scene *)ptr->id.data;
1702         return BKE_scene_use_new_shading_nodes(scene);
1703 }
1704
1705 static int rna_RenderSettings_use_spherical_stereo_get(PointerRNA *ptr)
1706 {
1707         Scene *scene = (Scene *)ptr->id.data;
1708         return BKE_scene_use_spherical_stereo(scene);
1709 }
1710
1711 static int rna_RenderSettings_use_game_engine_get(PointerRNA *ptr)
1712 {
1713         RenderData *rd = (RenderData *)ptr->data;
1714         RenderEngineType *type;
1715
1716         for (type = R_engines.first; type; type = type->next)
1717                 if (STREQ(type->idname, rd->engine))
1718                         return (type->flag & RE_GAME) != 0;
1719         
1720         return 0;
1721 }
1722
1723 static void rna_SceneRenderLayer_layer_set(PointerRNA *ptr, const int *values)
1724 {
1725         SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
1726         rl->lay = ED_view3d_scene_layer_set(rl->lay, values, NULL);
1727 }
1728
1729 static void rna_SceneRenderLayer_pass_update(Main *bmain, Scene *activescene, PointerRNA *ptr)
1730 {
1731         Scene *scene = (Scene *)ptr->id.data;
1732
1733         if (scene->nodetree)
1734                 ntreeCompositForceHidden(scene->nodetree);
1735         
1736         rna_Scene_glsl_update(bmain, activescene, ptr);
1737 }
1738
1739 static void rna_Scene_use_nodes_update(bContext *C, PointerRNA *ptr)
1740 {
1741         Scene *scene = (Scene *)ptr->data;
1742
1743         if (scene->use_nodes && scene->nodetree == NULL)
1744                 ED_node_composit_default(C, scene);
1745 }
1746
1747 static void rna_Physics_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1748 {
1749         Scene *scene = (Scene *)ptr->id.data;
1750         FOREACH_SCENE_OBJECT(scene, ob)
1751         {
1752                 BKE_ptcache_object_reset(scene, ob, PTCACHE_RESET_DEPSGRAPH);
1753         }
1754         FOREACH_SCENE_OBJECT_END
1755 }
1756
1757 static void rna_Scene_editmesh_select_mode_set(PointerRNA *ptr, const int *value)
1758 {
1759         Scene *scene = (Scene *)ptr->id.data;
1760         SceneLayer *sl = BKE_scene_layer_context_active(scene);
1761         ToolSettings *ts = (ToolSettings *)ptr->data;
1762         int flag = (value[0] ? SCE_SELECT_VERTEX : 0) | (value[1] ? SCE_SELECT_EDGE : 0) | (value[2] ? SCE_SELECT_FACE : 0);
1763
1764         if (flag) {
1765                 ts->selectmode = flag;
1766
1767                 if (sl->basact) {
1768                         Mesh *me = BKE_mesh_from_object(sl->basact->object);
1769                         if (me && me->edit_btmesh && me->edit_btmesh->selectmode != flag) {
1770                                 me->edit_btmesh->selectmode = flag;
1771                                 EDBM_selectmode_set(me->edit_btmesh);
1772                         }
1773                 }
1774         }
1775 }
1776
1777 static void rna_Scene_editmesh_select_mode_update(Main *UNUSED(bmain), bContext *C, Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
1778 {
1779         SceneLayer *sl = CTX_data_scene_layer(C);
1780         Mesh *me = NULL;
1781
1782         if (sl->basact) {
1783                 me = BKE_mesh_from_object(sl->basact->object);
1784                 if (me && me->edit_btmesh == NULL)
1785                         me = NULL;
1786         }
1787
1788         WM_main_add_notifier(NC_GEOM | ND_SELECT, me);
1789         WM_main_add_notifier(NC_SCENE | ND_TOOLSETTINGS, NULL);
1790 }
1791
1792 static void object_simplify_update(Object *ob)
1793 {
1794         ModifierData *md;
1795         ParticleSystem *psys;
1796
1797         if ((ob->id.tag & LIB_TAG_DOIT) == 0) {
1798                 return;
1799         }
1800
1801         ob->id.tag &= ~LIB_TAG_DOIT;
1802
1803         for (md = ob->modifiers.first; md; md = md->next) {
1804                 if (ELEM(md->type, eModifierType_Subsurf, eModifierType_Multires, eModifierType_ParticleSystem)) {
1805                         DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
1806                 }
1807         }
1808
1809         for (psys = ob->particlesystem.first; psys; psys = psys->next)
1810                 psys->recalc |= PSYS_RECALC_CHILD;
1811         
1812         if (ob->dup_group) {
1813                 GroupObject *gob;
1814
1815                 for (gob = ob->dup_group->gobject.first; gob; gob = gob->next)
1816                         object_simplify_update(gob->ob);
1817         }
1818 }
1819
1820 static void rna_Scene_use_simplify_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
1821 {
1822         Scene *sce = ptr->id.data;
1823         Scene *sce_iter;
1824         Base *base;
1825
1826         BKE_main_id_tag_listbase(&bmain->object, LIB_TAG_DOIT, true);
1827         for (SETLOOPER(sce, sce_iter, base))
1828                 object_simplify_update(base->object);
1829         
1830         WM_main_add_notifier(NC_GEOM | ND_DATA, NULL);
1831 }
1832
1833 static void rna_Scene_simplify_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
1834 {
1835         Scene *sce = ptr->id.data;
1836
1837         if (sce->r.mode & R_SIMPLIFY)
1838                 rna_Scene_use_simplify_update(bmain, sce, ptr);
1839 }
1840
1841 static void rna_Scene_use_persistent_data_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
1842 {
1843         Scene *sce = ptr->id.data;
1844
1845         if (!(sce->r.mode & R_PERSISTENT_DATA))
1846                 RE_FreePersistentData();
1847 }
1848
1849 static int rna_Scene_use_audio_get(PointerRNA *ptr)
1850 {
1851         Scene *scene = (Scene *)ptr->data;
1852         return (scene->audio.flag & AUDIO_MUTE) != 0;
1853 }
1854
1855 static void rna_Scene_use_audio_set(PointerRNA *ptr, int value)
1856 {
1857         Scene *scene = (Scene *)ptr->data;
1858
1859         if (value)
1860                 scene->audio.flag |= AUDIO_MUTE;
1861         else
1862                 scene->audio.flag &= ~AUDIO_MUTE;
1863
1864         BKE_sound_mute_scene(scene, value);
1865 }
1866
1867 static int rna_Scene_sync_mode_get(PointerRNA *ptr)
1868 {
1869         Scene *scene = (Scene *)ptr->data;
1870         if (scene->audio.flag & AUDIO_SYNC)
1871                 return AUDIO_SYNC;
1872         return scene->flag & SCE_FRAME_DROP;
1873 }
1874
1875 static void rna_Scene_sync_mode_set(PointerRNA *ptr, int value)
1876 {
1877         Scene *scene = (Scene *)ptr->data;
1878
1879         if (value == AUDIO_SYNC) {
1880                 scene->audio.flag |= AUDIO_SYNC;
1881         }
1882         else if (value == SCE_FRAME_DROP) {
1883                 scene->audio.flag &= ~AUDIO_SYNC;
1884                 scene->flag |= SCE_FRAME_DROP;
1885         }
1886         else {
1887                 scene->audio.flag &= ~AUDIO_SYNC;
1888                 scene->flag &= ~SCE_FRAME_DROP;
1889         }
1890 }
1891
1892 static int rna_GameSettings_auto_start_get(PointerRNA *UNUSED(ptr))
1893 {
1894         return (G.fileflags & G_FILE_AUTOPLAY) != 0;
1895 }
1896
1897 static void rna_GameSettings_auto_start_set(PointerRNA *UNUSED(ptr), int value)
1898 {
1899         if (value)
1900                 G.fileflags |= G_FILE_AUTOPLAY;
1901         else
1902                 G.fileflags &= ~G_FILE_AUTOPLAY;
1903 }
1904
1905 static void rna_GameSettings_exit_key_set(PointerRNA *ptr, int value)
1906 {
1907         GameData *gm = (GameData *)ptr->data;
1908
1909         if (ISKEYBOARD(value))
1910                 gm->exitkey = value;
1911 }
1912
1913 static StructRNA *rna_LayerCollectionSettings_refine(PointerRNA *ptr)
1914 {
1915         IDProperty *props = (IDProperty *)ptr->data;
1916         BLI_assert(props && props->type == IDP_GROUP);
1917
1918         switch (props->subtype) {
1919                 case IDP_GROUP_SUB_ENGINE_RENDER:
1920 #ifdef WITH_CLAY_ENGINE
1921                         if (STREQ(props->name, RE_engine_id_BLENDER_CLAY)) {
1922                                 return &RNA_LayerCollectionEngineSettingsClay;
1923                         }
1924 #endif
1925                         break;
1926                 case IDP_GROUP_SUB_MODE_OBJECT:
1927                         return &RNA_LayerCollectionModeSettingsObject;
1928                         break;
1929                 case IDP_GROUP_SUB_MODE_EDIT:
1930                         return &RNA_LayerCollectionModeSettingsEdit;
1931                         break;
1932                 default:
1933                         break;
1934         }
1935
1936         return &RNA_LayerCollectionSettings;
1937 }
1938
1939 static TimeMarker *rna_TimeLine_add(Scene *scene, const char name[], int frame)
1940 {
1941         TimeMarker *marker = MEM_callocN(sizeof(TimeMarker), "TimeMarker");
1942         marker->flag = SELECT;
1943         marker->frame = frame;
1944         BLI_strncpy_utf8(marker->name, name, sizeof(marker->name));
1945         BLI_addtail(&scene->markers, marker);
1946
1947         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1948         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1949
1950         return marker;
1951 }
1952
1953 static void rna_TimeLine_remove(Scene *scene, ReportList *reports, PointerRNA *marker_ptr)
1954 {
1955         TimeMarker *marker = marker_ptr->data;
1956         if (BLI_remlink_safe(&scene->markers, marker) == false) {
1957                 BKE_reportf(reports, RPT_ERROR, "Timeline marker '%s' not found in scene '%s'",
1958                             marker->name, scene->id.name + 2);
1959                 return;
1960         }
1961
1962         MEM_freeN(marker);
1963         RNA_POINTER_INVALIDATE(marker_ptr);
1964
1965         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1966         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1967 }
1968
1969 static void rna_TimeLine_clear(Scene *scene)
1970 {
1971         BLI_freelistN(&scene->markers);
1972
1973         WM_main_add_notifier(NC_SCENE | ND_MARKERS, NULL);
1974         WM_main_add_notifier(NC_ANIMATION | ND_MARKERS, NULL);
1975 }
1976
1977 static KeyingSet *rna_Scene_keying_set_new(Scene *sce, ReportList *reports, const char idname[], const char name[])
1978 {
1979         KeyingSet *ks = NULL;
1980
1981         /* call the API func, and set the active keyingset index */
1982         ks = BKE_keyingset_add(&sce->keyingsets, idname, name, KEYINGSET_ABSOLUTE, 0);
1983         
1984         if (ks) {
1985                 sce->active_keyingset = BLI_listbase_count(&sce->keyingsets);
1986                 return ks;
1987         }
1988         else {
1989                 BKE_report(reports, RPT_ERROR, "Keying set could not be added");
1990                 return NULL;
1991         }
1992 }
1993
1994 static void rna_UnifiedPaintSettings_update(bContext *C, PointerRNA *UNUSED(ptr))
1995 {
1996         Scene *scene = CTX_data_scene(C);
1997         SceneLayer *sl = CTX_data_scene_layer(C);
1998         Brush *br = BKE_paint_brush(BKE_paint_get_active(scene, sl));
1999         WM_main_add_notifier(NC_BRUSH | NA_EDITED, br);
2000 }
2001
2002 static void rna_UnifiedPaintSettings_size_set(PointerRNA *ptr, int value)
2003 {
2004         UnifiedPaintSettings *ups = ptr->data;
2005
2006         /* scale unprojected radius so it stays consistent with brush size */
2007         BKE_brush_scale_unprojected_radius(&ups->unprojected_radius,
2008                                            value, ups->size);
2009         ups->size = value;
2010 }
2011
2012 static void rna_UnifiedPaintSettings_unprojected_radius_set(PointerRNA *ptr, float value)
2013 {
2014         UnifiedPaintSettings *ups = ptr->data;
2015
2016         /* scale brush size so it stays consistent with unprojected_radius */
2017         BKE_brush_scale_size(&ups->size, value, ups->unprojected_radius);
2018         ups->unprojected_radius = value;
2019 }
2020
2021 static void rna_UnifiedPaintSettings_radius_update(bContext *C, PointerRNA *ptr)
2022 {
2023         /* changing the unified size should invalidate the overlay but also update the brush */
2024         BKE_paint_invalidate_overlay_all();
2025         rna_UnifiedPaintSettings_update(C, ptr);
2026 }
2027
2028 static char *rna_UnifiedPaintSettings_path(PointerRNA *UNUSED(ptr))
2029 {
2030         return BLI_strdup("tool_settings.unified_paint_settings");
2031 }
2032
2033 static char *rna_CurvePaintSettings_path(PointerRNA *UNUSED(ptr))
2034 {
2035         return BLI_strdup("tool_settings.curve_paint_settings");
2036 }
2037
2038 /* generic function to recalc geometry */
2039 static void rna_EditMesh_update(Main *UNUSED(bmain), bContext *C, Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
2040 {
2041         SceneLayer *sl = CTX_data_scene_layer(C);
2042         Mesh *me = NULL;
2043
2044         if (sl->basact) {
2045                 me = BKE_mesh_from_object(sl->basact->object);
2046                 if (me && me->edit_btmesh == NULL)
2047                         me = NULL;
2048         }
2049
2050         if (me) {
2051                 DAG_id_tag_update(&me->id, OB_RECALC_DATA);
2052                 WM_main_add_notifier(NC_GEOM | ND_DATA, me);
2053         }
2054 }
2055
2056 static char *rna_MeshStatVis_path(PointerRNA *UNUSED(ptr))
2057 {
2058         return BLI_strdup("tool_settings.statvis");
2059 }
2060
2061 /* note: without this, when Multi-Paint is activated/deactivated, the colors
2062  * will not change right away when multiple bones are selected, this function
2063  * is not for general use and only for the few cases where changing scene
2064  * settings and NOT for general purpose updates, possibly this should be
2065  * given its own notifier. */
2066 static void rna_Scene_update_active_object_data(bContext *C, PointerRNA *UNUSED(ptr))
2067 {
2068         SceneLayer *sl = CTX_data_scene_layer(C);
2069         Object *ob = OBACT_NEW;
2070
2071         if (ob) {
2072                 DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
2073                 WM_main_add_notifier(NC_OBJECT | ND_DRAW, &ob->id);
2074         }
2075 }
2076
2077 static void rna_SceneCamera_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2078 {
2079         Scene *scene = (Scene *)ptr->id.data;
2080         Object *camera = scene->camera;
2081
2082         if (camera)
2083                 DAG_id_tag_update(&camera->id, 0);
2084 }
2085
2086 static void rna_SceneSequencer_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
2087 {
2088         BKE_sequencer_cache_cleanup();
2089         BKE_sequencer_preprocessed_cache_cleanup();
2090 }
2091
2092 static char *rna_ToolSettings_path(PointerRNA *UNUSED(ptr))
2093 {
2094         return BLI_strdup("tool_settings");
2095 }
2096
2097 static PointerRNA rna_FreestyleLineSet_linestyle_get(PointerRNA *ptr)
2098 {
2099         FreestyleLineSet *lineset = (FreestyleLineSet *)ptr->data;
2100
2101         return rna_pointer_inherit_refine(ptr, &RNA_FreestyleLineStyle, lineset->linestyle);
2102 }
2103
2104 static void rna_FreestyleLineSet_linestyle_set(PointerRNA *ptr, PointerRNA value)
2105 {
2106         FreestyleLineSet *lineset = (FreestyleLineSet *)ptr->data;
2107
2108         if (lineset->linestyle)
2109                 id_us_min(&lineset->linestyle->id);
2110         lineset->linestyle = (FreestyleLineStyle *)value.data;
2111         id_us_plus(&lineset->linestyle->id);
2112 }
2113
2114 static FreestyleLineSet *rna_FreestyleSettings_lineset_add(
2115         ID *id, FreestyleSettings *config, Main *bmain, const char *name)
2116 {
2117         Scene *scene = (Scene *)id;
2118         FreestyleLineSet *lineset = BKE_freestyle_lineset_add(bmain, (FreestyleConfig *)config, name);
2119
2120         DAG_id_tag_update(&scene->id, 0);
2121         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2122
2123         return lineset;
2124 }
2125
2126 static void rna_FreestyleSettings_lineset_remove(
2127         ID *id, FreestyleSettings *config, ReportList *reports, PointerRNA *lineset_ptr)
2128 {
2129         FreestyleLineSet *lineset = lineset_ptr->data;
2130         Scene *scene = (Scene *)id;
2131
2132         if (!BKE_freestyle_lineset_delete((FreestyleConfig *)config, lineset)) {
2133                 BKE_reportf(reports, RPT_ERROR, "Line set '%s' could not be removed", lineset->name);
2134                 return;
2135         }
2136
2137         RNA_POINTER_INVALIDATE(lineset_ptr);
2138
2139         DAG_id_tag_update(&scene->id, 0);
2140         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2141 }
2142
2143 static PointerRNA rna_FreestyleSettings_active_lineset_get(PointerRNA *ptr)
2144 {
2145         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2146         FreestyleLineSet *lineset = BKE_freestyle_lineset_get_active(config);
2147         return rna_pointer_inherit_refine(ptr, &RNA_FreestyleLineSet, lineset);
2148 }
2149
2150 static void rna_FreestyleSettings_active_lineset_index_range(
2151         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2152 {
2153         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2154
2155         *min = 0;
2156         *max = max_ii(0, BLI_listbase_count(&config->linesets) - 1);
2157 }
2158
2159 static int rna_FreestyleSettings_active_lineset_index_get(PointerRNA *ptr)
2160 {
2161         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2162         return BKE_freestyle_lineset_get_active_index(config);
2163 }
2164
2165 static void rna_FreestyleSettings_active_lineset_index_set(PointerRNA *ptr, int value)
2166 {
2167         FreestyleConfig *config = (FreestyleConfig *)ptr->data;
2168         BKE_freestyle_lineset_set_active_index(config, value);
2169 }
2170
2171 static FreestyleModuleConfig *rna_FreestyleSettings_module_add(ID *id, FreestyleSettings *config)
2172 {
2173         Scene *scene = (Scene *)id;
2174         FreestyleModuleConfig *module = BKE_freestyle_module_add((FreestyleConfig *)config);
2175
2176         DAG_id_tag_update(&scene->id, 0);
2177         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2178
2179         return module;
2180 }
2181
2182 static void rna_FreestyleSettings_module_remove(
2183         ID *id, FreestyleSettings *config, ReportList *reports, PointerRNA *module_ptr)
2184 {
2185         Scene *scene = (Scene *)id;
2186         FreestyleModuleConfig *module = module_ptr->data;
2187
2188         if (!BKE_freestyle_module_delete((FreestyleConfig *)config, module)) {
2189                 if (module->script)
2190                         BKE_reportf(reports, RPT_ERROR, "Style module '%s' could not be removed", module->script->id.name + 2);
2191                 else
2192                         BKE_report(reports, RPT_ERROR, "Style module could not be removed");
2193                 return;
2194         }
2195
2196         RNA_POINTER_INVALIDATE(module_ptr);
2197
2198         DAG_id_tag_update(&scene->id, 0);
2199         WM_main_add_notifier(NC_SCENE | ND_RENDER_OPTIONS, NULL);
2200 }
2201
2202 char *rna_GPUDOF_path(PointerRNA *ptr)
2203 {
2204         /* if there is ID-data, resolve the path using the index instead of by name,
2205          * since the name used is the name of the texture assigned, but the texture
2206          * may be used multiple times in the same stack
2207          */
2208         if (ptr->id.data) {
2209                 if (GS(((ID *)ptr->id.data)->name) == ID_CA) {
2210                         return BLI_strdup("gpu_dof");
2211                 }
2212         }
2213
2214         return BLI_strdup("");
2215 }
2216
2217 static void rna_GPUFXSettings_fx_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2218 {
2219         GPUFXSettings *fx_settings = ptr->data;
2220
2221         BKE_screen_gpu_fx_validate(fx_settings);
2222 }
2223
2224 static void rna_GPUDOFSettings_blades_set(PointerRNA *ptr, const int value)
2225 {
2226         GPUDOFSettings *dofsettings = (GPUDOFSettings *)ptr->data;
2227
2228         if (value < 3 && dofsettings->num_blades > 2)
2229                 dofsettings->num_blades = 0;
2230         else if (value > 0 && dofsettings->num_blades == 0)
2231                 dofsettings->num_blades = 3;
2232         else
2233                 dofsettings->num_blades = value;
2234 }
2235
2236 static void rna_Stereo3dFormat_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2237 {
2238         ID *id = ptr->id.data;
2239
2240         if (id && GS(id->name) == ID_IM) {
2241                 Image *ima = (Image *)id;
2242                 ImBuf *ibuf;
2243                 void *lock;
2244
2245                 if (!BKE_image_is_stereo(ima))
2246                         return;
2247
2248                 ibuf = BKE_image_acquire_ibuf(ima, NULL, &lock);
2249
2250                 if (ibuf) {
2251                         BKE_image_signal(ima, NULL, IMA_SIGNAL_FREE);
2252                 }
2253                 BKE_image_release_ibuf(ima, ibuf, lock);
2254         }
2255 }
2256
2257 static int rna_gpu_is_hq_supported_get(PointerRNA *UNUSED(ptr))
2258 {
2259         return GPU_instanced_drawing_support() && GPU_geometry_shader_support();
2260 }
2261
2262 static void rna_SceneCollection_name_set(PointerRNA *ptr, const char *value)
2263 {
2264         Scene *scene = (Scene *)ptr->id.data;
2265         SceneCollection *sc = (SceneCollection *)ptr->data;
2266         BKE_collection_rename(scene, sc, value);
2267 }
2268
2269 static void rna_SceneCollection_filter_set(PointerRNA *ptr, const char *value)
2270 {
2271         Scene *scene = (Scene *)ptr->id.data;
2272         SceneCollection *sc = (SceneCollection *)ptr->data;
2273         BLI_strncpy_utf8(sc->filter, value, sizeof(sc->filter));
2274
2275         TODO_LAYER_SYNC_FILTER;
2276         (void)scene;
2277 }
2278
2279 static PointerRNA rna_SceneCollection_objects_get(CollectionPropertyIterator *iter)
2280 {
2281         ListBaseIterator *internal = &iter->internal.listbase;
2282
2283         /* we are actually iterating a LinkData list, so override get */
2284         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, ((LinkData *)internal->link)->data);
2285 }
2286
2287 static int rna_SceneCollection_move_above(ID *id, SceneCollection *sc_src, Main *bmain, SceneCollection *sc_dst)
2288 {
2289         Scene *scene = (Scene *)id;
2290
2291         if (!BKE_collection_move_above(scene, sc_dst, sc_src)) {
2292                 return 0;
2293         }
2294
2295         DAG_relations_tag_update(bmain);
2296         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2297
2298         return 1;
2299 }
2300
2301 static int rna_SceneCollection_move_below(ID *id, SceneCollection *sc_src, Main *bmain, SceneCollection *sc_dst)
2302 {
2303         Scene *scene = (Scene *)id;
2304
2305         if (!BKE_collection_move_below(scene, sc_dst, sc_src)) {
2306                 return 0;
2307         }
2308
2309         DAG_relations_tag_update(bmain);
2310         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2311
2312         return 1;
2313 }
2314
2315 static int rna_SceneCollection_move_into(ID *id, SceneCollection *sc_src, Main *bmain, SceneCollection *sc_dst)
2316 {
2317         Scene *scene = (Scene *)id;
2318
2319         if (!BKE_collection_move_into(scene, sc_dst, sc_src)) {
2320                 return 0;
2321         }
2322
2323         DAG_relations_tag_update(bmain);
2324         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2325
2326         return 1;
2327 }
2328
2329 static SceneCollection *rna_SceneCollection_new(
2330         ID *id, SceneCollection *sc_parent, Main *bmain, const char *name)
2331 {
2332         Scene *scene = (Scene *)id;
2333         SceneCollection *sc = BKE_collection_add(scene, sc_parent, name);
2334
2335         DAG_relations_tag_update(bmain);
2336         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2337
2338         return sc;
2339 }
2340
2341 static void rna_SceneCollection_remove(
2342         ID *id, SceneCollection *sc_parent, Main *bmain, ReportList *reports, PointerRNA *sc_ptr)
2343 {
2344         Scene *scene = (Scene *)id;
2345         SceneCollection *sc = sc_ptr->data;
2346
2347         const int index = BLI_findindex(&sc_parent->scene_collections, sc);
2348         if (index == -1) {
2349                 BKE_reportf(reports, RPT_ERROR, "Collection '%s' is not a sub-collection of '%s'",
2350                             sc->name, sc_parent->name);
2351                 return;
2352         }
2353
2354         if (!BKE_collection_remove(scene, sc)) {
2355                 BKE_reportf(reports, RPT_ERROR, "Collection '%s' could not be removed from collection '%s'",
2356                             sc->name, sc_parent->name);
2357                 return;
2358         }
2359
2360         RNA_POINTER_INVALIDATE(sc_ptr);
2361
2362         DAG_relations_tag_update(bmain);
2363         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2364 }
2365
2366 static int rna_SceneCollection_objects_active_index_get(PointerRNA *ptr)
2367 {
2368         SceneCollection *sc = (SceneCollection *)ptr->data;
2369         return sc->active_object_index;
2370 }
2371
2372 static void rna_SceneCollection_objects_active_index_set(PointerRNA *ptr, int value)
2373 {
2374         SceneCollection *sc = (SceneCollection *)ptr->data;
2375         sc->active_object_index = value;
2376 }
2377
2378 static void rna_SceneCollection_objects_active_index_range(
2379         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2380 {
2381         SceneCollection *sc = (SceneCollection *)ptr->data;
2382         *min = 0;
2383         *max = max_ii(0, BLI_listbase_count(&sc->objects) - 1);
2384 }
2385
2386 void rna_SceneCollection_object_link(
2387         ID *id, SceneCollection *sc, Main *bmain, ReportList *reports, Object *ob)
2388 {
2389         Scene *scene = (Scene *)id;
2390
2391         if (BLI_findptr(&sc->objects, ob, offsetof(LinkData, data))) {
2392                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is already in collection '%s'", ob->id.name + 2, sc->name);
2393                 return;
2394         }
2395
2396         BKE_collection_object_add(scene, sc, ob);
2397
2398         /* TODO(sergey): Only update relations for the current scene. */
2399         DAG_relations_tag_update(bmain);
2400
2401         /* TODO(sergey): Use proper flag for tagging here. */
2402         DAG_id_tag_update(&scene->id, 0);
2403
2404         DAG_id_tag_update(&ob->id, OB_RECALC_OB | OB_RECALC_DATA | OB_RECALC_TIME);
2405
2406         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2407 }
2408
2409 static void rna_SceneCollection_object_unlink(
2410         ID *id, SceneCollection *sc, Main *bmain, ReportList *reports, Object *ob)
2411 {
2412         Scene *scene = (Scene *)id;
2413
2414         if (!BLI_findptr(&sc->objects, ob, offsetof(LinkData, data))) {
2415                 BKE_reportf(reports, RPT_ERROR, "Object '%s' is not in collection '%s'", ob->id.name + 2, sc->name);
2416                 return;
2417         }
2418
2419         BKE_collection_object_remove(bmain, scene, sc, ob, false);
2420
2421         /* needed otherwise the depgraph will contain freed objects which can crash, see [#20958] */
2422         DAG_relations_tag_update(bmain);
2423
2424         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2425 }
2426
2427 /****** layer collection engine settings *******/
2428
2429 #define RNA_LAYER_ENGINE_GET_SET(_TYPE_, _ENGINE_, _MODE_, _NAME_)                 \
2430 static _TYPE_ rna_LayerEngineSettings_##_ENGINE_##_##_NAME_##_get(PointerRNA *ptr) \
2431 {                                                                                  \
2432         IDProperty *props = (IDProperty *)ptr->data;                                   \
2433         return BKE_collection_engine_property_value_get_##_TYPE_(props, #_NAME_);      \
2434 }                                                                                  \
2435                                                                                        \
2436 static void rna_LayerEngineSettings_##_ENGINE_##_##_NAME_##_set(PointerRNA *ptr, _TYPE_ value)  \
2437 {                                                                                  \
2438         IDProperty *props = (IDProperty *)ptr->data;                                   \
2439         BKE_collection_engine_property_value_set_##_TYPE_(props, #_NAME_, value);      \
2440 }                                                                                  \
2441
2442 #define RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(_NAME_) \
2443         RNA_LAYER_ENGINE_GET_SET(float, Clay, COLLECTION_MODE_NONE, _NAME_)
2444
2445 #define RNA_LAYER_ENGINE_CLAY_GET_SET_INT(_NAME_) \
2446         RNA_LAYER_ENGINE_GET_SET(int, Clay, COLLECTION_MODE_NONE, _NAME_)
2447
2448 #define RNA_LAYER_ENGINE_CLAY_GET_SET_BOOL(_NAME_) \
2449         RNA_LAYER_ENGINE_GET_SET(bool, Clay, COLLECTION_MODE_NONE, _NAME_)
2450
2451 /* mode engines */
2452
2453 #define RNA_LAYER_MODE_OBJECT_GET_SET_FLOAT(_NAME_) \
2454         RNA_LAYER_ENGINE_GET_SET(float, ObjectMode, COLLECTION_MODE_OBJECT, _NAME_)
2455
2456 #define RNA_LAYER_MODE_OBJECT_GET_SET_INT(_NAME_) \
2457         RNA_LAYER_ENGINE_GET_SET(int, ObjectMode, COLLECTION_MODE_OBJECT, _NAME_)
2458
2459 #define RNA_LAYER_MODE_OBJECT_GET_SET_BOOL(_NAME_) \
2460         RNA_LAYER_ENGINE_GET_SET(bool, ObjectMode, COLLECTION_MODE_OBJECT, _NAME_)
2461
2462 #define RNA_LAYER_MODE_EDIT_GET_SET_FLOAT(_NAME_) \
2463         RNA_LAYER_ENGINE_GET_SET(float, EditMode, COLLECTION_MODE_EDIT, _NAME_)
2464
2465 #define RNA_LAYER_MODE_EDIT_GET_SET_INT(_NAME_) \
2466         RNA_LAYER_ENGINE_GET_SET(int, EditMode, COLLECTION_MODE_EDIT, _NAME_)
2467
2468 #define RNA_LAYER_MODE_EDIT_GET_SET_BOOL(_NAME_) \
2469         RNA_LAYER_ENGINE_GET_SET(bool, EditMode, COLLECTION_MODE_EDIT, _NAME_)
2470
2471 /* clay engine */
2472 #ifdef WITH_CLAY_ENGINE
2473 RNA_LAYER_ENGINE_CLAY_GET_SET_INT(matcap_icon)
2474 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(matcap_rotation)
2475 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(matcap_hue)
2476 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(matcap_saturation)
2477 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(matcap_value)
2478 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(ssao_factor_cavity)
2479 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(ssao_factor_edge)
2480 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(ssao_distance)
2481 RNA_LAYER_ENGINE_CLAY_GET_SET_FLOAT(ssao_attenuation)
2482 #endif /* WITH_CLAY_ENGINE */
2483
2484 /* object engine */
2485 RNA_LAYER_MODE_OBJECT_GET_SET_BOOL(show_wire)
2486 RNA_LAYER_MODE_OBJECT_GET_SET_BOOL(show_backface_culling)
2487
2488 /* mesh engine */
2489 RNA_LAYER_MODE_EDIT_GET_SET_BOOL(show_occlude_wire)
2490 RNA_LAYER_MODE_EDIT_GET_SET_BOOL(face_normals_show)
2491 RNA_LAYER_MODE_EDIT_GET_SET_BOOL(vert_normals_show)
2492 RNA_LAYER_MODE_EDIT_GET_SET_BOOL(loop_normals_show)
2493 RNA_LAYER_MODE_EDIT_GET_SET_FLOAT(normals_length)
2494 RNA_LAYER_MODE_EDIT_GET_SET_FLOAT(backwire_opacity)
2495
2496 #undef RNA_LAYER_ENGINE_GET_SET
2497
2498 static void rna_LayerCollectionEngineSettings_update(bContext *C, PointerRNA *UNUSED(ptr))
2499 {
2500         Scene *scene = CTX_data_scene(C);
2501         /* TODO(sergey): Use proper flag for tagging here. */
2502         DAG_id_tag_update(&scene->id, 0);
2503 }
2504
2505 /***********************************/
2506
2507 static void rna_LayerCollectionSettings_name_get(PointerRNA *ptr, char *value)
2508 {
2509         IDProperty *props = (IDProperty *)ptr->data;
2510         strcpy(value, props->name);
2511 }
2512
2513 static int rna_LayerCollectionSettings_name_length(PointerRNA *ptr)
2514 {
2515         IDProperty *props = (IDProperty *)ptr->data;
2516         return strnlen(props->name, sizeof(props->name));
2517 }
2518
2519 static void rna_LayerCollectionSettings_use(ID *id, IDProperty *props, const char *identifier)
2520 {
2521         Scene *scene = (Scene *)id;
2522         PointerRNA scene_props_ptr;
2523         PropertyRNA *prop;
2524         IDProperty *scene_props;
2525
2526         scene_props = BKE_scene_collection_engine_get(scene, COLLECTION_MODE_NONE, props->name);
2527         RNA_pointer_create(id, &RNA_LayerCollectionSettings, scene_props, &scene_props_ptr);
2528         prop = RNA_struct_find_property(&scene_props_ptr, identifier);
2529
2530         switch (RNA_property_type(prop)) {
2531                 case PROP_FLOAT:
2532                 {
2533                         float value = BKE_collection_engine_property_value_get_float(scene_props, identifier);
2534                         BKE_collection_engine_property_add_float(props, identifier, value);
2535                         break;
2536                 }
2537                 case PROP_ENUM:
2538                 {
2539                         int value = BKE_collection_engine_property_value_get_int(scene_props, identifier);
2540                         BKE_collection_engine_property_add_int(props, identifier, value);
2541                         break;
2542                 }
2543                 case PROP_INT:
2544                 {
2545                         int value = BKE_collection_engine_property_value_get_int(scene_props, identifier);
2546                         BKE_collection_engine_property_add_int(props, identifier, value);
2547                         break;
2548                 }
2549                 case PROP_BOOLEAN:
2550                 {
2551                         int value = BKE_collection_engine_property_value_get_int(scene_props, identifier);
2552                         BKE_collection_engine_property_add_bool(props, identifier, value);
2553                         break;
2554                 }
2555                 case PROP_STRING:
2556                 case PROP_POINTER:
2557                 case PROP_COLLECTION:
2558                 default:
2559                         break;
2560         }
2561
2562         /* TODO(sergey): Use proper flag for tagging here. */
2563         DAG_id_tag_update(id, 0);
2564 }
2565
2566 static void rna_LayerCollectionSettings_unuse(ID *id, IDProperty *props, const char *identifier)
2567 {
2568         IDProperty *prop_to_remove = IDP_GetPropertyFromGroup(props, identifier);
2569         IDP_FreeFromGroup(props, prop_to_remove);
2570
2571         /* TODO(sergey): Use proper flag for tagging here. */
2572         DAG_id_tag_update(id, 0);
2573 }
2574
2575 static void rna_LayerCollection_name_get(PointerRNA *ptr, char *value)
2576 {
2577         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2578         strcpy(value, sc->name);
2579 }
2580
2581 static int rna_LayerCollection_name_length(PointerRNA *ptr)
2582 {
2583         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2584         return strnlen(sc->name, sizeof(sc->name));
2585 }
2586
2587 static void rna_LayerCollection_name_set(PointerRNA *ptr, const char *value)
2588 {
2589         Scene *scene = (Scene *)ptr->id.data;
2590         SceneCollection *sc = ((LayerCollection *)ptr->data)->scene_collection;
2591         BKE_collection_rename(scene, sc, value);
2592 }
2593
2594 static PointerRNA rna_LayerCollection_objects_get(CollectionPropertyIterator *iter)
2595 {
2596         ListBaseIterator *internal = &iter->internal.listbase;
2597         Base *base = ((LinkData *)internal->link)->data;
2598         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, base->object);
2599 }
2600
2601 static int rna_LayerCollection_move_above(ID *id, LayerCollection *lc_src, Main *bmain, LayerCollection *lc_dst)
2602 {
2603         Scene *scene = (Scene *)id;
2604
2605         if (!BKE_layer_collection_move_above(scene, lc_dst, lc_src)) {
2606                 return 0;
2607         }
2608
2609         DAG_relations_tag_update(bmain);
2610         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2611
2612         return 1;
2613 }
2614
2615 static int rna_LayerCollection_move_below(ID *id, LayerCollection *lc_src, Main *bmain, LayerCollection *lc_dst)
2616 {
2617         Scene *scene = (Scene *)id;
2618
2619         if (!BKE_layer_collection_move_below(scene, lc_dst, lc_src)) {
2620                 return 0;
2621         }
2622
2623         DAG_relations_tag_update(bmain);
2624         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2625
2626         return 1;
2627 }
2628
2629 static int rna_LayerCollection_move_into(ID *id, LayerCollection *lc_src, Main *bmain, LayerCollection *lc_dst)
2630 {
2631         Scene *scene = (Scene *)id;
2632
2633         if (!BKE_layer_collection_move_into(scene, lc_dst, lc_src)) {
2634                 return 0;
2635         }
2636
2637         DAG_relations_tag_update(bmain);
2638         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2639
2640         return 1;
2641 }
2642
2643 static void rna_LayerCollection_flag_update(bContext *C, PointerRNA *UNUSED(ptr))
2644 {
2645         Scene *scene = CTX_data_scene(C);
2646         /* TODO(sergey): Use proper flag for tagging here. */
2647         DAG_id_tag_update(&scene->id, 0);
2648         WM_event_add_notifier(C, NC_SCENE | ND_OB_SELECT, scene);
2649 }
2650
2651 static int rna_LayerCollections_active_collection_index_get(PointerRNA *ptr)
2652 {
2653         SceneLayer *sl = (SceneLayer *)ptr->data;
2654         return sl->active_collection;
2655 }
2656
2657 static void rna_LayerCollections_active_collection_index_set(PointerRNA *ptr, int value)
2658 {
2659         SceneLayer *sl = (SceneLayer *)ptr->data;
2660         int num_collections = BKE_layer_collection_count(sl);
2661         sl->active_collection = min_ff(value, num_collections - 1);
2662 }
2663
2664 static void rna_LayerCollections_active_collection_index_range(
2665         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2666 {
2667         SceneLayer *sl = (SceneLayer *)ptr->data;
2668         *min = 0;
2669         *max = max_ii(0, BKE_layer_collection_count(sl) - 1);
2670 }
2671
2672 static PointerRNA rna_LayerCollections_active_collection_get(PointerRNA *ptr)
2673 {
2674         SceneLayer *sl = (SceneLayer *)ptr->data;
2675         LayerCollection *lc = BKE_layer_collection_active(sl);
2676         return rna_pointer_inherit_refine(ptr, &RNA_LayerCollection, lc);
2677 }
2678
2679 static void rna_LayerCollections_active_collection_set(PointerRNA *ptr, PointerRNA value)
2680 {
2681         SceneLayer *sl = (SceneLayer *)ptr->data;
2682         LayerCollection *lc = (LayerCollection *)value.data;
2683         const int index = BKE_layer_collection_findindex(sl, lc);
2684         if (index != -1) sl->active_collection = index;
2685 }
2686
2687 LayerCollection * rna_SceneLayer_collection_link(
2688         ID *id, SceneLayer *sl, Main *bmain, SceneCollection *sc)
2689 {
2690         Scene *scene = (Scene *)id;
2691         LayerCollection *lc = BKE_collection_link(sl, sc);
2692
2693         DAG_relations_tag_update(bmain);
2694         /* TODO(sergey): Use proper flag for tagging here. */
2695         DAG_id_tag_update(id, 0);
2696         WM_main_add_notifier(NC_SCENE | ND_LAYER, scene);
2697
2698         return lc;
2699 }
2700
2701 static void rna_SceneLayer_collection_unlink(
2702         ID *id, SceneLayer *sl, Main *bmain, ReportList *reports, LayerCollection *lc)
2703 {
2704         Scene *scene = (Scene *)id;
2705
2706         if (BLI_findindex(&sl->layer_collections, lc) == -1) {
2707                 BKE_reportf(reports, RPT_ERROR, "Layer collection '%s' is not in '%s'", lc->scene_collection->name, sl->name);
2708                 return;
2709         }
2710
2711         BKE_collection_unlink(sl, lc);
2712
2713         DAG_relations_tag_update(bmain);
2714         /* TODO(sergey): Use proper flag for tagging here. */
2715         DAG_id_tag_update(id, 0);
2716         WM_main_add_notifier(NC_SCENE | ND_LAYER | ND_OB_ACTIVE, scene);
2717 }
2718
2719 static PointerRNA rna_LayerObjects_active_object_get(PointerRNA *ptr)
2720 {
2721         SceneLayer *sl = (SceneLayer *)ptr->data;
2722         return rna_pointer_inherit_refine(ptr, &RNA_Object, sl->basact ? sl->basact->object : NULL);
2723 }
2724
2725 static void rna_LayerObjects_active_object_set(PointerRNA *ptr, PointerRNA value)
2726 {
2727         SceneLayer *sl = (SceneLayer *)ptr->data;
2728         if (value.data)
2729                 sl->basact = BKE_scene_layer_base_find(sl, (Object *)value.data);
2730         else
2731                 sl->basact = NULL;
2732 }
2733
2734 static void rna_SceneLayer_name_set(PointerRNA *ptr, const char *value)
2735 {
2736         Scene *scene = (Scene *)ptr->id.data;
2737         SceneLayer *sl = (SceneLayer *)ptr->data;
2738         char oldname[sizeof(sl->name)];
2739
2740         BLI_strncpy(oldname, sl->name, sizeof(sl->name));
2741
2742         BLI_strncpy_utf8(sl->name, value, sizeof(sl->name));
2743         BLI_uniquename(&scene->render_layers, sl, DATA_("SceneLayer"), '.', offsetof(SceneLayer, name), sizeof(sl->name));
2744
2745         if (scene->nodetree) {
2746                 bNode *node;
2747                 int index = BLI_findindex(&scene->render_layers, sl);
2748
2749                 for (node = scene->nodetree->nodes.first; node; node = node->next) {
2750                         if (node->type == CMP_NODE_R_LAYERS && node->id == NULL) {
2751                                 if (node->custom1 == index)
2752                                         BLI_strncpy(node->name, sl->name, NODE_MAXSTR);
2753                         }
2754                 }
2755         }
2756 }
2757
2758 static PointerRNA rna_SceneLayer_objects_get(CollectionPropertyIterator *iter)
2759 {
2760         ListBaseIterator *internal = &iter->internal.listbase;
2761
2762         /* we are actually iterating a ObjectBase list, so override get */
2763         Base *base = (Base *)internal->link;
2764         return rna_pointer_inherit_refine(&iter->parent, &RNA_Object, base->object);
2765 }
2766
2767 static int rna_SceneLayer_objects_selected_skip(CollectionPropertyIterator *iter, void *UNUSED(data))
2768 {
2769         ListBaseIterator *internal = &iter->internal.listbase;
2770         Base *base = (Base *)internal->link;
2771
2772         if ((base->flag & BASE_SELECTED) != 0) {
2773                         return 0;
2774         }
2775
2776         return 1;
2777 };
2778
2779 static void rna_LayerObjects_selected_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
2780 {
2781         SceneLayer *sl = (SceneLayer *)ptr->data;
2782         rna_iterator_listbase_begin(iter, &sl->object_bases, rna_SceneLayer_objects_selected_skip);
2783 }
2784
2785 static void rna_SceneLayer_engine_set(PointerRNA *ptr, int value)
2786 {
2787         SceneLayer *sl = (SceneLayer *)ptr->data;
2788         RenderEngineType *type = BLI_findlink(&R_engines, value);
2789
2790         if (type)
2791                 BKE_scene_layer_engine_set(sl, type->idname);
2792 }
2793
2794 static EnumPropertyItem *rna_SceneLayer_engine_itemf(
2795         bContext *UNUSED(C), PointerRNA *UNUSED(ptr), PropertyRNA *UNUSED(prop), bool *r_free)
2796 {
2797         RenderEngineType *type;
2798         EnumPropertyItem *item = NULL;
2799         EnumPropertyItem tmp = {0, "", 0, "", ""};
2800         int a = 0, totitem = 0;
2801
2802         for (type = R_engines.first; type; type = type->next, a++) {
2803                 tmp.value = a;
2804                 tmp.identifier = type->idname;
2805                 tmp.name = type->name;
2806                 RNA_enum_item_add(&item, &totitem, &tmp);
2807         }
2808
2809         RNA_enum_item_end(&item, &totitem);
2810         *r_free = true;
2811
2812         return item;
2813 }
2814
2815 static int rna_SceneLayer_engine_get(PointerRNA *ptr)
2816 {
2817         SceneLayer *sl = (SceneLayer *)ptr->data;
2818         RenderEngineType *type;
2819         int a = 0;
2820
2821         for (type = R_engines.first; type; type = type->next, a++)
2822                 if (STREQ(type->idname, sl->engine))
2823                         return a;
2824
2825         return 0;
2826 }
2827
2828 static void rna_SceneLayer_engine_update(Main *bmain, Scene *UNUSED(unused), PointerRNA *UNUSED(ptr))
2829 {
2830         ED_render_engine_changed(bmain);
2831 }
2832
2833 static int rna_SceneLayer_multiple_engines_get(PointerRNA *UNUSED(ptr))
2834 {
2835         return (BLI_listbase_count(&R_engines) > 1);
2836 }
2837
2838 static void rna_SceneLayer_update_tagged(SceneLayer *UNUSED(sl), bContext *C)
2839 {
2840         Depsgraph *graph = CTX_data_depsgraph(C);
2841         DEG_OBJECT_ITER(graph, ob)
2842         {
2843                 /* Don't do anything, we just need to run the iterator to flush
2844                  * the base info to the objects. */
2845                 UNUSED_VARS(ob);
2846         }
2847         DEG_OBJECT_ITER_END
2848 }
2849
2850 static int rna_SceneLayer_active_layer_index_get(PointerRNA *ptr)
2851 {
2852         Scene *scene = (Scene *)ptr->data;
2853         return scene->active_layer;
2854 }
2855
2856 static void rna_SceneLayer_active_layer_index_set(PointerRNA *ptr, int value)
2857 {
2858         Scene *scene = (Scene *)ptr->data;
2859         int num_layers = BLI_listbase_count(&scene->render_layers);
2860         scene->active_layer = min_ff(value, num_layers - 1);
2861 }
2862
2863 static void rna_SceneLayer_active_layer_index_range(
2864         PointerRNA *ptr, int *min, int *max, int *UNUSED(softmin), int *UNUSED(softmax))
2865 {
2866         Scene *scene = (Scene *)ptr->data;
2867
2868         *min = 0;
2869         *max = max_ii(0, BLI_listbase_count(&scene->render_layers) - 1);
2870 }
2871
2872 static PointerRNA rna_SceneLayer_active_layer_get(PointerRNA *ptr)
2873 {
2874         Scene *scene = (Scene *)ptr->data;
2875         SceneLayer *sl = BLI_findlink(&scene->render_layers, scene->active_layer);
2876
2877         return rna_pointer_inherit_refine(ptr, &RNA_SceneLayer, sl);
2878 }
2879
2880 static void rna_SceneLayer_active_layer_set(PointerRNA *ptr, PointerRNA value)
2881 {
2882         Scene *scene = (Scene *)ptr->data;
2883         SceneLayer *sl = (SceneLayer *)value.data;
2884         const int index = BLI_findindex(&scene->render_layers, sl);
2885         if (index != -1) scene->active_layer = index;
2886 }
2887
2888 static SceneLayer *rna_SceneLayer_new(
2889         ID *id, Scene *UNUSED(sce), Main *bmain, const char *name)
2890 {
2891         Scene *scene = (Scene *)id;
2892         SceneLayer *sl = BKE_scene_layer_add(scene, name);
2893
2894         DAG_id_tag_update(&scene->id, 0);
2895         DAG_relations_tag_update(bmain);
2896         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2897
2898         return sl;
2899 }
2900
2901 static void rna_SceneLayer_remove(
2902         ID *id, Scene *UNUSED(sce), Main *bmain, ReportList *reports, PointerRNA *sl_ptr)
2903 {
2904         Scene *scene = (Scene *)id;
2905         SceneLayer *sl = sl_ptr->data;
2906
2907         if (!BKE_scene_layer_remove(bmain, scene, sl)) {
2908                 BKE_reportf(reports, RPT_ERROR, "Render layer '%s' could not be removed from scene '%s'",
2909                             sl->name, scene->id.name + 2);
2910                 return;
2911         }
2912
2913         RNA_POINTER_INVALIDATE(sl_ptr);
2914
2915         DAG_id_tag_update(&scene->id, 0);
2916         DAG_relations_tag_update(bmain);
2917         WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
2918 }
2919
2920 static void rna_ObjectBase_select_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
2921 {
2922         Base *base = (Base *)ptr->data;
2923         short mode = (base->flag & BASE_SELECTED) ? BA_SELECT : BA_DESELECT;
2924         ED_object_base_select(base, mode);
2925 }
2926 #else
2927
2928 /* Grease Pencil Interpolation tool settings */
2929 static void rna_def_gpencil_interpolate(BlenderRNA *brna)
2930 {
2931         StructRNA *srna;
2932         PropertyRNA *prop;
2933         
2934         srna = RNA_def_struct(brna, "GPencilInterpolateSettings", NULL);
2935         RNA_def_struct_sdna(srna, "GP_Interpolate_Settings");
2936         RNA_def_struct_path_func(srna, "rna_GPencilInterpolateSettings_path");
2937         RNA_def_struct_ui_text(srna, "Grease Pencil Interpolate Settings",
2938                                "Settings for Grease Pencil interpolation tools");
2939         
2940         /* flags */
2941         prop = RNA_def_property(srna, "interpolate_all_layers", PROP_BOOLEAN, PROP_NONE);
2942         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ALL_LAYERS);
2943         RNA_def_property_ui_text(prop, "Interpolate All Layers", "Interpolate all layers, not only active");
2944         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2945
2946         prop = RNA_def_property(srna, "interpolate_selected_only", PROP_BOOLEAN, PROP_NONE);
2947         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ONLY_SELECTED);
2948         RNA_def_property_ui_text(prop, "Interpolate Selected Strokes", "Interpolate only selected strokes in the original frame");
2949         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2950         
2951         /* interpolation type */
2952         prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
2953         RNA_def_property_enum_sdna(prop, NULL, "type");
2954         RNA_def_property_enum_items(prop, rna_enum_gpencil_interpolation_mode_items);
2955         RNA_def_property_enum_funcs(prop, NULL, "rna_GPencilInterpolateSettings_type_set", NULL);
2956         RNA_def_property_ui_text(prop, "Type",
2957                                  "Interpolation method to use the next time 'Interpolate Sequence' is run");
2958         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2959         
2960         /* easing */
2961         prop = RNA_def_property(srna, "easing", PROP_ENUM, PROP_NONE);
2962         RNA_def_property_enum_sdna(prop, NULL, "easing");
2963         RNA_def_property_enum_items(prop, rna_enum_beztriple_interpolation_easing_items);
2964         RNA_def_property_ui_text(prop, "Easing", 
2965                                  "Which ends of the segment between the preceding and following grease pencil frames "
2966                                  "easing interpolation is applied to");
2967         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2968         
2969         /* easing options */
2970         prop = RNA_def_property(srna, "back", PROP_FLOAT, PROP_NONE);
2971         RNA_def_property_float_sdna(prop, NULL, "back");
2972         RNA_def_property_ui_text(prop, "Back", "Amount of overshoot for 'back' easing");
2973         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2974         
2975         prop = RNA_def_property(srna, "amplitude", PROP_FLOAT, PROP_NONE);
2976         RNA_def_property_float_sdna(prop, NULL, "amplitude");
2977         RNA_def_property_range(prop, 0.0f, FLT_MAX); /* only positive values... */
2978         RNA_def_property_ui_text(prop, "Amplitude", "Amount to boost elastic bounces for 'elastic' easing");
2979         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2980         
2981         prop = RNA_def_property(srna, "period", PROP_FLOAT, PROP_NONE);
2982         RNA_def_property_float_sdna(prop, NULL, "period");
2983         RNA_def_property_ui_text(prop, "Period", "Time between bounces for elastic easing");
2984         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2985         
2986         /* custom curvemap */
2987         prop = RNA_def_property(srna, "interpolation_curve", PROP_POINTER, PROP_NONE);
2988         RNA_def_property_pointer_sdna(prop, NULL, "custom_ipo");
2989         RNA_def_property_struct_type(prop, "CurveMapping");
2990         RNA_def_property_ui_text(prop, "Interpolation Curve", 
2991                                  "Custom curve to control 'sequence' interpolation between Grease Pencil frames");
2992         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
2993 }
2994
2995 /* Grease Pencil Drawing Brushes */
2996 static void rna_def_gpencil_brush(BlenderRNA *brna)
2997 {
2998         StructRNA *srna;
2999         PropertyRNA *prop;
3000
3001         srna = RNA_def_struct(brna, "GPencilBrush", NULL);
3002         RNA_def_struct_sdna(srna, "bGPDbrush");
3003         RNA_def_struct_ui_text(srna, "Grease Pencil Brush",
3004                                "Collection of brushes being used to control the line style of new strokes");
3005         RNA_def_struct_ui_icon(srna, ICON_BRUSH_DATA);
3006
3007         /* Name */
3008         prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
3009         RNA_def_property_string_sdna(prop, NULL, "info");
3010         RNA_def_property_ui_text(prop, "Name", "Brush name");
3011         RNA_def_property_string_funcs(prop, NULL, NULL, "rna_GPencilBrush_name_set");
3012         RNA_def_struct_name_property(srna, prop);
3013         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3014
3015         /* Line Thickness */
3016         prop = RNA_def_property(srna, "line_width", PROP_INT, PROP_PIXEL);
3017         RNA_def_property_int_sdna(prop, NULL, "thickness");
3018         RNA_def_property_range(prop, 1, 300);
3019         RNA_def_property_ui_range(prop, 1, 10, 1, 0);
3020         RNA_def_property_ui_text(prop, "Thickness", "Thickness of strokes (in pixels)");
3021         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3022
3023         /* Sensitivity factor for new strokes */
3024         prop = RNA_def_property(srna, "pen_sensitivity_factor", PROP_FLOAT, PROP_NONE);
3025         RNA_def_property_float_sdna(prop, NULL, "draw_sensitivity");
3026         RNA_def_property_range(prop, 0.1f, 3.0f);
3027         RNA_def_property_ui_text(prop, "Sensitivity", "Pressure sensitivity factor for new strokes");
3028         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3029
3030         /* Strength factor for new strokes */
3031         prop = RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
3032         RNA_def_property_float_sdna(prop, NULL, "draw_strength");
3033         RNA_def_property_range(prop, 0.0f, 1.0f);
3034         RNA_def_property_ui_text(prop, "Strength", "Color strength for new strokes (affect alpha factor of color)");
3035         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3036
3037         /* Jitter factor for new strokes */
3038         prop = RNA_def_property(srna, "jitter", PROP_FLOAT, PROP_NONE);
3039         RNA_def_property_float_sdna(prop, NULL, "draw_jitter");
3040         RNA_def_property_range(prop, 0.0f, 1.0f);
3041         RNA_def_property_ui_text(prop, "Jitter", "Jitter factor for new strokes");
3042         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3043
3044         /* Randomnes factor for sensitivity and strength */
3045         prop = RNA_def_property(srna, "random_press", PROP_FLOAT, PROP_NONE);
3046         RNA_def_property_float_sdna(prop, NULL, "draw_random_press");
3047         RNA_def_property_range(prop, 0.0f, 1.0f);
3048         RNA_def_property_ui_text(prop, "Randomness", "Randomness factor for pressure and strength in new strokes");
3049         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3050
3051         /* Randomnes factor for subdivision */
3052         prop = RNA_def_property(srna, "random_subdiv", PROP_FLOAT, PROP_NONE);
3053         RNA_def_property_float_sdna(prop, NULL, "draw_random_sub");
3054         RNA_def_property_range(prop, 0.0f, 1.0f);
3055         RNA_def_property_ui_text(prop, "Random Subdivision", "Randomness factor for new strokes after subdivision");
3056         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3057
3058         /* Angle when brush is full size */
3059         prop = RNA_def_property(srna, "angle", PROP_FLOAT, PROP_ANGLE);
3060         RNA_def_property_float_sdna(prop, NULL, "draw_angle");
3061         RNA_def_property_range(prop, -M_PI_2, M_PI_2);
3062         RNA_def_property_ui_text(prop, "Angle",
3063                                  "Direction of the stroke at which brush gives maximal thickness "
3064                                  "(0° for horizontal)");
3065         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3066
3067         /* Factor to change brush size depending of angle */
3068         prop = RNA_def_property(srna, "angle_factor", PROP_FLOAT, PROP_NONE);
3069         RNA_def_property_float_sdna(prop, NULL, "draw_angle_factor");
3070         RNA_def_property_range(prop, 0.0f, 1.0f);
3071         RNA_def_property_ui_text(prop, "Angle Factor",
3072                                  "Reduce brush thickness by this factor when stroke is perpendicular to 'Angle' direction");
3073         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3074
3075         /* Smoothing factor for new strokes */
3076         prop = RNA_def_property(srna, "pen_smooth_factor", PROP_FLOAT, PROP_NONE);
3077         RNA_def_property_float_sdna(prop, NULL, "draw_smoothfac");
3078         RNA_def_property_range(prop, 0.0, 2.0f);
3079         RNA_def_property_ui_text(prop, "Smooth",
3080                                  "Amount of smoothing to apply to newly created strokes, to reduce jitter/noise");
3081         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3082
3083         /* Iterations of the Smoothing factor */
3084         prop = RNA_def_property(srna, "pen_smooth_steps", PROP_INT, PROP_NONE);
3085         RNA_def_property_int_sdna(prop, NULL, "draw_smoothlvl");
3086         RNA_def_property_range(prop, 1, 3);
3087         RNA_def_property_ui_text(prop, "Iterations",
3088                                  "Number of times to smooth newly created strokes");
3089         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3090
3091         /* Subdivision level for new strokes */
3092         prop = RNA_def_property(srna, "pen_subdivision_steps", PROP_INT, PROP_NONE);
3093         RNA_def_property_int_sdna(prop, NULL, "sublevel");
3094         RNA_def_property_range(prop, 0, 3);
3095         RNA_def_property_ui_text(prop, "Subdivision Steps",
3096                                  "Number of times to subdivide newly created strokes, for less jagged strokes");
3097         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3098
3099         /* Curves for pressure */
3100         prop = RNA_def_property(srna, "curve_sensitivity", PROP_POINTER, PROP_NONE);
3101         RNA_def_property_pointer_sdna(prop, NULL, "cur_sensitivity");
3102         RNA_def_property_struct_type(prop, "CurveMapping");
3103         RNA_def_property_ui_text(prop, "Curve Sensitivity", "Curve used for the sensitivity");
3104         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3105
3106         prop = RNA_def_property(srna, "curve_strength", PROP_POINTER, PROP_NONE);
3107         RNA_def_property_pointer_sdna(prop, NULL, "cur_strength");
3108         RNA_def_property_struct_type(prop, "CurveMapping");
3109         RNA_def_property_ui_text(prop, "Curve Strength", "Curve used for the strength");
3110         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3111
3112         prop = RNA_def_property(srna, "curve_jitter", PROP_POINTER, PROP_NONE);
3113         RNA_def_property_pointer_sdna(prop, NULL, "cur_jitter");
3114         RNA_def_property_struct_type(prop, "CurveMapping");
3115         RNA_def_property_ui_text(prop, "Curve Jitter", "Curve used for the jitter effect");
3116         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3117
3118         /* Flags */
3119         prop = RNA_def_property(srna, "use_pressure", PROP_BOOLEAN, PROP_NONE);
3120         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_PRESSURE);
3121         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
3122         RNA_def_property_ui_text(prop, "Use Pressure", "Use tablet pressure");
3123         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3124
3125         prop = RNA_def_property(srna, "use_strength_pressure", PROP_BOOLEAN, PROP_NONE);
3126         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_STENGTH_PRESSURE);
3127         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
3128         RNA_def_property_ui_text(prop, "Use Pressure Strength", "Use tablet pressure for color strength");
3129         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3130
3131         prop = RNA_def_property(srna, "use_jitter_pressure", PROP_BOOLEAN, PROP_NONE);
3132         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_JITTER_PRESSURE);
3133         RNA_def_property_ui_icon(prop, ICON_STYLUS_PRESSURE, 0);
3134         RNA_def_property_ui_text(prop, "Use Pressure Jitter", "Use tablet pressure for jitter");
3135         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3136
3137         prop = RNA_def_property(srna, "use_random_pressure", PROP_BOOLEAN, PROP_NONE);
3138         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_RANDOM_PRESSURE);
3139         RNA_def_property_ui_icon(prop, ICON_PARTICLES, 0);
3140         RNA_def_property_ui_text(prop, "Random Pressure", "Use random value for pressure");
3141         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3142
3143         prop = RNA_def_property(srna, "use_random_strength", PROP_BOOLEAN, PROP_NONE);
3144         RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_BRUSH_USE_RANDOM_STRENGTH);
3145         RNA_def_property_ui_icon(prop, ICON_PARTICLES, 0);
3146         RNA_def_property_ui_text(prop, "Random Strength", "Use random value for strength");
3147         RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, NULL);
3148
3149 }
3150
3151 /* Grease Pencil Drawing Brushes API */
3152 static void rna_def_gpencil_brushes(BlenderRNA *brna, PropertyRNA *cprop)
3153 {
3154         StructRNA *srna;
3155         PropertyRNA *prop;
3156
3157         FunctionRNA *func;
3158         PropertyRNA *parm;
3159
3160         RNA_def_property_srna(cprop, "GreasePencilBrushes");
3161         srna = RNA_def_struct(brna, "GreasePencilBrushes", NULL);
3162         RNA_def_struct_sdna(srna, "ToolSettings");
3163         RNA_def_struct_ui_text(srna, "Grease Pencil Brushes", "Collection of grease pencil brushes");
3164
3165         func = RNA_def_function(srna, "new", "rna_GPencil_brush_new");
3166         RNA_def_function_ui_description(func, "Add a new grease pencil brush");
3167         parm = RNA_def_string(func, "name", "GPencilBrush", MAX_NAME, "Name", "Name of the brush");
3168         RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
3169         RNA_def_boolean(func, "set_active", 0, "Set Active", "Set the newly created brush to the active brush");
3170         parm = RNA_def_pointer(func, "palette", "GPencilBrush", "", "The newly created brush");
3171         RNA_def_function_return(func, parm);
3172
3173         func = RNA_def_function(srna, "remove", "rna_GPencil_brush_remove");
3174         RNA_def_function_ui_description(func, "Remove a grease pencil brush");
3175         RNA_def_function_flag(func, FUNC_USE_REPORTS);
3176         parm = RNA_def_pointer(func, "brush", "GPencilBrush", "", "The brush to remove");
3177         RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED | PARM_RNAPTR);
3178         RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
3179
3180         prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
3181         RNA_def_property_struct_type(prop, "GPencilBrush");
3182         RNA_def_property_pointer_funcs(prop, "rna_GPencilBrushes_active_get", "rna_GPencilBrushes_active_set", NULL, NULL);
3183         RNA_def_property_flag(prop, PROP_EDITABLE);
3184         RNA_def_property_ui_text(prop, "Active Brush", "Current active brush");
3185
3186         prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
3187         RNA_def_property_int_funcs(prop,
3188                 "rna_GPencilBrushes_index_get",
3189                 "rna_GPencilBrushes_index_set",
3190                 "rna_GPencilBrushes_index_range");
3191         RNA_def_property_ui_text(prop, "Active Brush Index", "Index of active brush");
3192 }
3193
3194 static void rna_def_transform_orientation(BlenderRNA *brna)
3195 {
3196         StructRNA *srna;
3197         PropertyRNA *prop;
3198         
3199         srna = RNA_def_struct(brna, "TransformOrientation", NULL);
3200         
3201         prop = RNA_def_property(srna, "matrix", PROP_FLOAT, PROP_MATRIX);
3202         RNA_def_property_float_sdna(prop, NULL, "mat");
3203         RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_3x3);
3204         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_VIEW3D, NULL);
3205         
3206         prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
3207         RNA_def_struct_name_property(srna, prop);
3208         RNA_def_property_ui_text(prop, "Name", "Name of the custom transform orientation");
3209         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_VIEW3D, NULL);
3210 }
3211
3212 static void rna_def_tool_settings(BlenderRNA  *brna)
3213 {
3214         StructRNA *srna;
3215         PropertyRNA *prop;
3216
3217         static EnumPropertyItem uv_select_mode_items[] = {
3218                 {UV_SELECT_VERTEX, "VERTEX", ICON_UV_VERTEXSEL, "Vertex", "Vertex selection mode"},
3219                 {UV_SELECT_EDGE, "EDGE", ICON_UV_EDGESEL, "Edge", "Edge selection mode"},
3220                 {UV_SELECT_FACE, "FACE", ICON_UV_FACESEL, "Face", "Face selection mode"},
3221                 {UV_SELECT_ISLAND, "ISLAND", ICON_UV_ISLANDSEL, "Island", "Island selection mode"},
3222                 {0, NULL, 0, NULL, NULL}
3223         };
3224         
3225         /* the construction of this enum is quite special - everything is stored as bitflags,
3226          * with 1st position only for for on/off (and exposed as boolean), while others are mutually
3227          * exclusive options but which will only have any effect when autokey is enabled
3228          */
3229         static EnumPropertyItem auto_key_items[] = {
3230                 {AUTOKEY_MODE_NORMAL & ~AUTOKEY_ON, "ADD_REPLACE_KEYS", 0, "Add & Replace", ""},
3231                 {AUTOKEY_MODE_EDITKEYS & ~AUTOKEY_ON, "REPLACE_KEYS", 0, "Replace", ""},
3232                 {0, NULL, 0, NULL, NULL}
3233         };
3234
3235         static EnumPropertyItem retarget_roll_items[] = {
3236                 {SK_RETARGET_ROLL_NONE, "NONE", 0, "None", "Don't adjust roll"},
3237                 {SK_RETARGET_ROLL_VIEW, "VIEW", 0, "View", "Roll bones to face the view"},
3238                 {SK_RETARGET_ROLL_JOINT, "JOINT", 0, "Joint", "Roll bone to original joint plane offset"},
3239                 {0, NULL, 0, NULL, NULL}
3240         };
3241         
3242         static EnumPropertyItem sketch_convert_items[] = {
3243                 {SK_CONVERT_CUT_FIXED, "FIXED", 0, "Fixed", "Subdivide stroke in fixed number of bones"},
3244                 {SK_CONVERT_CUT_LENGTH, "LENGTH", 0, "Length", "Subdivide stroke in bones of specific length"},
3245                 {SK_CONVERT_CUT_ADAPTATIVE, "ADAPTIVE", 0, "Adaptive",
3246                  "Subdivide stroke adaptively, with more subdivision in curvier parts"},
3247                 {SK_CONVERT_RETARGET, "RETARGET", 0, "Retarget", "Retarget template bone chain to stroke"},
3248                 {0, NULL, 0, NULL, NULL}
3249         };
3250
3251         static EnumPropertyItem edge_tag_items[] = {
3252                 {EDGE_MODE_SELECT, "SELECT", 0, "Select", ""},
3253                 {EDGE_MODE_TAG_SEAM, "SEAM", 0, "Tag Seam", ""},
3254                 {EDGE_MODE_TAG_SHARP, "SHARP", 0, "Tag Sharp", ""},
3255                 {EDGE_MODE_TAG_CREASE, "CREASE", 0, "Tag Crease", ""},
3256                 {EDGE_MODE_TAG_BEVEL, "BEVEL", 0, "Tag Bevel", ""},
3257                 {EDGE_MODE_TAG_FREESTYLE, "FREESTYLE", 0, "Tag Freestyle Edge Mark", ""},
3258                 {0, NULL, 0, NULL, NULL}
3259         };
3260
3261         static EnumPropertyItem draw_groupuser_items[] = {
3262                 {OB_DRAW_GROUPUSER_NONE, "NONE", 0, "None", ""},
3263                 {OB_DRAW_GROUPUSER_ACTIVE, "ACTIVE", 0, "Active", "Show vertices with no weights in the active group"},
3264                 {OB_DRAW_GROUPUSER_ALL, "ALL", 0, "All", "Show vertices with no weights in any group"},
3265                 {0, NULL, 0, NULL, NULL}
3266         };
3267
3268         static EnumPropertyItem vertex_group_select_items[] = {
3269                 {WT_VGROUP_ALL, "ALL", 0, "All", "All Vertex Groups"},
3270                 {WT_VGROUP_BONE_DEFORM, "BONE_DEFORM", 0, "Deform", "Vertex Groups assigned to Deform Bones"},
3271                 {WT_VGROUP_BONE_DEFORM_OFF, "OTHER_DEFORM", 0, "Other", "Vertex Groups assigned to non Deform Bones"},
3272                 {0, NULL, 0, NULL, NULL}
3273         };
3274         
3275         static EnumPropertyItem gpencil_source_3d_items[] = {
3276                 {GP_TOOL_SOURCE_SCENE, "SCENE", 0, "Scene",
3277                  "Grease Pencil data attached to the current scene is used, "
3278                  "unless the active object already has Grease Pencil data (i.e. for old files)"},
3279                 {GP_TOOL_SOURCE_OBJECT, "OBJECT", 0, "Object",
3280                  "Grease Pencil data-blocks attached to the active object are used "
3281                  "(required when using pre 2.73 add-ons, e.g. BSurfaces)"},
3282                 {0, NULL, 0, NULL, NULL}
3283         };
3284         
3285         static EnumPropertyItem gpencil_stroke_placement_items[] = {
3286                 {GP_PROJECT_VIEWSPACE, "CURSOR", 0, "Cursor", "Draw stroke at the 3D cursor"},
3287                 {0, "VIEW", 0, "View", "Stick stroke to the view "}, /* weird, GP_PROJECT_VIEWALIGN is inverted */
3288                 {GP_PROJECT_VIEWSPACE | GP_PROJECT_DEPTH_VIEW, "SURFACE", 0, "Surface", "Stick stroke to surfaces"},
3289                 {GP_PROJECT_VIEWSPACE | GP_PROJECT_DEPTH_STROKE, "STROKE", 0, "Stroke", "Stick stroke to other strokes"},
3290                 {0, NULL, 0, NULL, NULL}
3291         };
3292         
3293         
3294         srna = RNA_def_struct(brna, "ToolSettings", NULL);
3295         RNA_def_struct_path_func(srna, "rna_ToolSettings_path");
3296         RNA_def_struct_ui_text(srna, "Tool Settings", "");
3297         
3298         prop = RNA_def_property(srna, "sculpt", PROP_POINTER, PROP_NONE);
3299         RNA_def_property_struct_type(prop, "Sculpt");
3300         RNA_def_property_ui_text(prop, "Sculpt", "");
3301         
3302         prop = RNA_def_property(srna, "use_auto_normalize", PROP_BOOLEAN, PROP_NONE);
3303         RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
3304         RNA_def_property_boolean_sdna(prop, NULL, "auto_normalize", 1);
3305         RNA_def_property_ui_text(prop, "WPaint Auto-Normalize",
3306                                  "Ensure all bone-deforming vertex groups add up "
3307                                  "to 1.0 while weight painting");
3308         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3309
3310         prop = RNA_def_property(srna, "use_multipaint", PROP_BOOLEAN, PROP_NONE);
3311         RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
3312         RNA_def_property_boolean_sdna(prop, NULL, "multipaint", 1);
3313         RNA_def_property_ui_text(prop, "WPaint Multi-Paint",
3314                                  "Paint across the weights of all selected bones, "
3315                                  "maintaining their relative influence");
3316         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3317
3318         prop = RNA_def_property(srna, "vertex_group_user", PROP_ENUM, PROP_NONE);
3319         RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
3320         RNA_def_property_enum_sdna(prop, NULL, "weightuser");
3321         RNA_def_property_enum_items(prop, draw_groupuser_items);
3322         RNA_def_property_ui_text(prop, "Mask Non-Group Vertices", "Display unweighted vertices");
3323         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3324
3325         prop = RNA_def_property(srna, "vertex_group_subset", PROP_ENUM, PROP_NONE);
3326         RNA_def_property_flag(prop, PROP_CONTEXT_UPDATE);
3327         RNA_def_property_enum_sdna(prop, NULL, "vgroupsubset");
3328         RNA_def_property_enum_items(prop, vertex_group_select_items);
3329         RNA_def_property_ui_text(prop, "Subset", "Filter Vertex groups for Display");
3330         RNA_def_property_update(prop, 0, "rna_Scene_update_active_object_data");
3331
3332         prop = RNA_def_property(srna, "vertex_paint", PROP_POINTER, PROP_NONE);
3333         RNA_def_property_pointer_sdna(prop, NULL, "vpaint");    RNA_def_property_ui_text(prop, "Vertex Paint", "");
3334
3335         prop = RNA_def_property(srna, "weight_paint", PROP_POINTER, PROP_NONE);
3336         RNA_def_property_pointer_sdna(prop, NULL, "wpaint");
3337         RNA_def_property_ui_text(prop, "Weight Paint", "");
3338
3339         prop = RNA_def_property(srna, "image_paint", PROP_POINTER, PROP_NONE);
3340         RNA_def_property_pointer_sdna(prop, NULL, "imapaint");
3341         RNA_def_property_ui_text(prop, "Image Paint", "");
3342
3343         prop = RNA_def_property(srna, "uv_sculpt", PROP_POINTER, PROP_NONE);
3344         RNA_def_property_pointer_sdna(prop, NULL, "uvsculpt");
3345         RNA_def_property_ui_text(prop, "UV Sculpt", "");
3346
3347         prop = RNA_def_property(srna, "particle_edit", PROP_POINTER, PROP_NONE);
3348         RNA_def_property_pointer_sdna(prop, NULL, "particle");
3349         RNA_def_property_ui_text(prop, "Particle Edit", "");
3350
3351         prop = RNA_def_property(srna, "use_uv_sculpt", PROP_BOOLEAN, PROP_NONE);
3352         RNA_def_property_boolean_sdna(prop, NULL, "use_uv_sculpt", 1);
3353         RNA_def_property_ui_text(prop, "UV Sculpt", "Enable brush for UV sculpting");
3354         RNA_def_property_ui_icon(prop, ICON_TPAINT_HLT, 0);
3355         RNA_def_property_update(prop, NC_SPACE | ND_SPACE_IMAGE, "rna_SpaceImageEditor_uv_sculpt_update");
3356
3357         prop = RNA_def_property(srna, "uv_sculpt_lock_borders", PROP_BOOLEAN, PROP_NONE);
3358         RNA_def_property_boolean_sdna(prop, NULL, "uv_sculpt_settings", UV_SCULPT_LOCK_BORDERS);
3359         RNA_def_property_ui_text(prop, "Lock Borders", "Disable editing of boundary edges");
3360
3361         prop = RNA_def_property(srna, "uv_sculpt_all_islands", PROP_BOOLEAN, PROP_NONE);
3362         RNA_def_property_boolean_sdna(prop, NULL, "uv_sculpt_settings", UV_SCULPT_ALL_ISLANDS);
3363         RNA_def_property_ui_text(prop, "Sculpt All Islands", "Brush operates on all islands");
3364
3365         prop = RNA_def_property(srna, "uv_sculpt_tool", PROP_ENUM, PROP_NONE);
3366         RNA_def_property_enum_sdna(prop, NULL, "uv_sculpt_tool");
3367         RNA_def_property_enum_items(prop, uv_sculpt_tool_items);
3368         RNA_def_property_ui_text(prop, "UV Sculpt Tools", "Select Tools for the UV sculpt brushes");
3369
3370         prop = RNA_def_property(srna, "uv_relax_method", PROP_ENUM, PROP_NONE);
3371         RNA_def_property_enum_sdna(prop, NULL, "uv_relax_method");
3372         RNA_def_property_enum_items(prop, uv_sculpt_relaxation_items);
3373         RNA_def_property_ui_text(prop, "Relaxation Method", "Algorithm used for UV relaxation");
3374
3375         /* Transform */
3376         prop = RNA_def_property(srna, "proportional_edit", PROP_ENUM, PROP_NONE);
3377         RNA_def_property_enum_sdna(prop, NULL, "proportional");
3378         RNA_def_property_enum_items(prop, rna_enum_proportional_editing_items);
3379         RNA_def_property_ui_text(prop, "Proportional Editing",
3380                                  "Proportional Editing mode, allows transforms with distance fall-off");
3381         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3382
3383         prop = RNA_def_property(srna, "use_proportional_edit_objects", PROP_BOOLEAN, PROP_NONE);
3384         RNA_def_property_boolean_sdna(prop, NULL, "proportional_objects", 0);
3385         RNA_def_property_ui_text(prop, "Proportional Editing Objects", "Proportional editing object mode");
3386         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3387         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3388
3389         prop = RNA_def_property(srna, "use_proportional_edit_mask", PROP_BOOLEAN, PROP_NONE);
3390         RNA_def_property_boolean_sdna(prop, NULL, "proportional_mask", 0);
3391         RNA_def_property_ui_text(prop, "Proportional Editing Objects", "Proportional editing mask mode");
3392         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3393         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3394
3395         prop = RNA_def_property(srna, "use_proportional_action", PROP_BOOLEAN, PROP_NONE);
3396         RNA_def_property_boolean_sdna(prop, NULL, "proportional_action", 0);
3397         RNA_def_property_ui_text(prop, "Proportional Editing Actions", "Proportional editing in action editor");
3398         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3399         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3400
3401         prop = RNA_def_property(srna, "use_proportional_fcurve", PROP_BOOLEAN, PROP_NONE);
3402         RNA_def_property_boolean_sdna(prop, NULL, "proportional_fcurve", 0);
3403         RNA_def_property_ui_text(prop, "Proportional Editing FCurves", "Proportional editing in FCurve editor");
3404         RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
3405         RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
3406
3407         prop = RNA_def_property(srna, "lock_markers", PROP_BOOLEAN, PROP_NONE);
3408         RNA_def_property_boolean_sdna(prop, NULL, "lock_markers", 0);
3409         RNA_def_property_ui_text(prop, "Lock Markers", "Prevent marker editing");
3410
3411         prop = RNA_def_property(srna, "proportional_edit_falloff", PROP_ENUM, PROP_NONE);
3412         RNA_def_property_enum_sdna(prop, NULL, "prop_mode");
3413         RNA_def_property_enum_items(prop, rna_enum_proportional_falloff_items);
3414         RNA_def_property_ui_text(prop, "Proportional Editing Falloff", "Falloff type for proportional editing mode");
3415         RNA_def_property_update(prop,&nbs