Merging r39717 through r39983 from trunk into soc-2011-tomato
[blender.git] / source / blender / makesrna / intern / rna_nodetree.c
index eadb692d669348a997258627210e6aa58e01ede6..1b1da30005028b27acd1d02c38da916256bfb5d0 100644 (file)
 #include <stdlib.h>
 #include <string.h>
 
+#include "RNA_access.h"
 #include "RNA_define.h"
+#include "RNA_enum_types.h"
 
 #include "rna_internal.h"
+#include "rna_internal_types.h"
 
 #include "DNA_material_types.h"
+#include "DNA_mesh_types.h"
 #include "DNA_node_types.h"
+#include "DNA_object_types.h"
 #include "DNA_scene_types.h"
 #include "DNA_texture_types.h"
 
 
 #include "MEM_guardedalloc.h"
 
+EnumPropertyItem nodetree_type_items[] = {
+       {NTREE_SHADER,          "MATERIAL",             ICON_MATERIAL,          "Material",             "Material nodes"        },
+       {NTREE_TEXTURE,         "TEXTURE",              ICON_TEXTURE,           "Texture",              "Texture nodes"         },
+       {NTREE_COMPOSIT,        "COMPOSITING",  ICON_RENDERLAYERS,      "Compositing",  "Compositing nodes"     },
+       {0, NULL, 0, NULL, NULL}
+};
+
 
 EnumPropertyItem node_socket_type_items[] = {
-       {SOCK_VALUE,  "VALUE",     0,    "Value",     ""},
+       {SOCK_FLOAT,  "VALUE",     0,    "Value",     ""},
        {SOCK_VECTOR, "VECTOR",    0,    "Vector",    ""},
        {SOCK_RGBA,   "RGBA",      0,    "RGBA",      ""},
        {0, NULL, 0, NULL, NULL}};
 
-EnumPropertyItem node_blend_type_items[] = {
-{ 0, "MIX",          0, "Mix",         ""},
-{ 1, "ADD",          0, "Add",         ""},
-{ 3, "SUBTRACT",     0, "Subtract",    ""},
-{ 2, "MULTIPLY",     0, "Multiply",    ""},
-{ 4, "SCREEN",       0, "Screen",      ""},
-{ 9, "OVERLAY",      0, "Overlay",     ""},
-{ 5, "DIVIDE",       0, "Divide",      ""},
-{ 6, "DIFFERENCE",   0, "Difference",  ""},
-{ 7, "DARKEN",       0, "Darken",      ""},
-{ 8, "LIGHTEN",      0, "Lighten",     ""},
-{10, "DODGE",        0, "Dodge",       ""},
-{11, "BURN",         0, "Burn",        ""},
-{15, "COLOR",        0, "Color",       ""},
-{14, "VALUE",        0, "Value",       ""},
-{13, "SATURATION",   0, "Saturation",  ""},
-{12, "HUE",          0, "Hue",         ""},
-{16, "SOFT_LIGHT",   0, "Soft Light",  ""},
-{17, "LINEAR_LIGHT", 0, "Linear Light",""},
-{0, NULL, 0, NULL, NULL}};
-
 EnumPropertyItem node_math_items[] = {
 { 0, "ADD",          0, "Add",          ""},
 { 1, "SUBTRACT",     0, "Subtract",     ""},
@@ -119,6 +110,41 @@ EnumPropertyItem node_filter_items[] = {
 {6, "SHADOW",  0, "Shadow",  ""},
 {0, NULL, 0, NULL, NULL}};
 
+
+/* Add any new socket value subtype here.
+ * When adding a new subtype here, make sure you also add it
+ * to the subtype definitions in DNA_node_types.h.
+ * This macro is used by the RNA and the internal converter functions
+ * to define all socket subtypes. The SUBTYPE macro must be defined
+ * before using this macro, and undefined afterwards.
+ */
+#define NODE_DEFINE_SUBTYPES_INT \
+SUBTYPE(INT, Int, NONE, None) \
+SUBTYPE(INT, Int, UNSIGNED, Unsigned)
+
+#define NODE_DEFINE_SUBTYPES_FLOAT \
+SUBTYPE(FLOAT, Float, NONE, None) \
+SUBTYPE(FLOAT, Float, UNSIGNED, Unsigned) \
+SUBTYPE(FLOAT, Float, PERCENTAGE, Percentage) \
+SUBTYPE(FLOAT, Float, FACTOR, Factor) \
+SUBTYPE(FLOAT, Float, ANGLE, Angle) \
+SUBTYPE(FLOAT, Float, TIME, Time) \
+SUBTYPE(FLOAT, Float, DISTANCE, Distance)
+
+#define NODE_DEFINE_SUBTYPES_VECTOR \
+SUBTYPE(VECTOR, Vector, NONE, None) \
+SUBTYPE(VECTOR, Vector, TRANSLATION, Translation) \
+SUBTYPE(VECTOR, Vector, DIRECTION, Direction) \
+SUBTYPE(VECTOR, Vector, VELOCITY, Velocity) \
+SUBTYPE(VECTOR, Vector, ACCELERATION, Acceleration) \
+SUBTYPE(VECTOR, Vector, EULER, Euler) \
+SUBTYPE(VECTOR, Vector, XYZ, XYZ)
+
+#define NODE_DEFINE_SUBTYPES \
+NODE_DEFINE_SUBTYPES_INT \
+NODE_DEFINE_SUBTYPES_FLOAT \
+NODE_DEFINE_SUBTYPES_VECTOR
+
 #ifdef RNA_RUNTIME
 
 #include "BLI_linklist.h"
@@ -141,32 +167,18 @@ static StructRNA *rna_Node_refine(struct PointerRNA *ptr)
                                
                #include "rna_nodetree_types.h"
                
-               #undef DefNode
-               
                case NODE_GROUP:
                        return &RNA_NodeGroup;
+               case NODE_FORLOOP:
+                       return &RNA_NodeForLoop;
+               case NODE_WHILELOOP:
+                       return &RNA_NodeWhileLoop;
                        
                default:
                        return &RNA_Node;
        }
 }
 
