Applied patch #23379. Does not change existing .blend files and looks
[blender.git] / source / blender / makesrna / intern / rna_nodetree.c
index d1e73d6add30a636dcbd90fcd0b21600905c1f92..5044518ca93d39ede12d9431c178f2bbc8f8f605 100644 (file)
@@ -15,9 +15,9 @@
  *
  * 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.
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  *
- * Contributor(s): Blender Foundation (2008), Nathan Letwory, Robin Allen
+ * Contributor(s): Blender Foundation (2008), Nathan Letwory, Robin Allen, Bob Holcomb
  *
  * ***** END GPL LICENSE BLOCK *****
  */
@@ -25,9 +25,7 @@
 #include <stdlib.h>
 #include <string.h>
 
-#include "RNA_access.h"
 #include "RNA_define.h"
-#include "RNA_types.h"
 
 #include "rna_internal.h"
 
 #include "BKE_image.h"
 #include "BKE_texture.h"
 
+#include "BLI_math.h"
+
 #include "WM_types.h"
 
+#include "MEM_guardedalloc.h"
+
 #ifdef RNA_RUNTIME
 
 #include "ED_node.h"
@@ -63,6 +65,9 @@ static StructRNA *rna_Node_refine(struct PointerRNA *ptr)
                
                #undef DefNode
                
+               case NODE_GROUP:
+                       return &RNA_NodeGroup;
+                       
                default:
                        return &RNA_Node;
        }
@@ -111,21 +116,6 @@ static char *rna_NodeSocket_path(PointerRNA *ptr)
        return NULL;
 }
 
-static int has_nodetree(bNodeTree *ntree, bNodeTree *lookup)
-{
-       bNode *node;
-
-       if(ntree == lookup)
-               return 1;
-       
-       for(node=ntree->nodes.first; node; node=node->next)
-               if(node->type == NODE_GROUP && node->id)
-                       if(has_nodetree((bNodeTree*)node->id, lookup))
-                               return 1;
-       
-       return 0;
-}
-
 /* Button Set Funcs for Matte Nodes */
 static void rna_Matte_t1_set(PointerRNA *ptr, float value)
 {
@@ -149,24 +139,27 @@ static void rna_Matte_t2_set(PointerRNA *ptr, float value)
        chroma->t2 = value;
 }
 
-static void node_update(Main *bmain, Scene *scene, bNodeTree *ntree, bNode *node)
+static void rna_Image_start_frame_set(PointerRNA *ptr, int value)
 {
-       Material *ma;
-       Tex *tex;
-       Scene *sce;
-       
-       /* look through all datablocks, to support groups */
-       for(ma=bmain->mat.first; ma; ma=ma->id.next)
-               if(ma->nodetree && ma->use_nodes && has_nodetree(ma->nodetree, ntree))
-                       ED_node_changed_update(&ma->id, node);
-       
-       for(tex=bmain->tex.first; tex; tex=tex->id.next)
-               if(tex->nodetree && tex->use_nodes && has_nodetree(tex->nodetree, ntree))
-                       ED_node_changed_update(&tex->id, node);
+       bNode *node= (bNode*)ptr->data;
+       NodeImageFile *image = node->storage;
        
-       for(sce=bmain->scene.first; sce; sce=sce->id.next)
-               if(sce->nodetree && sce->use_nodes && has_nodetree(sce->nodetree, ntree))
-                       ED_node_changed_update(&sce->id, node);
+       CLAMP(value, MINFRAME, image->efra); 
+       image->sfra= value;
+}
+
+static void rna_Image_end_frame_set(PointerRNA *ptr, int value)
+{
+       bNode *node= (bNode*)ptr->data;
+       NodeImageFile *image = node->storage;
+
+       CLAMP(value, image->sfra, MAXFRAME);
+       image->efra= value;
+}
+
+static void node_update(Main *bmain, Scene *scene, bNodeTree *ntree, bNode *node)
+{
+       ED_node_generic_update(bmain, scene, ntree, node);
 }
 
 static void rna_Node_update(Main *bmain, Scene *scene, PointerRNA *ptr)
@@ -177,14 +170,24 @@ static void rna_Node_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        node_update(bmain, scene, ntree, node);
 }
 
