svn merge -r 30566:30717 https://svn.blender.org/svnroot/bf-blender/trunk/blender
[blender.git] / source / blender / makesrna / intern / rna_curve.c
index c0ad35eb7c39b295398b795c0240125bda7bf33c..84807446f5020d8986740a4c6463b1a2b7bdbf31 100644 (file)
@@ -36,6 +36,9 @@
 
 #include "WM_types.h"
 
+#include "BKE_curve.h"
+#include "ED_curve.h"
+
 EnumPropertyItem beztriple_handle_type_items[] = {
                {HD_FREE, "FREE", 0, "Free", ""},
                {HD_AUTO, "AUTO", 0, "Auto", ""},
@@ -59,6 +62,8 @@ EnumPropertyItem curve_type_items[] = {
 
 #ifdef RNA_RUNTIME
 
+#include "BLI_math.h"
+
 #include "DNA_object_types.h"
 
 #include "BKE_curve.h"
@@ -69,6 +74,8 @@ EnumPropertyItem curve_type_items[] = {
 
 #include "MEM_guardedalloc.h"
 
+#include "ED_curve.h" /* for BKE_curve_nurbs */
+
 static StructRNA *rna_Curve_refine(PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->data;
@@ -139,6 +146,40 @@ static int rna_Curve_texspace_editable(PointerRNA *ptr)
        return (cu->texflag & CU_AUTOSPACE)? 0: PROP_EDITABLE;
 }
 
+static void rna_Curve_texspace_loc_get(PointerRNA *ptr, float *values)
+{
+       Curve *cu= (Curve *)ptr->data;
+       
+       if (!cu->bb)
+               tex_space_curve(cu);
+       
+       copy_v3_v3(values, cu->loc);
+}
+
+static void rna_Curve_texspace_loc_set(PointerRNA *ptr, const float *values)
+{
+       Curve *cu= (Curve *)ptr->data;
+       
+       copy_v3_v3(cu->loc, values);
+}
+
+static void rna_Curve_texspace_size_get(PointerRNA *ptr, float *values)
+{
+       Curve *cu= (Curve *)ptr->data;
+       
+       if (!cu->bb)
+               tex_space_curve(cu);
+       
+       copy_v3_v3(values, cu->size);
+}
+
+static void rna_Curve_texspace_size_set(PointerRNA *ptr, const float *values)
+{
+       Curve *cu= (Curve *)ptr->data;
+       
+       copy_v3_v3(cu->size, values);
+}
+
 static void rna_Curve_material_index_range(PointerRNA *ptr, int *min, int *max)
 {
        Curve *cu= (Curve*)ptr->id.data;
@@ -157,7 +198,8 @@ static void rna_Curve_active_textbox_index_range(PointerRNA *ptr, int *min, int
 static void rna_Curve_dimension_set(PointerRNA *ptr, int value)
 {
        Curve *cu= (Curve*)ptr->id.data;
-       Nurb *nu= cu->editnurb ? cu->editnurb->first : cu->nurb.first;
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+       Nurb *nu= nurbs->first;
 
        if(value==CU_3D) {
                cu->flag |=  CU_3D;
@@ -179,10 +221,10 @@ static void rna_Curve_dimension_set(PointerRNA *ptr, int value)
 }
 
 
-
 static int rna_Nurb_length(PointerRNA *ptr)
 {
        Nurb *nu= (Nurb*)ptr->data;
+       if(nu->type == CU_BEZIER) return 0;
        return nu->pntsv>0 ? nu->pntsu*nu->pntsv : nu->pntsu;
 }
 
@@ -273,11 +315,9 @@ static void rna_Curve_taperObject_set(PointerRNA *ptr, PointerRNA value)
 static void rna_Curve_resolution_u_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->id.data;
-       Nurb *nu=NULL;
-       
-       if (cu->editnurb) nu= cu->editnurb->first;
-       else nu=cu->nurb.first;
-       
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+       Nurb *nu= nurbs->first;
+
        while(nu) {
                nu->resolu= cu->resolu;
                nu= nu->next;
@@ -289,16 +329,15 @@ static void rna_Curve_resolution_u_update_data(Main *bmain, Scene *scene, Pointe
 static void rna_Curve_resolution_v_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->id.data;
-       Nurb *nu=NULL;
-       
-       if (cu->editnurb) nu= cu->editnurb->first;
-       else nu=cu->nurb.first;
-       
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+       Nurb *nu=nurbs->first;
+
+
        while(nu) {
                nu->resolv= cu->resolv;
                nu= nu->next;
        }
-       
+
        rna_Curve_update_data(bmain, scene, ptr);
 }
 
@@ -306,13 +345,13 @@ static void rna_Curve_resolution_v_update_data(Main *bmain, Scene *scene, Pointe
 void rna_Curve_body_get(PointerRNA *ptr, char *value)
 {
        Curve *cu= (Curve*)ptr->id.data;
-       strcpy(value, cu->str);
+       BLI_strncpy(value, cu->str, cu->len+1);
 }
 
 int rna_Curve_body_length(PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->id.data;
-       return strlen(cu->str);
+       return cu->len;
 }
 
 /* TODO - check UTF & python play nice */
@@ -321,8 +360,7 @@ void rna_Curve_body_set(PointerRNA *ptr, const char *value)
        int len= strlen(value);
        Curve *cu= (Curve*)ptr->id.data;
 
-       cu->pos = len;
-       cu->len = len;
+       cu->len= cu->pos = len;
 
        if(cu->str)             MEM_freeN(cu->str);
        if(cu->strinfo) MEM_freeN(cu->strinfo);
@@ -364,7 +402,7 @@ static void rna_Nurb_update_knot_v(Main *bmain, Scene *scene, PointerRNA *ptr)
        rna_Curve_update_data(bmain, scene, ptr);
 }
 
-static void rna_Curve_spline_points_add(ID *id, Nurb *nu, bContext *C, ReportList *reports, int number)
+static void rna_Curve_spline_points_add(ID *id, Nurb *nu, ReportList *reports, int number)
 {
        if(nu->type == CU_BEZIER) {
                BKE_report(reports, RPT_ERROR, "Bezier spline can't have points added");
@@ -378,11 +416,11 @@ static void rna_Curve_spline_points_add(ID *id, Nurb *nu, bContext *C, ReportLis
                /* update */
                makeknots(nu, 1);
 
-               rna_Curve_update_data_id(CTX_data_main(C), CTX_data_scene(C), id);
+               rna_Curve_update_data_id(NULL, NULL, id);
        }
 }
 
-static void rna_Curve_spline_bezpoints_add(ID *id, Nurb *nu, bContext *C, ReportList *reports, int number)
+static void rna_Curve_spline_bezpoints_add(ID *id, Nurb *nu, ReportList *reports, int number)
 {
        if(nu->type != CU_BEZIER) {
                BKE_report(reports, RPT_ERROR, "Only bezier splines can be added");
@@ -395,7 +433,7 @@ static void rna_Curve_spline_bezpoints_add(ID *id, Nurb *nu, bContext *C, Report
                /* update */
                makeknots(nu, 1);
 
-               rna_Curve_update_data_id(CTX_data_main(C), CTX_data_scene(C), id);
+               rna_Curve_update_data_id(NULL, NULL, id);
        }
 }
 
@@ -431,12 +469,9 @@ static void rna_Curve_spline_remove(Curve *cu, ReportList *reports, Nurb *nu)
 {
        /* todo, check we're in the list */
        int found= 0;
-       if(cu->editnurb) {
-               found= BLI_remlink_safe(cu->editnurb, nu);
-       }
-       else {
-               found= BLI_remlink_safe(&cu->nurb, nu);
-       }
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+
+       found= BLI_remlink_safe(nurbs, nu);
 
        if(!found) {
                BKE_reportf(reports, RPT_ERROR, "Curve \"%s\" does not contain spline given", cu->id.name+2);
@@ -451,11 +486,10 @@ static PointerRNA rna_Curve_active_spline_get(PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->data;
        Nurb *nu;
+       ListBase *nurbs= BKE_curve_nurbs(cu);
 
-       if(cu->editnurb)
-               nu= BLI_findlink(cu->editnurb, cu->actnu);
-       else
-               nu= BLI_findlink(&cu->nurb, cu->actnu); // currently set to -1,  should be changed to be allowed outside of editmode.
+       // for curve outside editmode will set to -1,  should be changed to be allowed outside of editmode.
+       nu= BLI_findlink(nurbs, cu->actnu);
 
        if(nu)
                return rna_pointer_inherit_refine(ptr, &RNA_Spline, nu);
@@ -467,14 +501,13 @@ static void rna_Curve_active_spline_set(PointerRNA *ptr, PointerRNA value)
 {
        Curve *cu= (Curve*)ptr->data;
        Nurb *nu= value.data;
+       ListBase *nubase= BKE_curve_nurbs(cu);
 
        /* -1 is ok for an unset index */
        if(nu==NULL)
                cu->actnu= -1;
-       else if(cu->editnurb)
-               cu->actnu= BLI_findindex(cu->editnurb, nu);
        else
-               cu->actnu= BLI_findindex(&cu->nurb, nu);
+               cu->actnu= BLI_findindex(nubase, nu);
 }
 
 #else
@@ -489,14 +522,14 @@ static void rna_def_bpoint(BlenderRNA *brna)
        RNA_def_struct_ui_text(srna, "SplinePoint", "Spline point without handles");
 
        /* Boolean values */
-       prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f1", 0);
-       RNA_def_property_ui_text(prop, "Selected", "Selection status");
+       RNA_def_property_ui_text(prop, "Select", "Selection status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "hidden", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 0);
-       RNA_def_property_ui_text(prop, "Hidden", "Visibility status");
+       RNA_def_property_ui_text(prop, "Hide", "Visibility status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Vector value */
@@ -542,24 +575,24 @@ static void rna_def_beztriple(BlenderRNA *brna)
        RNA_def_struct_ui_text(srna, "Bezier Curve Point", "Bezier curve point with two handles");
 
        /* Boolean values */
-       prop= RNA_def_property(srna, "selected_handle1", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select_left_handle", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f1", 0);
        RNA_def_property_ui_text(prop, "Handle 1 selected", "Handle 1 selection status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "selected_handle2", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select_right_handle", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f3", 0);
        RNA_def_property_ui_text(prop, "Handle 2 selected", "Handle 2 selection status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "selected_control_point", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select_control_point", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f2", 0);
        RNA_def_property_ui_text(prop, "Control Point selected", "Control point selection status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "hidden", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 0);
-       RNA_def_property_ui_text(prop, "Hidden", "Visibility status");
+       RNA_def_property_ui_text(prop, "Hide", "Visibility status");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Enums */
@@ -657,9 +690,9 @@ static void rna_def_nurbs(BlenderRNA *brna, StructRNA *srna)
        PropertyRNA *prop;
        
        /* flags */
-       prop= RNA_def_property(srna, "uv_orco", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "map_along_length", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_UV_ORCO);
-       RNA_def_property_ui_text(prop, "UV Orco", "Forces to use UV coordinates for texture mapping 'orco'");
+       RNA_def_property_ui_text(prop, "Map Along Length", "Generate texture mapping coordinates following the curve direction, rather than the local bounding box");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "vertex_normal_flip", PROP_BOOLEAN, PROP_NONE);
@@ -694,6 +727,12 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        RNA_def_property_ui_text(prop, "Font size", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
+       prop= RNA_def_property(srna, "small_caps_scale", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "smallcaps_scale");
+       RNA_def_property_ui_range(prop, 0, 1.0, 0.1, 0);
+       RNA_def_property_ui_text(prop, "Small Caps", "Scale of small capitals");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
        prop= RNA_def_property(srna, "line_dist", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "linedist");
        RNA_def_property_range(prop, 0.0f, 10.0f);
@@ -760,11 +799,15 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        
        prop= RNA_def_property(srna, "body", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "str");
-       RNA_def_property_ui_text(prop, "Body Text", "contence of this text object");
+       RNA_def_property_ui_text(prop, "Body Text", "contents of this text object");
        RNA_def_property_string_funcs(prop, "rna_Curve_body_get", "rna_Curve_body_length", "rna_Curve_body_set");
        RNA_def_property_string_maxlength(prop, 8192); /* note that originally str did not have a limit! */
-       RNA_def_struct_name_property(srna, prop);
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
+       prop= RNA_def_property(srna, "body_format", PROP_COLLECTION, PROP_NONE);
+       RNA_def_property_collection_sdna(prop, NULL, "strinfo", "len");
+       RNA_def_property_struct_type(prop, "TextCharacterFormat");
+       RNA_def_property_ui_text(prop, "Character Info", "Stores the style of each character");
        
        /* pointers */
        prop= RNA_def_property(srna, "text_on_curve", PROP_POINTER, PROP_NONE);
@@ -798,6 +841,7 @@ static void rna_def_textbox(BlenderRNA *brna)
        
        srna= RNA_def_struct(brna, "TextBox", NULL);
        RNA_def_struct_ui_text(srna, "Text Box", "Text bounding box for layout");
+       // XXX: still needs path function
        
        /* number values */
        prop= RNA_def_property(srna, "x", PROP_FLOAT, PROP_NONE);
@@ -835,29 +879,30 @@ static void rna_def_charinfo(BlenderRNA *brna)
        RNA_def_struct_ui_text(srna, "Text Character Format", "Text character formatting settings");
        
        /* flags */
-       prop= RNA_def_property(srna, "style", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_STYLE);
-       RNA_def_property_ui_text(prop, "Style", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
-       
        prop= RNA_def_property(srna, "bold", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_BOLD);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_CHINFO_BOLD);
        RNA_def_property_ui_text(prop, "Bold", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "italic", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_ITALIC);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_CHINFO_ITALIC);
        RNA_def_property_ui_text(prop, "Italic", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "underline", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_UNDERLINE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_CHINFO_UNDERLINE);
        RNA_def_property_ui_text(prop, "Underline", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
-       prop= RNA_def_property(srna, "wrap", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_WRAP);
+       /* probably there is no reason to expose this */
+       /* prop= RNA_def_property(srna, "wrap", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_CHINFO_WRAP);
        RNA_def_property_ui_text(prop, "Wrap", "");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data"); */
+
+       prop= RNA_def_property(srna, "use_small_caps", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_CHINFO_SMALLCAPS);
+       RNA_def_property_ui_text(prop, "Small Caps", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
@@ -903,7 +948,7 @@ static void rna_def_curve_spline_points(BlenderRNA *brna, PropertyRNA *cprop)
 
        func= RNA_def_function(srna, "add", "rna_Curve_spline_points_add");
        RNA_def_function_ui_description(func, "Add a number of points to this spline.");
-       RNA_def_function_flag(func, FUNC_USE_CONTEXT|FUNC_USE_SELF_ID|FUNC_USE_REPORTS);
+       RNA_def_function_flag(func, FUNC_USE_SELF_ID|FUNC_USE_REPORTS);
        parm= RNA_def_int(func, "number", 1, INT_MIN, INT_MAX, "Number", "Number of points to add to the spline", 0, INT_MAX);
 
        /*
@@ -930,7 +975,7 @@ static void rna_def_curve_spline_bezpoints(BlenderRNA *brna, PropertyRNA *cprop)
 
        func= RNA_def_function(srna, "add", "rna_Curve_spline_bezpoints_add");
        RNA_def_function_ui_description(func, "Add a number of points to this spline.");
-       RNA_def_function_flag(func, FUNC_USE_CONTEXT|FUNC_USE_SELF_ID|FUNC_USE_REPORTS);
+       RNA_def_function_flag(func, FUNC_USE_SELF_ID|FUNC_USE_REPORTS);
        parm= RNA_def_int(func, "number", 1, INT_MIN, INT_MAX, "Number", "Number of points to add to the spline", 0, INT_MAX);
 
        /*
@@ -1002,7 +1047,6 @@ static void rna_def_curve(BlenderRNA *brna)
        RNA_def_struct_refine_func(srna, "rna_Curve_refine");
        
        rna_def_animdata_common(srna);
-       rna_def_texmat_common(srna, "rna_Curve_texspace_editable");
 
        prop= RNA_def_property(srna, "shape_keys", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "key");
@@ -1138,6 +1182,43 @@ static void rna_def_curve(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_DEFORM_FILL);
        RNA_def_property_ui_text(prop, "Fill deformed", "Fill curve after applying deformation");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       
+       /* texture space */
+       prop= RNA_def_property(srna, "auto_texspace", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "texflag", CU_AUTOSPACE);
+       RNA_def_property_ui_text(prop, "Auto Texture Space", "Adjusts active object's texture space automatically when transforming object");
+       
+       prop= RNA_def_property(srna, "texspace_loc", PROP_FLOAT, PROP_TRANSLATION);
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Texture Space Location", "Texture space location");
+       RNA_def_property_editable_func(prop, "rna_Curve_texspace_editable");
+       RNA_def_property_float_funcs(prop, "rna_Curve_texspace_loc_get", "rna_Curve_texspace_loc_set", NULL);   
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       
+       prop= RNA_def_property(srna, "texspace_size", PROP_FLOAT, PROP_XYZ);
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Texture Space Size", "Texture space size");
+       RNA_def_property_editable_func(prop, "rna_Curve_texspace_editable");
+       RNA_def_property_float_funcs(prop, "rna_Curve_texspace_size_get", "rna_Curve_texspace_size_set", NULL);
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       
+       /* not supported yet
+        prop= RNA_def_property(srna, "texspace_rot", PROP_FLOAT, PROP_EULER);
+        RNA_def_property_float(prop, NULL, "rot");
+        RNA_def_property_ui_text(prop, "Texture Space Rotation", "Texture space rotation");
+        RNA_def_property_editable_func(prop, texspace_editable);
+        RNA_def_property_update(prop, 0, "rna_Curve_update_data");*/
+       
+       prop= RNA_def_property(srna, "map_along_length", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_UV_ORCO);
+       RNA_def_property_ui_text(prop, "Map Along Length", "Generate texture mapping coordinates following the curve direction, rather than the local bounding box");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       
+       /* materials */
+       prop= RNA_def_property(srna, "materials", PROP_COLLECTION, PROP_NONE);
+       RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
+       RNA_def_property_struct_type(prop, "Material");
+       RNA_def_property_ui_text(prop, "Materials", "");
 }
 
 static void rna_def_curve_nurb(BlenderRNA *brna)
@@ -1189,13 +1270,13 @@ static void rna_def_curve_nurb(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Type", "The interpolation type for this curve element");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "point_count_u", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "point_count_u", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* editing this needs knot recalc*/
        RNA_def_property_int_sdna(prop, NULL, "pntsu");
        RNA_def_property_ui_text(prop, "Points U", "Total number points for the curve or surface in the U direction");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "point_count_v", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "point_count_v", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* editing this needs knot recalc*/
        RNA_def_property_int_sdna(prop, NULL, "pntsv");
        RNA_def_property_ui_text(prop, "Points V", "Total number points for the surface on the V direction");