-static StructRNA *rna_NodeSocketType_refine(struct PointerRNA *ptr)
-{
-       bNodeSocket *ns= (bNodeSocket*)ptr->data;
-       
-       switch(ns->type) {
-               case SOCK_VALUE:
-                       return &RNA_ValueNodeSocket;
-               case SOCK_VECTOR:
-                       return &RNA_VectorNodeSocket;
-               case SOCK_RGBA:
-                       return &RNA_RGBANodeSocket;
-               default:
-                       return &RNA_UnknownType;
-       }
-}              
-
 static StructRNA *rna_NodeTree_refine(struct PointerRNA *ptr)
 {
        bNodeTree *ntree= (bNodeTree*)ptr->data;
@@ -190,6 +202,46 @@ static char *rna_Node_path(PointerRNA *ptr)
        return BLI_sprintfN("nodes[\"%s\"]", node->name);
 }
 
+static StructRNA *rna_NodeSocket_refine(PointerRNA *ptr)
+{
+       bNodeSocket *sock= (bNodeSocket*)ptr->data;
+       
+       if (sock->default_value) {
+               /* This returns the refined socket type with the full definition
+                * of the default input value with type and subtype.
+                */
+               
+               #define SUBTYPE(socktype, stypename, id, idname) \
+               { \
+                       bNodeSocketValue##stypename *value= (bNodeSocketValue##stypename*)sock->default_value; \
+                       if (value->subtype==PROP_##id) \
+                               return &RNA_NodeSocket##stypename##idname; \
+               }
+               
+               switch (sock->type) {
+               case SOCK_FLOAT:
+                       NODE_DEFINE_SUBTYPES_FLOAT
+                       break;
+               case SOCK_INT:
+                       NODE_DEFINE_SUBTYPES_INT
+                       break;
+               case SOCK_BOOLEAN:
+                       return &RNA_NodeSocketBoolean;
+                       break;
+               case SOCK_VECTOR:
+                       NODE_DEFINE_SUBTYPES_VECTOR
+                       break;
+               case SOCK_RGBA:
+                       return &RNA_NodeSocketRGBA;
+                       break;
+               }
+               
+               #undef SUBTYPE
+       }
+       
+       return &RNA_NodeSocket;
+}
+
 static char *rna_NodeSocket_path(PointerRNA *ptr)
 {
        bNodeTree *ntree= (bNodeTree*)ptr->id.data;
@@ -277,7 +329,7 @@ static void rna_Node_scene_set(PointerRNA *ptr, PointerRNA value)
 
 
 
-static void node_update(Main *bmain, Scene *scene, bNodeTree *ntree, bNode *node)
+static void node_update(Main *bmain, Scene *UNUSED(scene), bNodeTree *ntree, bNode *node)
 {
        ED_node_generic_update(bmain, ntree, node);
 }
@@ -295,7 +347,7 @@ static void rna_NodeGroup_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        bNodeTree *ntree= (bNodeTree*)ptr->id.data;
        bNode *node= (bNode*)ptr->data;
        
-       nodeGroupVerify((bNodeTree *)node->id);
+       ntreeUpdateTree((bNodeTree *)node->id);
        
        node_update(bmain, scene, ntree, node);
 }
@@ -317,55 +369,6 @@ static void rna_Node_name_set(PointerRNA *ptr, const char *value)
        BKE_all_animdata_fix_paths_rename("nodes", oldname, node->name);
 }
 
-/* this should be done at display time! if no custom names are set */
-#if 0
-static void rna_Node_update_username(Main *bmain, Scene *scene, PointerRNA *ptr)
-{
-       bNode *node= (bNode*)ptr->data;
-       const char *name;
-
-       
-       /*
-       if (!node->username[0]) {
-               if(node->id) {
-                       BLI_strncpy(node->username, node->id->name+2, NODE_MAXSTR);
-               }
-               else {
-               
-                       switch(node->typeinfo->type) {
-                               case SH_NODE_MIX_RGB:
-                               case CMP_NODE_MIX_RGB:
-                               case TEX_NODE_MIX_RGB:
-                                       if(RNA_enum_name(node_blend_type_items, node->custom1, &name))
-                                               BLI_strncpy(node->username, name, NODE_MAXSTR);
-                                       break;
-                               case CMP_NODE_FILTER:
-                                       if(RNA_enum_name(node_filter_items, node->custom1, &name))
-                                               BLI_strncpy(node->username, name, NODE_MAXSTR);
-                                       break;
-                               case CMP_NODE_FLIP:
-                                       if(RNA_enum_name(node_flip_items, node->custom1, &name))
-                                               BLI_strncpy(node->username, name, NODE_MAXSTR);
-                                       break;
-                               case SH_NODE_MATH:
-                               case CMP_NODE_MATH:
-                               case TEX_NODE_MATH:
-                                       if(RNA_enum_name(node_math_items, node->custom1, &name))
-                                               BLI_strncpy(node->username, name, NODE_MAXSTR);
-                                       break;
-                               case SH_NODE_VECT_MATH:
-                                       if(RNA_enum_name(node_vec_math_items, node->custom1, &name))
-                                               BLI_strncpy(node->username, name, NODE_MAXSTR);
-                                       break;
-                       }
-                */
-               }
-       }
-
-       rna_Node_update(bmain, scene, ptr);
-}
-#endif
-
 static void rna_NodeSocket_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        bNodeTree *ntree= (bNodeTree*)ptr->id.data;
