Revision: 17869
          
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=17869
Author:   blendix
Date:     2008-12-15 11:48:04 +0100 (Mon, 15 Dec 2008)

Log Message:
-----------

RNA:
* DNA_sequence_types.h done, patch by Roelf de Kock, with various changes,
  mainly the use of inheritance for different sequence types and hiding the
  separate Strip struct.

Modified Paths:
--------------
    
branches/blender2.5/blender/source/blender/editors/space_outliner/space_outliner.c
    branches/blender2.5/blender/source/blender/makesdna/DNA_sequence_types.h
    branches/blender2.5/blender/source/blender/makesrna/RNA_types.h
    branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_ID.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_image.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_scene.c

Added Paths:
-----------
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_sequence.c

Modified: 
branches/blender2.5/blender/source/blender/editors/space_outliner/space_outliner.c
===================================================================
--- 
branches/blender2.5/blender/source/blender/editors/space_outliner/space_outliner.c
  2008-12-15 08:37:39 UTC (rev 17868)
+++ 
branches/blender2.5/blender/source/blender/editors/space_outliner/space_outliner.c
  2008-12-15 10:48:04 UTC (rev 17869)
@@ -230,7 +230,8 @@
 
                if(nameprop)
                        nameptr= RNA_property_string_get_alloc(&lookup, 
nameprop, name, sizeof(name));
-               else
+
+               if(!nameprop || strlen(nameptr) == 0)
                        sprintf(nameptr, "%d", cell->index+1);
        }
 

Modified: 
branches/blender2.5/blender/source/blender/makesdna/DNA_sequence_types.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesdna/DNA_sequence_types.h    
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesdna/DNA_sequence_types.h    
2008-12-15 10:48:04 UTC (rev 17869)
@@ -182,9 +182,6 @@
        ListBase *seqbasep;
        ListBase seqbase;
        ListBase metastack;
-       short flag;
-       short pad;
-       int rt;
 } Editing;
 
 /* ************* Effect Variable Structs ********* */

Modified: branches/blender2.5/blender/source/blender/makesrna/RNA_types.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/RNA_types.h     
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/RNA_types.h     
2008-12-15 10:48:04 UTC (rev 17869)
@@ -62,10 +62,11 @@
        PROP_NONE = 0,
        PROP_UNSIGNED = 1,
        PROP_FILEPATH = 2,