+static void rna_NodeGroup_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       bNodeTree *ntree= (bNodeTree*)ptr->id.data;
+       bNode *node= (bNode*)ptr->data;
+       
+       nodeVerifyGroup((bNodeTree *)node->id);
+       
+       node_update(bmain, scene, ntree, node);
+}
+
 static void rna_Node_update_name(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        bNodeTree *ntree= (bNodeTree*)ptr->id.data;
        bNode *node= (bNode*)ptr->data;
-       char oldname[32];
+       char oldname[sizeof(node->name)];
        
        /* make a copy of the old name first */
-       BLI_strncpy(oldname, node->name, sizeof(oldname));
+       BLI_strncpy(oldname, node->name, sizeof(node->name));
        
        nodeUniqueName(ntree, node);
        node->flag |= NODE_CUSTOM_NAME;
@@ -474,7 +477,7 @@ static EnumPropertyItem node_filter_items[] = {
 
 enum
 {
-       Category_NoCategory,
+       Category_GroupNode,
        Category_ShaderNode,
        Category_CompositorNode,
        Category_TextureNode
@@ -521,6 +524,8 @@ static void init(void)
        
        #undef DefNode
        #undef Str
+       
+       reg_node(NODE_GROUP, Category_GroupNode, "GROUP", "NodeGroup", "Node", "Group", "");
 }
 
 static StructRNA* def_node(BlenderRNA *brna, int node_id)
@@ -535,17 +540,17 @@ static StructRNA* def_node(BlenderRNA *brna, int node_id)
        return srna;
 }
 
-static EnumPropertyItem* alloc_node_type_items(int category)
+void alloc_node_type_items(EnumPropertyItem *items, int category)
 {
        int i;
-       int count = 2;
-       EnumPropertyItem *item, *items;
+       int count = 3;
+       EnumPropertyItem *item  = items;
        
        for(i=0; i<MaxNodes; i++)
                if(nodes[i].defined && nodes[i].category == category)
                        count++;
                
-       item = items = malloc(count * sizeof(EnumPropertyItem));
+       /*item = items = MEM_callocN(count * sizeof(EnumPropertyItem), "alloc_node_type_items");*/
        
        for(i=0; i<MaxNodes; i++) {
                NodeInfo *node = nodes + i;
@@ -562,19 +567,41 @@ static EnumPropertyItem* alloc_node_type_items(int category)
        
        item->value = NODE_DYNAMIC;
        item->identifier = "SCRIPT";
+       item->icon = 0;
        item->name = "Script";
        item->description = "";
        
        item++;
        
-       memset(item, 0, sizeof(EnumPropertyItem));
+       item->value = NODE_GROUP;
+       item->identifier = "GROUP";
+       item->icon = 0;
+       item->name = "Group";
+       item->description = "";
        
-       return items;
+       item++;
+       
+       /* NOTE!, increase 'count' when adding items here */
+       
+       memset(item, 0, sizeof(EnumPropertyItem));
 }
 
 
 /* -- Common nodes ---------------------------------------------------------- */
 
+static void def_group(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       
+       prop = RNA_def_property(srna, "nodetree", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "id");
+       RNA_def_property_struct_type(prop, "NodeTree");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Node Tree", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeGroup_update");
+}
+
+
 static void def_math(StructRNA *srna)
 {
        PropertyRNA *prop;
@@ -629,12 +656,12 @@ static void def_time(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Curve", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "start", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_start", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "custom1");
        RNA_def_property_ui_text(prop, "Start Frame", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "end", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_end", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "custom2");
        RNA_def_property_ui_text(prop, "End Frame", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -661,7 +688,7 @@ static void def_mix_rgb(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Blend Type", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "alpha", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_alpha", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom2", 1);
        RNA_def_property_ui_text(prop, "Alpha", "Include alpha of second input in this operation");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -698,12 +725,12 @@ static void def_sh_material(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Material", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 
-       prop = RNA_def_property(srna, "diffuse", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_diffuse", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", SH_NODE_MAT_DIFF);
        RNA_def_property_ui_text(prop, "Diffuse", "Material Node outputs Diffuse");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 
-       prop = RNA_def_property(srna, "specular", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_specular", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", SH_NODE_MAT_SPEC);
        RNA_def_property_ui_text(prop, "Specular", "Material Node outputs Specular");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -738,23 +765,23 @@ static void def_sh_mapping(StructRNA *srna)
        RNA_def_property_ui_range(prop, -10.f, 10.f, 0.1f, 2);
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_mapping_update");
        
-       prop = RNA_def_property(srna, "clamp_minimum", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_min", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", TEXMAP_CLIP_MIN);
        RNA_def_property_ui_text(prop, "Clamp Minimum", "Clamp the output coordinate to a minimum value");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop= RNA_def_property(srna, "minimum", PROP_FLOAT, PROP_XYZ);
+       prop= RNA_def_property(srna, "min", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "min");
        RNA_def_property_ui_text(prop, "Minimum", "Minimum value to clamp coordinate to");
        RNA_def_property_ui_range(prop, -10.f, 10.f, 0.1f, 2);
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "clamp_maximum", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_max", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", TEXMAP_CLIP_MAX);
        RNA_def_property_ui_text(prop, "Clamp Maximum", "Clamp the output coordinate to a maximum value");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop= RNA_def_property(srna, "maximum", PROP_FLOAT, PROP_XYZ);
+       prop= RNA_def_property(srna, "max", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "max");
        RNA_def_property_ui_text(prop, "Maximum", "Maximum value to clamp coordinate to");
        RNA_def_property_ui_range(prop, -10.f, 10.f, 0.1f, 2);
@@ -786,7 +813,7 @@ static void def_cmp_alpha_over(StructRNA *srna)
        PropertyRNA *prop;
        
        // XXX: Tooltip
-       prop = RNA_def_property(srna, "convert_premul", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_premultiply", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", 1);
        RNA_def_property_ui_text(prop, "Convert Premul", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -806,19 +833,19 @@ static void def_cmp_hue_saturation(StructRNA *srna)
 
        RNA_def_struct_sdna_from(srna, "NodeHueSat", "storage");
        
-       prop = RNA_def_property(srna, "hue", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_hue", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "hue");
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "Hue", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "sat", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_saturation", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "sat");
        RNA_def_property_range(prop, 0.0f, 2.0f);
        RNA_def_property_ui_text(prop, "Saturation", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "val", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_value", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "val");
        RNA_def_property_range(prop, 0.0f, 2.0f);
        RNA_def_property_ui_text(prop, "Value", "");
@@ -842,21 +869,21 @@ static void def_cmp_blur(StructRNA *srna)
 
        RNA_def_struct_sdna_from(srna, "NodeBlurData", "storage");
        
-       prop = RNA_def_property(srna, "sizex", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "size_x", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "sizex");
        RNA_def_property_range(prop, 0, 256);
        RNA_def_property_ui_text(prop, "Size X", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "sizey", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "size_y", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "sizey");
        RNA_def_property_range(prop, 0, 256);
        RNA_def_property_ui_text(prop, "Size Y", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 
-       prop = RNA_def_property(srna, "relative", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_relative", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "relative", 1);
-       RNA_def_property_ui_text(prop, "Relative", "");
+       RNA_def_property_ui_text(prop, "Relative", "Use relative (percent) values to define blur radius");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
@@ -883,14 +910,14 @@ static void def_cmp_blur(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Filter Type", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "bokeh", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_bokeh", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "bokeh", 1);
-       RNA_def_property_ui_text(prop, "Bokeh", "");
+       RNA_def_property_ui_text(prop, "Bokeh", "Uses circular filter (slower)");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "gamma", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_gamma_correction", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gamma", 1);
-       RNA_def_property_ui_text(prop, "Gamma", "");
+       RNA_def_property_ui_text(prop, "Gamma", "Applies filter on gamma corrected values");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
 }
@@ -959,25 +986,29 @@ static void def_cmp_vector_blur(StructRNA *srna)
        
        prop = RNA_def_property(srna, "samples", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "samples");
+       RNA_def_property_range(prop, 1, 256);
        RNA_def_property_ui_text(prop, "Samples", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "min_speed", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "speed_min", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "minspeed");
+       RNA_def_property_range(prop, 0, 1024);
        RNA_def_property_ui_text(prop, "Min Speed", "Minimum speed for a pixel to be blurred; used to separate background from foreground");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
                
-       prop = RNA_def_property(srna, "max_speed", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "speed_max", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "maxspeed");
+       RNA_def_property_range(prop, 0, 1024);
        RNA_def_property_ui_text(prop, "Max Speed", "Maximum speed, or zero for none");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "fac");
+       RNA_def_property_range(prop, 0.0f, 2.0f);
        RNA_def_property_ui_text(prop, "Blur Factor", "Scaling factor for motion vectors; actually 'shutter speed' in frames");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "curved", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_curved", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "curved", 1);
        RNA_def_property_ui_text(prop, "Curved", "Interpolate between frames in a bezier curve, rather than linearly");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1024,30 +1055,30 @@ static void def_cmp_image(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "ImageUser", "storage");
        
-       prop = RNA_def_property(srna, "frames", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_duration", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "frames");
-       RNA_def_property_range(prop, 1, MAXFRAMEF);
+       RNA_def_property_range(prop, 0, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Frames", "Number of images used in animation");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "start", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_start", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "sfra");
        RNA_def_property_range(prop, 1, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Start Frame", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "offset", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_offset", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "offset");
        RNA_def_property_range(prop, MINAFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Offset", "Offsets the number of the frame to use in the animation");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "cyclic", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_cyclic", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "cycl", 1);
        RNA_def_property_ui_text(prop, "Cyclic", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "auto_refresh", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_auto_refresh", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_ANIM_ALWAYS);
        RNA_def_property_ui_text(prop, "Auto-Refresh", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1077,12 +1108,6 @@ static void def_cmp_render_layers(StructRNA *srna)
        RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Node_scene_layer_itemf");
        RNA_def_property_ui_text(prop, "Layer", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
-       
-       /* TODO: comments indicate this might be a hack */
-       prop = RNA_def_property(srna, "re_render", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "custom2", 1);
-       RNA_def_property_ui_text(prop, "Re-render", "");
-       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
 static void def_cmp_output_file(StructRNA *srna)
@@ -1112,9 +1137,9 @@ static void def_cmp_output_file(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "NodeImageFile", "storage");
        
-       prop = RNA_def_property(srna, "filename", PROP_STRING, PROP_DIRPATH);
+       prop = RNA_def_property(srna, "filepath", PROP_STRING, PROP_DIRPATH);
        RNA_def_property_string_sdna(prop, NULL, "name");
-       RNA_def_property_ui_text(prop, "Filename", "");
+       RNA_def_property_ui_text(prop, "File Path", "Output path for the image, same functionality as render output.");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "image_type", PROP_ENUM, PROP_NONE);
@@ -1123,7 +1148,7 @@ static void def_cmp_output_file(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Image Type", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "exr_half", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_exr_half", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "subimtype", R_OPENEXR_HALF);
        RNA_def_property_ui_text(prop, "Half", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1139,15 +1164,17 @@ static void def_cmp_output_file(StructRNA *srna)
        RNA_def_property_range(prop, 1, 100);
        RNA_def_property_ui_text(prop, "Quality", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
-       
-       prop = RNA_def_property(srna, "start_frame", PROP_INT, PROP_NONE);
+
+       prop = RNA_def_property(srna, "frame_start", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "sfra");
+       RNA_def_property_int_funcs(prop, NULL, "rna_Image_start_frame_set", NULL);
        RNA_def_property_range(prop, MINFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Start Frame", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "end_frame", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "frame_end", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "efra");
+       RNA_def_property_int_funcs(prop, NULL, "rna_Image_end_frame_set", NULL);
        RNA_def_property_range(prop, MINFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "End Frame", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1172,6 +1199,7 @@ static void def_cmp_scale(StructRNA *srna)
                {0, "RELATIVE",   0, "Relative",   ""},
                {1, "ABSOLUTE",   0, "Absolute",   ""},
                {2, "SCENE_SIZE", 0, "Scene Size", ""},
+               {3, "RENDER_SIZE", 0, "Render Size", ""},
                {0, NULL, 0, NULL, NULL}};
        
        prop = RNA_def_property(srna, "space", PROP_ENUM, PROP_NONE);
@@ -1181,6 +1209,23 @@ static void def_cmp_scale(StructRNA *srna)
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
+static void def_cmp_rotate(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       
+       static EnumPropertyItem rotate_items[] = {
+               {0, "NEAREST",   0, "Nearest",   ""},
+               {1, "BILINEAR",   0, "Bilinear",   ""},
+               {2, "BICUBIC", 0, "Bicubic", ""},
+               {0, NULL, 0, NULL, NULL}};
+       
+       prop = RNA_def_property(srna, "filter_type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "custom1");
+       RNA_def_property_enum_items(prop, rotate_items);
+       RNA_def_property_ui_text(prop, "Filter", "Method to use to filter rotation");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+}
+
 static void def_cmp_diff_matte(StructRNA *srna)
 {
        PropertyRNA *prop;
@@ -1191,14 +1236,14 @@ static void def_cmp_diff_matte(StructRNA *srna)
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t1_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
-       RNA_def_property_ui_text(prop, "Tolerance", "Color distances below this threshold are keyed.");
+       RNA_def_property_ui_text(prop, "Tolerance", "Color distances below this threshold are keyed");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "falloff", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t2_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
-       RNA_def_property_ui_text(prop, "Falloff", "Color distances below this additional threshold are partially keyed.");
+       RNA_def_property_ui_text(prop, "Falloff", "Color distances below this additional threshold are partially keyed");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
@@ -1208,19 +1253,19 @@ static void def_cmp_color_matte(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "NodeChroma", "storage");
 
-       prop = RNA_def_property(srna, "h", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_hue", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "H", "Hue tolerance for colors to be considered a keying color");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "s", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_saturation", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "S", "Saturation Tolerance for the color");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "v", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "color_value", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t3");
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "V", "Value Tolerance for the color");
@@ -1237,26 +1282,37 @@ static void def_cmp_distance_matte(StructRNA *srna)
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t1_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
-       RNA_def_property_ui_text(prop, "Tolerance", "Color distances below this threshold are keyed.");
+       RNA_def_property_ui_text(prop, "Tolerance", "Color distances below this threshold are keyed");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "falloff", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t2_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
-       RNA_def_property_ui_text(prop, "Falloff", "Color distances below this additional threshold are partially keyed.");
+       RNA_def_property_ui_text(prop, "Falloff", "Color distances below this additional threshold are partially keyed");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
 static void def_cmp_color_spill(StructRNA *srna)
 {
        PropertyRNA *prop;
-       
+
        static EnumPropertyItem channel_items[] = {
                {1, "R", 0, "R", "Red Spill Suppression"},
                {2, "G", 0, "G", "Green Spill Suppression"},
                {3, "B", 0, "B", "Blue Spill Suppression"},
                {0, NULL, 0, NULL, NULL}};
+
+       static EnumPropertyItem limit_channel_items[] = {
+               {1, "R", 0, "R", "Limit by Red"},
+               {2, "G", 0, "G", "Limit by Green"},
+               {3, "B", 0, "B", "Limit by Blue"},
+               {0, NULL, 0, NULL, NULL}};
+
+       static EnumPropertyItem algorithm_items[] = {
+               {0, "SIMPLE", 0, "Simple", "Simple Limit Algorithm"},
+               {1, "AVERAGE", 0, "Average", "Average Limit Algorithm"},
+               {0, NULL, 0, NULL, NULL}};
        
        prop = RNA_def_property(srna, "channel", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "custom1");
@@ -1264,12 +1320,47 @@ static void def_cmp_color_spill(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Channel", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       RNA_def_struct_sdna_from(srna, "NodeChroma", "storage");
-       
-       prop = RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_float_sdna(prop, NULL, "t1");
-       RNA_def_property_range(prop, 0.0f, 0.5f);
-       RNA_def_property_ui_text(prop, "Amount", "How much the selected channel is affected by");
+       prop = RNA_def_property(srna, "limit_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "custom2");
+       RNA_def_property_enum_items(prop, algorithm_items);
+       RNA_def_property_ui_text(prop, "Algorithm", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       RNA_def_struct_sdna_from(srna, "NodeColorspill", "storage");
+
+       prop = RNA_def_property(srna, "limit_channel", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "limchan");
+       RNA_def_property_enum_items(prop, limit_channel_items);
+       RNA_def_property_ui_text(prop, "Limit Channel", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "ratio", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "limscale");
+       RNA_def_property_range(prop, 0.5f, 1.5f);
+       RNA_def_property_ui_text(prop, "Ratio", "Scale limit by value");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "use_unspill", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "unspill", 0);
+       RNA_def_property_ui_text(prop, "Unspill", "Compensate all channels (diffenrently) by hand");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "unspill_red", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "uspillr");
+       RNA_def_property_range(prop, 0.0f, 1.5f);
+       RNA_def_property_ui_text(prop, "R", "Red spillmap scale");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "unspill_green", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "uspillg");
+       RNA_def_property_range(prop, 0.0f, 1.5f);
+       RNA_def_property_ui_text(prop, "G", "Green spillmap scale");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "unspill_blue", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "uspillb");
+       RNA_def_property_range(prop, 0.0f, 1.5f);
+       RNA_def_property_ui_text(prop, "B", "Blue spillmap scale");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
@@ -1279,14 +1370,14 @@ static void def_cmp_luma_matte(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "NodeChroma", "storage");
        
-       prop = RNA_def_property(srna, "high", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "limit_max", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t1_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "High", "Values higher than this setting are 100% opaque");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "low", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "limit_min", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t2_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
@@ -1300,14 +1391,14 @@ static void def_cmp_chroma_matte(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "NodeChroma", "storage");
        
-       prop = RNA_def_property(srna, "acceptance", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "tolerance", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t1_set", NULL);
        RNA_def_property_range(prop, 1.0f, 80.0f);
        RNA_def_property_ui_text(prop, "Acceptance", "Tolerance for a color to be considered a keying color");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "cutoff", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "threshold", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t2_set", NULL);
        RNA_def_property_range(prop, 0.0f, 30.0f);
@@ -1343,6 +1434,11 @@ static void def_cmp_channel_matte(StructRNA *srna)
                {CMP_NODE_CHANNEL_MATTE_CS_YUV, "YUV", 0, "YUV",   "YUV Color Space"},
                {CMP_NODE_CHANNEL_MATTE_CS_YCC, "YCC", 0, "YCbCr", "YCbCr Color Space"},
                {0, NULL, 0, NULL, NULL}};
+
+       static EnumPropertyItem algorithm_items[] = {
+               {0, "SINGLE", 0, "Single", "Limit by single channel"},
+               {1, "MAX", 0, "Max", "Limit by max of other channels "},
+               {0, NULL, 0, NULL, NULL}};
        
        prop = RNA_def_property(srna, "color_space", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "custom1");
@@ -1350,24 +1446,36 @@ static void def_cmp_channel_matte(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Color Space", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       
-       prop= RNA_def_property(srna, "channel", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "matte_channel", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "custom2");
        RNA_def_property_enum_items(prop, prop_tri_channel_items);
        RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Node_channel_itemf");
        RNA_def_property_ui_text(prop, "Channel", "Channel used to determine matte");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
-       
+
        RNA_def_struct_sdna_from(srna, "NodeChroma", "storage");
+
+       prop = RNA_def_property(srna, "limit_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "algorithm");
+       RNA_def_property_enum_items(prop, algorithm_items);
+       RNA_def_property_ui_text(prop, "Algorithm", "Algorithm to use to limit channel");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       prop = RNA_def_property(srna, "limit_channel", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "channel");
+   RNA_def_property_enum_items(prop, prop_tri_channel_items);
+   RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Node_channel_itemf");
+       RNA_def_property_ui_text(prop, "Limit Channel", "Limit by this channels value");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "high", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "limit_max", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t1");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t1_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "High", "Values higher than this setting are 100% opaque");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "low", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "limit_min", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "t2");
        RNA_def_property_float_funcs(prop, NULL, "rna_Matte_t2_set", NULL);
        RNA_def_property_range(prop, 0.0f, 1.0f);
@@ -1459,7 +1567,7 @@ static void def_cmp_defocus(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Angle", "Bokeh shape rotation offset in degrees");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "gamma_correction", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_gamma_correction", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gamco", 1);
        RNA_def_property_ui_text(prop, "Gamma Correction", "Enable gamma correction before and after main process");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1471,7 +1579,7 @@ static void def_cmp_defocus(StructRNA *srna)
        RNA_def_property_ui_text(prop, "fStop", "Amount of focal blur, 128=infinity=perfect focus, half the value doubles the blur radius");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "max_blur", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "blur_max", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "maxblur");
        RNA_def_property_range(prop, 0.0f, 10000.0f);
        RNA_def_property_ui_text(prop, "Max Blur", "blur limit, maximum CoC radius, 0=no limit");
@@ -1483,7 +1591,7 @@ static void def_cmp_defocus(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Threshold", "CoC radius threshold, prevents background bleed on in-focus midground, 0=off");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "preview", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_preview", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "preview", 1);
        RNA_def_property_ui_text(prop, "Preview", "Enable sampling mode, useful for preview when using low samplecounts");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1510,12 +1618,12 @@ static void def_cmp_invert(StructRNA *srna)
 {
        PropertyRNA *prop;
        
-       prop = RNA_def_property(srna, "rgb", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "invert_rgb", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", CMP_CHAN_RGB);
        RNA_def_property_ui_text(prop, "RGB", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "alpha", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "invert_alpha", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", CMP_CHAN_A);
        RNA_def_property_ui_text(prop, "Alpha", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1525,36 +1633,65 @@ static void def_cmp_crop(StructRNA *srna)
 {
        PropertyRNA *prop;
        
-       prop = RNA_def_property(srna, "crop_size", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_crop_size", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "custom1", 1);
        RNA_def_property_ui_text(prop, "Crop Image Size", "Whether to crop the size of the input image");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
-       
+
+   prop = RNA_def_property(srna, "relative", PROP_BOOLEAN, PROP_NONE);
+   RNA_def_property_boolean_sdna(prop, NULL, "custom2", 1);
+   RNA_def_property_ui_text(prop, "Relative", "Use relative values to crop image");
+   RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
        RNA_def_struct_sdna_from(srna, "NodeTwoXYs", "storage");
 
-       prop = RNA_def_property(srna, "x1", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "min_x", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "x1");
        RNA_def_property_range(prop, 0, 10000);
        RNA_def_property_ui_text(prop, "X1", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "x2", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "max_x", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "x2");
        RNA_def_property_range(prop, 0, 10000);
        RNA_def_property_ui_text(prop, "X2", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "y1", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "min_y", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "y1");
        RNA_def_property_range(prop, 0, 10000);
        RNA_def_property_ui_text(prop, "Y1", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "y2", PROP_INT, PROP_NONE);
+       prop = RNA_def_property(srna, "max_y", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "y2");
        RNA_def_property_range(prop, 0, 10000);
        RNA_def_property_ui_text(prop, "Y2", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+   prop = RNA_def_property(srna, "rel_min_x", PROP_FLOAT, PROP_NONE);
+   RNA_def_property_float_sdna(prop, NULL, "fac_x1");
+   RNA_def_property_range(prop, 0.0, 1.0);
+   RNA_def_property_ui_text(prop, "X1", "");
+   RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+   prop = RNA_def_property(srna, "rel_max_x", PROP_FLOAT, PROP_NONE);
+   RNA_def_property_float_sdna(prop, NULL, "fac_x2");
+   RNA_def_property_range(prop, 0.0, 1.0);
+   RNA_def_property_ui_text(prop, "X2", "");
+   RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+   prop = RNA_def_property(srna, "rel_min_y", PROP_FLOAT, PROP_NONE);
+   RNA_def_property_float_sdna(prop, NULL, "fac_y1");
+   RNA_def_property_range(prop, 0.0, 1.0);
+   RNA_def_property_ui_text(prop, "Y1", "");
+   RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+   prop = RNA_def_property(srna, "rel_max_y", PROP_FLOAT, PROP_NONE);
+   RNA_def_property_float_sdna(prop, NULL, "fac_y2");
+   RNA_def_property_range(prop, 0.0, 1.0);
+   RNA_def_property_ui_text(prop, "Y2", "");
+   RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
 static void def_cmp_dblur(StructRNA *srna)
@@ -1569,7 +1706,7 @@ static void def_cmp_dblur(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Iterations", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "wrap", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_wrap", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "wrap", 1);
        RNA_def_property_ui_text(prop, "Wrap", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1726,7 +1863,7 @@ static void def_cmp_glare(StructRNA *srna)
        RNA_def_property_ui_text(prop, "Fade", "Streak fade-out factor");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "rotate_45", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_rotate_45", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "angle", 1);
        RNA_def_property_ui_text(prop, "Rotate 45", "Simple star filter: add 45 degree rotation offset");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1806,22 +1943,99 @@ static void def_cmp_lensdist(StructRNA *srna)
        
        RNA_def_struct_sdna_from(srna, "NodeLensDist", "storage");
        
-       prop = RNA_def_property(srna, "projector", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_projector", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "proj", 1);
-       RNA_def_property_ui_text(prop, "Projector", "Enable/disable projector mode. Effect is applied in horizontal direction only.");
+       RNA_def_property_ui_text(prop, "Projector", "Enable/disable projector mode. Effect is applied in horizontal direction only");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "jitter", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_jitter", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "jit", 1);
        RNA_def_property_ui_text(prop, "Jitter", "Enable/disable jittering; faster, but also noisier");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
-       prop = RNA_def_property(srna, "fit", PROP_BOOLEAN, PROP_NONE);
+       prop = RNA_def_property(srna, "use_fit", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "fit", 1);
        RNA_def_property_ui_text(prop, "Fit", "For positive distortion factor only: scale image such that black areas are not visible");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
+
+static void def_cmp_colorbalance(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       static float default_1[3] = {1.f, 1.f, 1.f};
        
+       static EnumPropertyItem type_items[] = {
+               {0, "LIFT_GAMMA_GAIN",      0, "Lift/Gamma/Gain",      ""},
+               {1, "OFFSET_POWER_SLOPE",     0, "Offset/Power/Slope (ASC-CDL)",     "ASC-CDL standard color correction"},
+               {0, NULL, 0, NULL, NULL}};
+       
+       prop = RNA_def_property(srna, "correction_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "custom1");
+       RNA_def_property_enum_items(prop, type_items);
+       RNA_def_property_ui_text(prop, "Correction Formula", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       RNA_def_struct_sdna_from(srna, "NodeColorBalance", "storage");
+       
+       prop = RNA_def_property(srna, "lift", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "lift");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_float_array_default(prop, default_1);
+       RNA_def_property_ui_range(prop, 0, 2, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Lift", "Correction for Shadows");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       prop = RNA_def_property(srna, "gamma", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "gamma");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_float_array_default(prop, default_1);
+       RNA_def_property_ui_range(prop, 0, 2, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Gamma", "Correction for Midtones");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       prop = RNA_def_property(srna, "gain", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "gain");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_float_array_default(prop, default_1);
+       RNA_def_property_ui_range(prop, 0, 2, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Gain", "Correction for Highlights");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       
+       prop = RNA_def_property(srna, "offset", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "lift");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_range(prop, 0, 1, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Offset", "Correction for Shadows");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       prop = RNA_def_property(srna, "power", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "gamma");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_float_array_default(prop, default_1);
+       RNA_def_property_ui_range(prop, 0, 2, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Power", "Correction for Midtones");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+       
+       prop = RNA_def_property(srna, "slope", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "gain");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_float_array_default(prop, default_1);
+       RNA_def_property_ui_range(prop, 0, 2, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Slope", "Correction for Highlights");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+}
+
+static void def_cmp_huecorrect(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       
+       prop = RNA_def_property(srna, "mapping", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "storage");
+       RNA_def_property_struct_type(prop, "CurveMapping");
+       RNA_def_property_ui_text(prop, "Mapping", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+}
 
 
 /* -- Texture Nodes --------------------------------------------------------- */
@@ -1832,7 +2046,7 @@ static void def_tex_output(StructRNA *srna)
 
        RNA_def_struct_sdna_from(srna, "TexNodeOutput", "storage");
        
-       prop = RNA_def_property(srna, "output_name", PROP_STRING, PROP_NONE);
+       prop = RNA_def_property(srna, "filepath", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "name");
        RNA_def_property_ui_text(prop, "Output Name", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
@@ -1889,31 +2103,31 @@ static void def_tex_bricks(StructRNA *srna)
 
 /* -------------------------------------------------------------------------- */
 
+static EnumPropertyItem shader_node_type_items[MaxNodes];
 static void rna_def_shader_node(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
-       EnumPropertyItem *node_type_items;
        
-       node_type_items = alloc_node_type_items(Category_ShaderNode);
+       alloc_node_type_items(shader_node_type_items, Category_ShaderNode);
 
        srna = RNA_def_struct(brna, "ShaderNode", "Node");
-       RNA_def_struct_ui_text(srna, "Shader Node", "Material shader node.");
+       RNA_def_struct_ui_text(srna, "Shader Node", "Material shader node");
        RNA_def_struct_sdna(srna, "bNode");
 
        prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_enum_items(prop, node_type_items);
+       RNA_def_property_enum_items(prop, shader_node_type_items);
        RNA_def_property_ui_text(prop, "Type", "");
 }
 
+static EnumPropertyItem compositor_node_type_items[MaxNodes];
 static void rna_def_compositor_node(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
-       EnumPropertyItem *node_type_items;
        
-       node_type_items = alloc_node_type_items(Category_CompositorNode);
+       alloc_node_type_items(compositor_node_type_items, Category_CompositorNode);
        
        srna = RNA_def_struct(brna, "CompositorNode", "Node");
        RNA_def_struct_ui_text(srna, "Compositor Node", "");
@@ -1921,17 +2135,17 @@ static void rna_def_compositor_node(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_enum_items(prop, node_type_items);
+       RNA_def_property_enum_items(prop, compositor_node_type_items);
        RNA_def_property_ui_text(prop, "Type", "");
 }
 
+static EnumPropertyItem texture_node_type_items[MaxNodes];
 static void rna_def_texture_node(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
-       EnumPropertyItem *node_type_items;
        
-       node_type_items = alloc_node_type_items(Category_TextureNode);
+       alloc_node_type_items(texture_node_type_items, Category_TextureNode);
        
        srna = RNA_def_struct(brna, "TextureNode", "Node");
        RNA_def_struct_ui_text(srna, "Texture Node", "");
@@ -1939,7 +2153,7 @@ static void rna_def_texture_node(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_enum_items(prop, node_type_items);
+       RNA_def_property_enum_items(prop, texture_node_type_items);
        RNA_def_property_ui_text(prop, "Type", "");
 }
 
@@ -1971,13 +2185,13 @@ static void rna_def_node_socket_value(BlenderRNA *brna)
        
        prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Name", "Socket name.");
+       RNA_def_property_ui_text(prop, "Name", "Socket name");
        RNA_def_struct_name_property(srna, prop);
        
        prop = RNA_def_property(srna, "default_value", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ns.vec");
        RNA_def_property_array(prop, 1);
-       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached.");
+       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
        RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
 }
@@ -1995,13 +2209,13 @@ static void rna_def_node_socket_vector(BlenderRNA *brna)
        
        prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Name", "Socket name.");
+       RNA_def_property_ui_text(prop, "Name", "Socket name");
        RNA_def_struct_name_property(srna, prop);
        
        prop = RNA_def_property(srna, "default_value", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "ns.vec");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached.");
+       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
        RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
 }
@@ -2019,13 +2233,13 @@ static void rna_def_node_socket_rgba(BlenderRNA *brna)
        
        prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Name", "Socket name.");
+       RNA_def_property_ui_text(prop, "Name", "Socket name");
        RNA_def_struct_name_property(srna, prop);
        
        prop = RNA_def_property(srna, "default_value", PROP_FLOAT, PROP_COLOR);
        RNA_def_property_float_sdna(prop, NULL, "ns.vec");
        RNA_def_property_array(prop, 4);
-       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached.");
+       RNA_def_property_ui_text(prop, "Default Value", "Default value of the socket when no link is attached");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
        RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
 }
@@ -2036,7 +2250,7 @@ static void rna_def_node(BlenderRNA *brna)
        PropertyRNA *prop;
        
        srna = RNA_def_struct(brna, "Node", NULL);
-       RNA_def_struct_ui_text(srna, "Node", "Node in a node tree.");
+       RNA_def_struct_ui_text(srna, "Node", "Node in a node tree");
        RNA_def_struct_sdna(srna, "bNode");
        RNA_def_struct_ui_icon(srna, ICON_NODE);
        RNA_def_struct_refine_func(srna, "rna_Node_refine");
@@ -2050,7 +2264,7 @@ static void rna_def_node(BlenderRNA *brna)
        RNA_def_property_update(prop, NC_NODE, "rna_Node_update");
        
        prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
-       RNA_def_property_ui_text(prop, "Name", "Node name.");
+       RNA_def_property_ui_text(prop, "Name", "Node name");
        RNA_def_struct_name_property(srna, prop);
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update_name");
        
@@ -2071,7 +2285,7 @@ static void rna_def_nodetree(BlenderRNA *brna)
        PropertyRNA *prop;
        
        srna = RNA_def_struct(brna, "NodeTree", "ID");
-       RNA_def_struct_ui_text(srna, "Node Tree", "Node tree consisting of linked nodes used for materials, textures and compositing.");
+       RNA_def_struct_ui_text(srna, "Node Tree", "Node tree consisting of linked nodes used for materials, textures and compositing");
        RNA_def_struct_sdna(srna, "bNodeTree");
        RNA_def_struct_ui_icon(srna, ICON_NODETREE);
        
@@ -2112,13 +2326,15 @@ void RNA_def_nodetree(BlenderRNA *brna)
        rna_def_shader_node(brna);
        rna_def_compositor_node(brna);
        rna_def_texture_node(brna);
-       
+               
        #define DefNode(Category, ID, DefFunc, EnumName, StructName, UIName, UIDesc) \
                define_specific_node(brna, ID, DefFunc);
                
        #include "rna_nodetree_types.h"
        
        #undef DefNode
+       
+       define_specific_node(brna, NODE_GROUP, def_group);
 }
 
 #endif