@@ -382,18 +385,42 @@ static void rna_NodeGroupSocket_update(Main *bmain, Scene *scene, PointerRNA *pt
        bNodeSocket *sock= (bNodeSocket*)ptr->data;
        bNode *node;
        
-       nodeGroupVerify(ntree);
+       ntreeUpdateTree(ntree);
        
        if (nodeFindNode(ntree, sock, &node, NULL, NULL))
                node_update(bmain, scene, ntree, node);
 }
 
-static void rna_NodeSocket_defvalue_range(PointerRNA *ptr, float *min, float *max)
+static void rna_NodeLink_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       bNodeTree *ntree= (bNodeTree*)ptr->id.data;
+
+       ntree->update |= NTREE_UPDATE_LINKS;
+       ntreeUpdateTree(ntree);
+}
+
+static void rna_NodeSocketInt_range(PointerRNA *ptr, int *min, int *max)
 {
        bNodeSocket *sock= (bNodeSocket*)ptr->data;
+       bNodeSocketValueInt *val= (bNodeSocketValueInt*)sock->default_value;
+       *min = val->min;
+       *max = val->max;
+}
 
-       *min = sock->ns.min;
-       *max = sock->ns.max;
+static void rna_NodeSocketFloat_range(PointerRNA *ptr, float *min, float *max)
+{
+       bNodeSocket *sock= (bNodeSocket*)ptr->data;
+       bNodeSocketValueFloat *val= (bNodeSocketValueFloat*)sock->default_value;
+       *min = val->min;
+       *max = val->max;
+}
+
+static void rna_NodeSocketVector_range(PointerRNA *ptr, float *min, float *max)
+{
+       bNodeSocket *sock= (bNodeSocket*)ptr->data;
+       bNodeSocketValueVector *val= (bNodeSocketValueVector*)sock->default_value;
+       *min = val->min;
+       *max = val->max;
 }
 
 static void rna_Node_mapping_update(Main *bmain, Scene *scene, PointerRNA *ptr)
@@ -436,7 +463,7 @@ static EnumPropertyItem *renderresult_layers_add_enum(RenderLayer *rl)
        return item;
 }
 
