Cycles: svn merge -r40266:40358 https://svn.blender.org/svnroot/bf-blender/trunk...
[blender-staging.git] / source / blender / makesrna / intern / rna_scene_api.c
index d4891ada52bcd2d9becb8e2cf2e0629e0387236f..124fa9037e342af85e43417b9622e3439a5ff93e 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * $Id$
  *
  * ***** BEGIN GPL LICENSE BLOCK *****
  * ***** END GPL LICENSE BLOCK *****
  */
 
+/** \file blender/makesrna/intern/rna_scene_api.c
+ *  \ingroup RNA
+ */
+
+
 #include <stdlib.h>
 #include <stdio.h>
 
@@ -55,12 +60,18 @@ static void rna_Scene_frame_set(Scene *scene, int frame, float subframe)
        CLAMP(scene->r.cfra, MINAFRAME, MAXFRAME);
        scene_update_for_newframe(G.main, scene, (1<<20) - 1);
 
-       WM_main_add_notifier(NC_SCENE|ND_FRAME, scene);
+       /* cant use NC_SCENE|ND_FRAME because this casues wm_event_do_notifiers to call 
+        * scene_update_for_newframe which will loose any un-keyed changes [#24690] */
+       /* WM_main_add_notifier(NC_SCENE|ND_FRAME, scene); */
+       
+       /* instead just redraw the views */
+       WM_main_add_notifier(NC_WINDOW, NULL);
 }
 
 static void rna_Scene_update_tagged(Scene *scene)
 {
        scene_update_tagged(G.main, scene);
+       scene_clear_tagged(G.main, scene);
 }
 
 static void rna_SceneRender_get_frame_path(RenderData *rd, int frame, char *name)
@@ -68,18 +79,16 @@ static void rna_SceneRender_get_frame_path(RenderData *rd, int frame, char *name
        if(BKE_imtype_is_movie(rd->imtype))
                BKE_makeanimstring(name, rd);
        else
-               BKE_makepicstring(name, rd->pic, (frame==INT_MIN) ? rd->cfra : frame, rd->imtype, rd->scemode & R_EXTENSION);
+               BKE_makepicstring(name, rd->pic, (frame==INT_MIN) ? rd->cfra : frame, rd->imtype, rd->scemode & R_EXTENSION, TRUE);
 }
 
 #ifdef WITH_COLLADA
-
+/* don't remove this, as COLLADA exporting cannot be done through operators in render() callback. */
 #include "../../collada/collada.h"
 
-static void rna_Scene_collada_export(Scene *scene, char *filepath)
+static void rna_Scene_collada_export(Scene *scene, const char *filepath, int selected)
 {
-       /* XXX not really nice, as this will bring essentially in COLLADA as dependency for
-        * blenderplayer. For now stubbing in blc. */
-       collada_export(scene, filepath);
+       collada_export(scene, filepath, selected);
 }
 
 #endif
@@ -92,34 +101,38 @@ void RNA_api_scene(StructRNA *srna)
        PropertyRNA *parm;
 
        func= RNA_def_function(srna, "frame_set", "rna_Scene_frame_set");
-       RNA_def_function_ui_description(func, "Set scene frame updating all objects immediately.");
-       parm= RNA_def_int(func, "frame", 0, MINAFRAME, MAXFRAME, "", "Frame number to set.", MINAFRAME, MAXFRAME);
+       RNA_def_function_ui_description(func, "Set scene frame updating all objects immediately");
+       parm= RNA_def_int(func, "frame", 0, MINAFRAME, MAXFRAME, "", "Frame number to set", MINAFRAME, MAXFRAME);
        RNA_def_property_flag(parm, PROP_REQUIRED);
-       parm= RNA_def_float(func, "subframe", 0.0, 0.0, 1.0, "", "Sub-frame time, between 0.0 and 1.0", 0.0, 1.0);
+       RNA_def_float(func, "subframe", 0.0, 0.0, 1.0, "", "Sub-frame time, between 0.0 and 1.0", 0.0, 1.0);
 
        func= RNA_def_function(srna, "update", "rna_Scene_update_tagged");
-       RNA_def_function_ui_description(func, "Update data tagged to be updated from previous access to data or operators.");
+       RNA_def_function_ui_description(func, "Update data tagged to be updated from previous access to data or operators");
 
 #ifdef WITH_COLLADA
+       /* don't remove this, as COLLADA exporting cannot be done through operators in render() callback. */
        func= RNA_def_function(srna, "collada_export", "rna_Scene_collada_export");
-       parm= RNA_def_string(func, "filepath", "", FILE_MAX, "File Path", "File path to write Collada file.");
+       RNA_def_string(func, "filepath", "", FILE_MAX, "File Path", "File path to write Collada file");
+       parm= RNA_def_boolean(func, "selected", 0, "Export only selected", "Export only selected elements");
        RNA_def_property_flag(parm, PROP_REQUIRED);
        RNA_def_property_subtype(parm, PROP_FILEPATH); /* allow non utf8 */
-       RNA_def_function_ui_description(func, "Export to collada file.");
+       RNA_def_function_ui_description(func, "Export to collada file");
 #endif
 }
 
+
 void RNA_api_scene_render(StructRNA *srna)
 {
        FunctionRNA *func;
        PropertyRNA *parm;
 
        func= RNA_def_function(srna, "frame_path", "rna_SceneRender_get_frame_path");
-       RNA_def_function_ui_description(func, "Return the absolute path to the filename to be written for a given frame.");
-       parm= RNA_def_int(func, "frame", INT_MIN, INT_MIN, INT_MAX, "", "Frame number to use, if unset the current frame will be used.", MINAFRAME, MAXFRAME);
-       parm= RNA_def_string(func, "filepath", "", FILE_MAX, "File Path", "the resulting filepath from the scenes render settings.");
+       RNA_def_function_ui_description(func, "Return the absolute path to the filename to be written for a given frame");
+       RNA_def_int(func, "frame", INT_MIN, INT_MIN, INT_MAX, "",
+                   "Frame number to use, if unset the current frame will be used", MINAFRAME, MAXFRAME);
+       parm= RNA_def_string_file_path(func, "filepath", "", FILE_MAX, "File Path",
+                                      "The resulting filepath from the scenes render settings");
        RNA_def_property_flag(parm, PROP_THICK_WRAP); /* needed for string return value */
-       RNA_def_property_subtype(parm, PROP_FILEPATH); /* allow non utf8 */
        RNA_def_function_output(func, parm);
 }