-       PROP_COLOR = 3,
-       PROP_VECTOR = 4,
-       PROP_MATRIX = 5,
-       PROP_ROTATION = 6
+       PROP_DIRPATH = 3,
+       PROP_COLOR = 4,
+       PROP_VECTOR = 5,
+       PROP_MATRIX = 6,
+       PROP_ROTATION = 7
 } PropertySubType;
 
 typedef enum PropertyFlag {

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c       
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c       
2008-12-15 10:48:04 UTC (rev 17869)
@@ -638,6 +638,7 @@
                case PROP_NONE: return "PROP_NONE";
                case PROP_UNSIGNED: return "PROP_UNSIGNED";
                case PROP_FILEPATH: return "PROP_FILEPATH";
+               case PROP_DIRPATH: return "PROP_DIRPATH";
                case PROP_COLOR: return "PROP_COLOR";
                case PROP_VECTOR: return "PROP_VECTOR";
                case PROP_MATRIX: return "PROP_MATRIX";
@@ -921,6 +922,7 @@
        {"rna_scene.c", RNA_def_scene},
        {"rna_screen.c", RNA_def_screen},
        {"rna_sensor.c", RNA_def_sensor},
+       {"rna_sequence.c", RNA_def_sequence},
        {"rna_vfont.c", RNA_def_vfont},
        {"rna_wm.c", RNA_def_wm},
        {"rna_world.c", RNA_def_world}, 

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_ID.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_ID.c 
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_ID.c 
2008-12-15 10:48:04 UTC (rev 17869)
@@ -162,7 +162,7 @@
        RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* must be unique */
        RNA_def_property_ui_text(prop, "Name", "Unique datablock ID name.");
        RNA_def_property_string_funcs(prop, "rna_ID_name_get", 
"rna_ID_name_length", "rna_ID_name_set");
-       RNA_def_property_string_maxlength(prop, 22);
+       RNA_def_property_string_maxlength(prop, sizeof(((ID*)NULL)->name)-2);
        RNA_def_struct_name_property(srna, prop);
 
        prop= RNA_def_property(srna, "users", PROP_INT, PROP_UNSIGNED);

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_image.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_image.c      
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_image.c      
2008-12-15 10:48:04 UTC (rev 17869)
@@ -145,7 +145,7 @@
 
        prop= RNA_def_property(srna, "premultiply", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_DO_PREMUL);
-       RNA_def_property_ui_text(prop, "Premultiply", "Convert from key alpha 
to premultiplied alpha.");
+       RNA_def_property_ui_text(prop, "Premultiply", "Convert RGB from key 
alpha to premultiplied alpha.");
 
        /* generated image (image_generated_change_cb) */
        prop= RNA_def_property(srna, "generated_type", PROP_ENUM, PROP_NONE);

Modified: 
branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h   
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h   
2008-12-15 10:48:04 UTC (rev 17869)
@@ -123,6 +123,7 @@
 void RNA_def_scene(struct BlenderRNA *brna);
 void RNA_def_screen(struct BlenderRNA *brna);
 void RNA_def_sensor(struct BlenderRNA *brna);
+void RNA_def_sequence(struct BlenderRNA *brna);
 void RNA_def_vfont(struct BlenderRNA *brna);
 void RNA_def_wm(struct BlenderRNA *brna);
 void RNA_def_world(struct BlenderRNA *brna);

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_scene.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_scene.c      
2008-12-15 08:37:39 UTC (rev 17868)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_scene.c      
2008-12-15 10:48:04 UTC (rev 17869)
@@ -143,6 +143,11 @@
        
        prop= RNA_def_property(srna, "nodetree", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Node Tree", "Compositing node tree.");
+       
+       prop= RNA_def_property(srna, "sequence_editor", PROP_POINTER, 
PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "ed");
+       RNA_def_property_struct_type(prop, "SequenceEditor");
+       RNA_def_property_ui_text(prop, "Sequence Editor", "");
 
        prop= RNA_def_property(srna, "radiosity", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "radio");

Added: branches/blender2.5/blender/source/blender/makesrna/intern/rna_sequence.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_sequence.c   
                        (rev 0)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_sequence.c   
2008-12-15 10:48:04 UTC (rev 17869)
@@ -0,0 +1,865 @@
+/**
+ * $Id$
+ *
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ *
+ * Contributor(s): Blender Foundation (2008)
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <stdlib.h>
+#include <limits.h>
+
+#include "RNA_define.h"
+#include "RNA_types.h"
+
+#include "rna_internal.h"
+
+#include "DNA_object_types.h"
+#include "DNA_scene_types.h"
+#include "DNA_sequence_types.h"
+
+#ifdef RNA_RUNTIME
+
+/* name functions that ignore the first two characters */
+static void rna_Sequence_name_get(PointerRNA *ptr, char *value)
+{
+       Sequence *seq= (Sequence*)ptr->data;
+       BLI_strncpy(value, seq->name+2, sizeof(seq->name)-2);
+}
+
+static int rna_Sequence_name_length(PointerRNA *ptr)
+{
+       Sequence *seq= (Sequence*)ptr->data;
+       return strlen(seq->name+2);
+}
+
+static void rna_Sequence_name_set(PointerRNA *ptr, const char *value)
+{
+       Sequence *seq= (Sequence*)ptr->data;
+       BLI_strncpy(seq->name+2, value, sizeof(seq->name)-2);
+}
+
+static StructRNA* rna_Sequence_refine(struct PointerRNA *ptr)
+{
+       Sequence *seq= (Sequence*)ptr->data;
+
+       switch(seq->type) {
+               case SEQ_IMAGE:
+                       return &RNA_ImageSequence;
+               case SEQ_META:
+                       return &RNA_MetaSequence;
+               case SEQ_SCENE:
+                       return &RNA_SceneSequence;
+               case SEQ_MOVIE:
+               case SEQ_MOVIE_AND_HD_SOUND:
+                       return &RNA_MovieSequence;
+               case SEQ_RAM_SOUND:
+               case SEQ_HD_SOUND:
+                       return &RNA_SoundSequence;
+               case SEQ_CROSS:
+               case SEQ_ADD:
+               case SEQ_SUB:
+               case SEQ_ALPHAOVER:
+               case SEQ_ALPHAUNDER:
+               case SEQ_GAMCROSS:
+               case SEQ_MUL:
+               case SEQ_OVERDROP:
+                       return &RNA_EffectSequence;
+               case SEQ_PLUGIN:
+                       return &RNA_PluginSequence;
+               case SEQ_WIPE:
+                       return &RNA_WipeSequence;
+               case SEQ_GLOW:
+                       return &RNA_GlowSequence;
+               case SEQ_TRANSFORM:
+                       return &RNA_TransformSequence;
+               case SEQ_COLOR:
+                       return &RNA_ColorSequence;
+               case SEQ_SPEED:
+                       return &RNA_SpeedControlSequence;
+               default:
+                       return &RNA_Sequence;
+       }
+}
+
+static void *rna_SequenceEdtior_meta_stack_get(CollectionPropertyIterator 
*iter)
+{
+       ListBaseIterator *internal= iter->internal;
+       MetaStack *ms= (MetaStack*)internal->link;
+
+       return (Sequence*)ms->parseq;
+}
+
+#else
+
+static void rna_def_strip_element(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+       
+       srna = RNA_def_struct(brna, "SequenceElement", NULL, "Sequence 
Element");
+       RNA_def_struct_sdna(srna, "StripElem");
+       
+       prop= RNA_def_property(srna, "filename", PROP_STRING, PROP_FILEPATH);
+       RNA_def_property_string_sdna(prop, NULL, "name");
+       RNA_def_property_ui_text(prop, "Filename", "");
+}
+
+static void rna_def_strip_crop(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+       
+       srna = RNA_def_struct(brna, "SequenceCrop", NULL, "Sequence Crop");
+       RNA_def_struct_sdna(srna, "StripCrop");
+
+       prop= RNA_def_property(srna, "top", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_ui_text(prop, "Top", "");
+       RNA_def_property_ui_range(prop, 0, 4096, 1, 0);
+       
+       prop= RNA_def_property(srna, "bottom", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_ui_text(prop, "Bottom", "");
+       RNA_def_property_ui_range(prop, 0, 4096, 1, 0);
+       
+       prop= RNA_def_property(srna, "left", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_ui_text(prop, "Left", "");

@@ Diff output truncated at 10240 characters. @@

_______________________________________________
Bf-blender-cvs mailing list
Bf-blender-cvs@blender.org
http://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to