-static EnumPropertyItem *rna_Node_image_layer_itemf(bContext *C, PointerRNA *ptr, int *free)
+static EnumPropertyItem *rna_Node_image_layer_itemf(bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
 {
        bNode *node= (bNode*)ptr->data;
        Image *ima = (Image *)node->id;
@@ -453,7 +480,7 @@ static EnumPropertyItem *rna_Node_image_layer_itemf(bContext *C, PointerRNA *ptr
        return item;
 }
 
-static EnumPropertyItem *rna_Node_scene_layer_itemf(bContext *C, PointerRNA *ptr, int *free)
+static EnumPropertyItem *rna_Node_scene_layer_itemf(bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
 {
        bNode *node= (bNode*)ptr->data;
        Scene *sce = (Scene *)node->id;
@@ -470,7 +497,7 @@ static EnumPropertyItem *rna_Node_scene_layer_itemf(bContext *C, PointerRNA *ptr
        return item;
 }
 
-static EnumPropertyItem *rna_Node_channel_itemf(bContext *C, PointerRNA *ptr, int *free)
+static EnumPropertyItem *rna_Node_channel_itemf(bContext *UNUSED(C), PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
 {
        bNode *node= (bNode*)ptr->data;
        EnumPropertyItem *item= NULL;
@@ -520,21 +547,25 @@ static EnumPropertyItem *rna_Node_channel_itemf(bContext *C, PointerRNA *ptr, in
        return item;
 }
 
-static bNode *rna_NodeTree_node_new(bNodeTree *ntree, bContext *C, ReportList *reports, int type, bNodeTree *group)
+static bNode *rna_NodeTree_node_new(bNodeTree *ntree, bContext *UNUSED(C), ReportList *reports, int type, bNodeTree *group)
 {
        bNode *node;
+       bNodeTemplate ntemp;
 
        if (type == NODE_GROUP && group == NULL) {
                BKE_reportf(reports, RPT_ERROR, "node type \'GROUP\' missing group argument");
                return NULL;
        }
-       node = nodeAddNodeType(ntree, type, group, NULL);
-
+       
+       ntemp.type = type;
+       ntemp.ngroup = group;
+       node = nodeAddNode(ntree, &ntemp);
+       
        if (node == NULL) {
-                BKE_reportf(reports, RPT_ERROR, "Unable to create node");
+               BKE_reportf(reports, RPT_ERROR, "Unable to create node");
        }
        else {
-               nodeGroupVerify(ntree); /* update group node socket links*/
+               ntreeUpdateTree(ntree); /* update group node socket links*/
                NodeTagChanged(ntree, node);
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
 
@@ -564,7 +595,7 @@ static bNode *rna_NodeTree_node_composite_new(bNodeTree *ntree, bContext *C, Rep
                }
 
                ntreeCompositForceHidden(ntree, CTX_data_scene(C));
-               ntreeSolveOrder(ntree);
+               ntreeUpdateTree(ntree);
        }
 
        return node;
@@ -592,7 +623,7 @@ static void rna_NodeTree_node_remove(bNodeTree *ntree, ReportList *reports, bNod
                        id_us_min(node->id);
 
                nodeFreeNode(ntree, node);
-               nodeGroupVerify(ntree); /* update group node socket links*/
+               ntreeUpdateTree(ntree); /* update group node socket links*/
 
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
        }
@@ -601,15 +632,14 @@ static void rna_NodeTree_node_remove(bNodeTree *ntree, ReportList *reports, bNod
 static bNodeLink *rna_NodeTree_link_new(bNodeTree *ntree, ReportList *reports, bNodeSocket *in, bNodeSocket *out)
 {
        bNodeLink *ret;
-       bNode *fromnode, *tonode;
+       bNode *fromnode= NULL, *tonode= NULL;
+       int from_in_out, to_in_out;
 
-       if (!nodeFindNode(ntree, in, &fromnode, NULL, NULL)) {
-               BKE_reportf(reports, RPT_ERROR, "Unable to locate input socket's node in nodetree");
-               return NULL;
-       }
-
-       if (!nodeFindNode(ntree, out, &tonode, NULL, NULL)) {
-               BKE_reportf(reports, RPT_ERROR, "Unable to locate output socket's node in nodetree");
+       nodeFindNode(ntree, in, &fromnode, NULL, &from_in_out);
+       nodeFindNode(ntree, out, &tonode, NULL, &to_in_out);
+       
+       if (&from_in_out == &to_in_out) {
+               BKE_reportf(reports, RPT_ERROR, "Same input/output direction of sockets");
                return NULL;
        }
 
@@ -621,9 +651,7 @@ static bNodeLink *rna_NodeTree_link_new(bNodeTree *ntree, ReportList *reports, b
        if(ret) {
                NodeTagChanged(ntree, tonode);
 
-               nodeGroupVerify(ntree); /* update group node socket links*/
-
-               ntreeSolveOrder(ntree);
+               ntreeUpdateTree(ntree);
 
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
        }
@@ -637,8 +665,7 @@ static void rna_NodeTree_link_remove(bNodeTree *ntree, ReportList *reports, bNod
        }
        else {
                nodeRemLink(ntree, link);
-               ntreeSolveOrder(ntree);
-               nodeGroupVerify(ntree); /* update group node socket links*/
+               ntreeUpdateTree(ntree);
 
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
        }
@@ -647,9 +674,10 @@ static void rna_NodeTree_link_remove(bNodeTree *ntree, ReportList *reports, bNod
 static bNodeSocket *rna_NodeTree_input_new(bNodeTree *ntree, ReportList *UNUSED(reports), const char *name, int type)
 {
        /* XXX should check if tree is a group here! no good way to do this currently. */
-       bNodeSocket *gsock= nodeGroupAddSocket(ntree, name, type, SOCK_IN);
+       bNodeSocket *gsock= node_group_add_socket(ntree, name, type, SOCK_IN);
        
-       nodeGroupVerify(ntree); /* update group node socket links*/
+       ntree->update |= NTREE_UPDATE_GROUP_IN;
+       ntreeUpdateTree(ntree);
        WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
        return gsock;
 }
@@ -657,9 +685,10 @@ static bNodeSocket *rna_NodeTree_input_new(bNodeTree *ntree, ReportList *UNUSED(
 static bNodeSocket *rna_NodeTree_output_new(bNodeTree *ntree, ReportList *UNUSED(reports), const char *name, int type)
 {
        /* XXX should check if tree is a group here! no good way to do this currently. */
-       bNodeSocket *gsock= nodeGroupAddSocket(ntree, name, type, SOCK_OUT);
+       bNodeSocket *gsock= node_group_add_socket(ntree, name, type, SOCK_OUT);
        
-       nodeGroupVerify(ntree); /* update group node socket links*/
+       ntree->update |= NTREE_UPDATE_GROUP_OUT;
+       ntreeUpdateTree(ntree);
        WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
        return gsock;
 }
@@ -676,11 +705,12 @@ static bNodeSocket *rna_NodeTree_input_expose(bNodeTree *ntree, ReportList *repo
                BKE_reportf(reports, RPT_ERROR, "Socket is not an input");
        else {
                /* XXX should check if tree is a group here! no good way to do this currently. */
-               gsock = nodeGroupAddSocket(ntree, sock->name, sock->type, SOCK_IN);
+               gsock = node_group_add_socket(ntree, sock->name, sock->type, SOCK_IN);
                if (add_link)
                        nodeAddLink(ntree, NULL, gsock, node, sock);
                
-               nodeGroupVerify(ntree); /* update group node socket links*/
+               ntree->update |= NTREE_UPDATE_GROUP_IN;
+               ntreeUpdateTree(ntree);
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
                return gsock;
        }
@@ -699,11 +729,12 @@ static bNodeSocket *rna_NodeTree_output_expose(bNodeTree *ntree, ReportList *rep
                BKE_reportf(reports, RPT_ERROR, "Socket is not an output");
        else {
                /* XXX should check if tree is a group here! no good way to do this currently. */
-               gsock = nodeGroupAddSocket(ntree, sock->name, sock->type, SOCK_OUT);
+               gsock = node_group_add_socket(ntree, sock->name, sock->type, SOCK_OUT);
                if (add_link)
                        nodeAddLink(ntree, node, sock, NULL, gsock);
                
-               nodeGroupVerify(ntree); /* update group node socket links*/
+               ntree->update |= NTREE_UPDATE_GROUP_OUT;
+               ntreeUpdateTree(ntree);
                WM_main_add_notifier(NC_NODE|NA_EDITED, ntree);
                return gsock;
        }
@@ -738,14 +769,16 @@ static EnumPropertyItem node_ycc_items[] = {
 { 2, "JFIF",     0, "Jpeg",     ""},
 {0, NULL, 0, NULL, NULL}};
 
-#define MaxNodes 1000
+#define MaxNodes 50000
 
 enum
 {
        Category_GroupNode,
+       Category_LoopNode,
+       Category_LayoutNode,
        Category_ShaderNode,
        Category_CompositorNode,
-       Category_TextureNode
+       Category_TextureNode,
 };
 
 typedef struct NodeInfo
@@ -785,9 +818,10 @@ static void init(void)
                
        #include "rna_nodetree_types.h"
        
-       #undef DefNode
-       
        reg_node(NODE_GROUP, Category_GroupNode, "GROUP", "NodeGroup", "Node", "Group", "");
+       reg_node(NODE_FORLOOP, Category_LoopNode, "FORLOOP", "NodeForLoop", "Node", "ForLoop", "");
+       reg_node(NODE_WHILELOOP, Category_LoopNode, "WHILELOOP", "NodeWhileLoop", "Node", "WhileLoop", "");
+       reg_node(NODE_FRAME, Category_LayoutNode, "FRAME", "NodeFrame", "Node", "Frame", "");
 }
 
 static StructRNA* def_node(BlenderRNA *brna, int node_id)
@@ -802,7 +836,7 @@ static StructRNA* def_node(BlenderRNA *brna, int node_id)
        return srna;
 }
 
-void alloc_node_type_items(EnumPropertyItem *items, int category)
+static void alloc_node_type_items(EnumPropertyItem *items, int category)
 {
        int i;
        int count = 3;
@@ -863,6 +897,41 @@ static void def_group(StructRNA *srna)
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeGroup_update");
 }
 
+static void def_forloop(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       
+       prop = RNA_def_property(srna, "node_tree", 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_whileloop(StructRNA *srna)
+{
+       PropertyRNA *prop;
+       
+       prop = RNA_def_property(srna, "node_tree", 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");
+
+       prop = RNA_def_property(srna, "max_iterations", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "custom1");
+       RNA_def_property_range(prop, 0.0f, 10000000.0f);
+       RNA_def_property_ui_text(prop, "Max. Iterations", "Limit for number of iterations");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeGroup_update");
+}
+
+static void def_frame(StructRNA *srna)
+{
+//     PropertyRNA *prop;
+       
+}
 
 static void def_math(StructRNA *srna)
 {
@@ -946,7 +1015,7 @@ static void def_mix_rgb(StructRNA *srna)
        
        prop = RNA_def_property(srna, "blend_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "custom1");
-       RNA_def_property_enum_items(prop, node_blend_type_items);
+       RNA_def_property_enum_items(prop, ramp_blend_items);
        RNA_def_property_ui_text(prop, "Blend Type", "");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
@@ -1284,7 +1353,7 @@ static void def_cmp_vector_blur(StructRNA *srna)
        
        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_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");
 }
 
@@ -1332,29 +1401,29 @@ static void def_cmp_image(StructRNA *srna)
        prop = RNA_def_property(srna, "frame_duration", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "frames");
        RNA_def_property_range(prop, 0, MAXFRAMEF);
-       RNA_def_property_ui_text(prop, "Frames", "Number of images used in animation");
+       RNA_def_property_ui_text(prop, "Frames", "Sets the number of images of a movie to use"); /* copied from the rna_image.c */
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "frame_start", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "sfra");
        RNA_def_property_range(prop, MINAFRAMEF, MAXFRAMEF);
-       RNA_def_property_ui_text(prop, "Start Frame", "");
+       RNA_def_property_ui_text(prop, "Start Frame", "Sets the global starting frame of the movie/sequence, assuming first picture has a #1"); /* copied from the rna_image.c */
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        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_ui_text(prop, "Offset", "Offsets the number of the frame to use in the animation"); /* copied from the rna_image.c */
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        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_ui_text(prop, "Cyclic", "Cycle the images in the movie"); /* copied from the rna_image.c */
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        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_ui_text(prop, "Auto-Refresh", "Always refresh image on frame changes"); /* copied from the rna_image.c */
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop= RNA_def_property(srna, "layer", PROP_ENUM, PROP_NONE);
@@ -1393,6 +1462,9 @@ static void def_cmp_output_file(StructRNA *srna)
                {R_TARGA,   "TARGA",        0, "Targa",        ""},
                {R_RAWTGA,  "RAW_TARGA",    0, "Targa Raw",    ""},
                {R_PNG,     "PNG",          0, "PNG",          ""},
+#ifdef WITH_DDS
+               {R_DDS,     "DDS",          0, "DirectDraw Surface", ""},
+#endif
                {R_BMP,     "BMP",          0, "BMP",          ""},
                {R_JPEG90,  "JPEG",         0, "JPEG",         ""},
                {R_IRIS,    "IRIS",         0, "IRIS",         ""},
@@ -1617,7 +1689,7 @@ static void def_cmp_color_spill(StructRNA *srna)
 
        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_ui_text(prop, "Unspill", "Compensate all channels (differently) 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);
@@ -1738,8 +1810,8 @@ static void def_cmp_channel_matte(StructRNA *srna)
 
        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_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");
        
@@ -1879,13 +1951,13 @@ static void def_cmp_defocus(StructRNA *srna)
        
        prop = RNA_def_property(srna, "use_zbuffer", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "no_zbuf", 1);
-       RNA_def_property_ui_text(prop, "Use Z-Buffer", "Disable when using an image as input instead of actual zbuffer (auto enabled if node not image based, eg. time node)");
+       RNA_def_property_ui_text(prop, "Use Z-Buffer", "Disable when using an image as input instead of actual z-buffer (auto enabled if node not image based, eg. time node)");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
        prop = RNA_def_property(srna, "z_scale", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "scale");
        RNA_def_property_range(prop, 0.0f, 1000.0f);
-       RNA_def_property_ui_text(prop, "Z-Scale", "Scales the Z input when not using a zbuffer, controls maximum blur designated by the color white or input value 1");
+       RNA_def_property_ui_text(prop, "Z-Scale", "Scales the Z input when not using a z-buffer, controls maximum blur designated by the color white or input value 1");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
@@ -1913,10 +1985,10 @@ static void def_cmp_crop(StructRNA *srna)
        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");
+       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");
 
@@ -1944,29 +2016,29 @@ static void def_cmp_crop(StructRNA *srna)
        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_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_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_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");
+       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)
@@ -2288,6 +2360,7 @@ static void def_cmp_colorbalance(StructRNA *srna)
        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_range(prop, 0.f, FLT_MAX);
        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");
@@ -2296,6 +2369,7 @@ static void def_cmp_colorbalance(StructRNA *srna)
        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_range(prop, 0.f, FLT_MAX);
        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");
@@ -2333,6 +2407,61 @@ static void def_cmp_ycc(StructRNA *srna)
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
 }
 
+static void def_cmp_movieclip(StructRNA *srna)
+{
+       PropertyRNA *prop;
+
+       prop = RNA_def_property(srna, "clip", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "id");
+       RNA_def_property_struct_type(prop, "MovieClip");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Movie Clip", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       RNA_def_struct_sdna_from(srna, "MovieClipUser", "storage");
+}
+
+static void def_cmp_stabilize2d(StructRNA *srna)
+{
+       PropertyRNA *prop;
+
+       static EnumPropertyItem filter_type_items[] = {
+               {0, "NEAREST",   0, "Nearest",   ""},
+               {1, "BILINEAR",   0, "Bilinear",   ""},
+               {2, "BICUBIC", 0, "Bicubic", ""},
+               {0, NULL, 0, NULL, NULL}};
+
+       prop = RNA_def_property(srna, "clip", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "id");
+       RNA_def_property_struct_type(prop, "MovieClip");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Movie Clip", "");
+       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
+
+       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, filter_type_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 dev_cmd_transform(StructRNA *srna)
+{
+       PropertyRNA *prop;
+
+       static EnumPropertyItem filter_type_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, filter_type_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");
+}
+
 
 /* -- Texture Nodes --------------------------------------------------------- */
 
@@ -2575,94 +2704,112 @@ static void rna_def_node_socket(BlenderRNA *brna)
 
        srna = RNA_def_struct(brna, "NodeSocket", NULL);
        RNA_def_struct_ui_text(srna, "Node Socket", "Input or output socket of a node");
-       RNA_def_struct_refine_func(srna, "rna_NodeSocketType_refine");
        RNA_def_struct_sdna(srna, "bNodeSocket");
+       RNA_def_struct_refine_func(srna, "rna_NodeSocket_refine");
        RNA_def_struct_ui_icon(srna, ICON_PLUG);
        RNA_def_struct_path_func(srna, "rna_NodeSocket_path");
 
+       prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "type");
+       RNA_def_property_enum_items(prop, node_socket_type_items);
+       RNA_def_property_enum_default(prop, 0);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Type", "Node Socket type");
+
        prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        /* XXX must be editable for group sockets. if necessary use a special rna definition for these */
 //     RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Name", "Socket name");
        RNA_def_struct_name_property(srna, prop);
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeGroupSocket_update");
-
-       /* can add back if there is any use in reading them */
-#if 0
-       prop = RNA_def_property(srna, "min", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_float_sdna(prop, NULL, "ns.min");
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Minimum Value", "");
-       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
-
-       prop = RNA_def_property(srna, "max", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_float_sdna(prop, NULL, "ns.max");
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Maximum Value", "");
-       RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
-#endif
-
-       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_socket_type_items);
-       RNA_def_property_ui_text(prop, "Type", "Node Socket type");
-}
-
-static void rna_def_node_socket_value(BlenderRNA *brna)
-{
-       StructRNA *srna;
-       PropertyRNA *prop;
-
-       srna = RNA_def_struct(brna, "ValueNodeSocket", "NodeSocket");
-       RNA_def_struct_ui_text(srna, "Value Node Socket", "Input or output socket of a node");
-       RNA_def_struct_sdna(srna, "bNodeSocket");
-       RNA_def_struct_ui_icon(srna, ICON_PLUG);
-       RNA_def_struct_path_func(srna, "rna_NodeSocket_path");
-
-       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_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
-       RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
-}
-
-static void rna_def_node_socket_vector(BlenderRNA *brna)
-{
-       StructRNA *srna;
-       PropertyRNA *prop;
-
-       srna = RNA_def_struct(brna, "VectorNodeSocket", "NodeSocket");
-       RNA_def_struct_ui_text(srna, "Vector Node Socket", "Input or output socket of a node");
-       RNA_def_struct_sdna(srna, "bNodeSocket");
-       RNA_def_struct_ui_icon(srna, ICON_PLUG);
-       RNA_def_struct_path_func(srna, "rna_NodeSocket_path");
-
-       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_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
-       RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
 }
 
-static void rna_def_node_socket_rgba(BlenderRNA *brna)
+static void rna_def_node_socket_subtype(BlenderRNA *brna, int type, int subtype, const char *name, const char *ui_name)
 {
        StructRNA *srna;
-       PropertyRNA *prop;
-
-       srna = RNA_def_struct(brna, "RGBANodeSocket", "NodeSocket");
-       RNA_def_struct_ui_text(srna, "RGBA Node Socket", "Input or output socket of a node");
+       PropertyRNA *prop=NULL;
+       PropertySubType propsubtype= PROP_NONE;
+       
+       #define SUBTYPE(socktype, stypename, id, idname)        { PROP_##id, #id, 0, #idname, ""},
+       static EnumPropertyItem subtype_items[] = {
+               NODE_DEFINE_SUBTYPES
+               {0, NULL, 0, NULL, NULL}
+       };
+       #undef SUBTYPE
+
+       #define SUBTYPE(socktype, stypename, id, idname)        if (subtype==PROP_##id) propsubtype = PROP_##id;
+       NODE_DEFINE_SUBTYPES
+       #undef SUBTYPE
+       
+       srna = RNA_def_struct(brna, name, "NodeSocket");
+       RNA_def_struct_ui_text(srna, ui_name, "Input or output socket of a node");
        RNA_def_struct_sdna(srna, "bNodeSocket");
        RNA_def_struct_ui_icon(srna, ICON_PLUG);
        RNA_def_struct_path_func(srna, "rna_NodeSocket_path");
-
-       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_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
-       RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocket_defvalue_range");
+       
+       switch (type) {
+       case SOCK_INT:
+               RNA_def_struct_sdna_from(srna, "bNodeSocketValueInt", "default_value");
+               
+               prop = RNA_def_property(srna, "subtype", PROP_ENUM, PROP_NONE);
+               RNA_def_property_enum_sdna(prop, NULL, "subtype");
+               RNA_def_property_enum_items(prop, subtype_items);
+               RNA_def_property_ui_text(prop, "Subtype", "Subtype defining the socket value details");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               
+               prop = RNA_def_property(srna, "default_value", PROP_INT, propsubtype);
+               RNA_def_property_int_sdna(prop, NULL, "value");
+               RNA_def_property_int_funcs(prop, NULL, NULL, "rna_NodeSocketInt_range");
+               RNA_def_property_ui_text(prop, "Default Value", "");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               break;
+       case SOCK_FLOAT:
+               RNA_def_struct_sdna_from(srna, "bNodeSocketValueFloat", "default_value");
+               
+               prop = RNA_def_property(srna, "subtype", PROP_ENUM, PROP_NONE);
+               RNA_def_property_enum_sdna(prop, NULL, "subtype");
+               RNA_def_property_enum_items(prop, subtype_items);
+               RNA_def_property_ui_text(prop, "Subtype", "Subtype defining the socket value details");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               
+               prop = RNA_def_property(srna, "default_value", PROP_FLOAT, propsubtype);
+               RNA_def_property_float_sdna(prop, NULL, "value");
+               RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocketFloat_range");
+               RNA_def_property_ui_text(prop, "Default Value", "");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               break;
+       case SOCK_BOOLEAN:
+               RNA_def_struct_sdna_from(srna, "bNodeSocketValueBoolean", "default_value");
+               
+               prop = RNA_def_property(srna, "default_value", PROP_BOOLEAN, PROP_NONE);
+               RNA_def_property_boolean_sdna(prop, NULL, "value", 1);
+               RNA_def_property_ui_text(prop, "Default Value", "");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               break;
+       case SOCK_VECTOR:
+               RNA_def_struct_sdna_from(srna, "bNodeSocketValueVector", "default_value");
+               
+               prop = RNA_def_property(srna, "subtype", PROP_ENUM, PROP_NONE);
+               RNA_def_property_enum_sdna(prop, NULL, "subtype");
+               RNA_def_property_enum_items(prop, subtype_items);
+               RNA_def_property_ui_text(prop, "Subtype", "Subtype defining the socket value details");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               
+               prop = RNA_def_property(srna, "default_value", PROP_FLOAT, propsubtype);
+               RNA_def_property_float_sdna(prop, NULL, "value");
+               RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocketVector_range");
+               RNA_def_property_ui_text(prop, "Default Value", "");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               break;
+       case SOCK_RGBA:
+               RNA_def_struct_sdna_from(srna, "bNodeSocketValueRGBA", "default_value");
+               
+               prop = RNA_def_property(srna, "default_value", PROP_FLOAT, PROP_COLOR);
+               RNA_def_property_float_sdna(prop, NULL, "value");
+               RNA_def_property_ui_text(prop, "Default Value", "");
+               RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_NodeSocket_update");
+               break;
+       }
 }
 
 static void rna_def_node(BlenderRNA *brna)
@@ -2685,11 +2832,16 @@ 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", "Unique node identifier");
        RNA_def_struct_name_property(srna, prop);
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Node_name_set");
        RNA_def_property_update(prop, NC_NODE|NA_EDITED, "rna_Node_update");
        
+       prop = RNA_def_property(srna, "label", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "label");
+       RNA_def_property_ui_text(prop, "Label", "Optional custom node label");
+       RNA_def_property_update(prop, NC_NODE, "rna_Node_update");
+       
        prop = RNA_def_property(srna, "inputs", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "inputs", NULL);
        RNA_def_property_struct_type(prop, "NodeSocket");
@@ -2699,13 +2851,19 @@ static void rna_def_node(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "outputs", NULL);
        RNA_def_property_struct_type(prop, "NodeSocket");
        RNA_def_property_ui_text(prop, "Outputs", "");
+
+       prop = RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "parent");
+       RNA_def_property_struct_type(prop, "Node");
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Parent", "Parent this node is attached to");
 }
 
 static void rna_def_node_link(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
-       
+
        srna = RNA_def_struct(brna, "NodeLink", NULL);
        RNA_def_struct_ui_text(srna, "NodeLink", "Link between nodes in a node tree");
        RNA_def_struct_sdna(srna, "bNodeLink");
@@ -2747,7 +2905,7 @@ static void rna_def_group_sockets_api(BlenderRNA *brna, PropertyRNA *cprop, int
        RNA_def_function_ui_description(func, "Add a socket to the group tree.");
        RNA_def_function_flag(func, FUNC_USE_REPORTS);
        RNA_def_string(func, "name", "Socket", 32, "Name", "Name of the socket");
-       RNA_def_enum(func, "type", node_socket_type_items, SOCK_VALUE, "Type", "Type of socket");
+       RNA_def_enum(func, "type", node_socket_type_items, SOCK_FLOAT, "Type", "Type of socket");
        /* return value */
        parm= RNA_def_pointer(func, "socket", "NodeSocket", "", "New socket.");
        RNA_def_function_return(func, parm);
@@ -2768,12 +2926,6 @@ static void rna_def_nodetree(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       static EnumPropertyItem nodetree_type_items[] = {
-               {NTREE_SHADER,      "SHADER",       0,    "Shader",       ""},
-               {NTREE_COMPOSIT,    "COMPOSITE",    0,    "Composite",    ""},
-               {NTREE_TEXTURE,     "TEXTURE",      0,    "Texture",      ""},
-               {0, NULL, 0, NULL, NULL}};
-       
        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_sdna(srna, "bNodeTree");
@@ -2796,6 +2948,7 @@ static void rna_def_nodetree(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_struct_type(prop, "GreasePencil");
        RNA_def_property_ui_text(prop, "Grease Pencil Data", "Grease Pencil datablock");
+       RNA_def_property_update(prop, NC_NODE, NULL);
        
        prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
@@ -2885,15 +3038,23 @@ void RNA_def_nodetree(BlenderRNA *brna)
 {
        init();
        rna_def_nodetree(brna);
+       
        rna_def_node_socket(brna);
-       rna_def_node_socket_value(brna);
-       rna_def_node_socket_vector(brna);
-       rna_def_node_socket_rgba(brna);
+       
+       /* Generate RNA definitions for all socket subtypes */
+       #define SUBTYPE(socktype, stypename, id, idname) \
+       rna_def_node_socket_subtype(brna, SOCK_##socktype, PROP_##id, "NodeSocket"#stypename#idname, #idname" "#stypename" Node Socket");
+       NODE_DEFINE_SUBTYPES
+       #undef SUBTYPE
+       rna_def_node_socket_subtype(brna, SOCK_BOOLEAN, 0, "NodeSocketBoolean", "Boolean Node Socket");
+       rna_def_node_socket_subtype(brna, SOCK_RGBA, 0, "NodeSocketRGBA", "RGBA Node Socket");
+       
        rna_def_node(brna);
        rna_def_node_link(brna);
        rna_def_shader_node(brna);
        rna_def_compositor_node(brna);
        rna_def_texture_node(brna);
+       
        rna_def_composite_nodetree(brna);
        rna_def_shader_nodetree(brna);
        rna_def_texture_nodetree(brna);
@@ -2902,10 +3063,14 @@ void RNA_def_nodetree(BlenderRNA *brna)
                
        #include "rna_nodetree_types.h"
        
-       #undef DefNode
-       
        define_specific_node(brna, NODE_GROUP, def_group);
+       define_specific_node(brna, NODE_FORLOOP, def_forloop);
+       define_specific_node(brna, NODE_WHILELOOP, def_whileloop);
+       define_specific_node(brna, NODE_FRAME, def_frame);
 }
 
+/* clean up macro definition */
+#undef NODE_DEFINE_SUBTYPES
+
 #endif