svn merge -r 30566:30717 https://svn.blender.org/svnroot/bf-blender/trunk/blender
[blender.git] / source / blender / makesrna / intern / rna_curve.c
index d19a2289490810037eb0fd0e9e985b5539895c08..84807446f5020d8986740a4c6463b1a2b7bdbf31 100644 (file)
@@ -15,7 +15,7 @@
  *
  * 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), Juho Veps�l�inen
  *
@@ -25,7 +25,6 @@
 #include <stdlib.h>
 
 #include "RNA_define.h"
-#include "RNA_types.h"
 
 #include "rna_internal.h"
 
 
 #include "BKE_font.h"
 
+#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", ""},
                {HD_VECT, "VECTOR", 0, "Vector", ""},
                {HD_ALIGN, "ALIGNED", 0, "Aligned", ""},
-               {HD_AUTO_ANIM, "AUTO_CLAMPED", 0, "Auto Clamped", ""},
                {0, NULL, 0, NULL, NULL}};
 
 EnumPropertyItem beztriple_interpolation_mode_items[] = {
@@ -48,14 +51,19 @@ EnumPropertyItem beztriple_interpolation_mode_items[] = {
                {BEZT_IPO_LIN, "LINEAR", 0, "Linear", ""},
                {BEZT_IPO_BEZ, "BEZIER", 0, "Bezier", ""},
                {0, NULL, 0, NULL, NULL}};
-               
-EnumPropertyItem beztriple_keyframe_type_items[] = {
-               {BEZT_KEYTYPE_KEYFRAME, "KEYFRAME", 0, "Keyframe", ""},
-               {BEZT_KEYTYPE_BREAKDOWN, "BREAKDOWN", 0, "Breakdown", ""},
-               {0, NULL, 0, NULL, NULL}};
+
+EnumPropertyItem curve_type_items[] = {
+       {CU_POLY, "POLY", 0, "Poly", ""},
+       {CU_BEZIER, "BEZIER", 0, "Bezier", ""},
+       {CU_BSPLINE, "BSPLINE", 0, "BSpline", ""},
+       {CU_CARDINAL, "CARDINAL", 0, "Cardinal", ""},
+       {CU_NURBS, "NURBS", 0, "Ease", ""},
+       {0, NULL, 0, NULL, NULL}};
 
 #ifdef RNA_RUNTIME
 
+#include "BLI_math.h"
+
 #include "DNA_object_types.h"
 
 #include "BKE_curve.h"
@@ -63,13 +71,16 @@ EnumPropertyItem beztriple_keyframe_type_items[] = {
 #include "BKE_main.h"
 
 #include "WM_api.h"
-#include "WM_types.h"
 
-StructRNA *rna_Curve_refine(PointerRNA *ptr)
+#include "MEM_guardedalloc.h"
+
+#include "ED_curve.h" /* for BKE_curve_nurbs */
+
+static StructRNA *rna_Curve_refine(PointerRNA *ptr)
 {
        Curve *cu= (Curve*)ptr->data;
        short obtype= curve_type(cu);
-
+       
        if(obtype == OB_FONT) return &RNA_TextCurve;
        else if(obtype == OB_SURF) return &RNA_SurfaceCurve;
        else return &RNA_Curve;
@@ -135,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;
@@ -142,24 +187,327 @@ static void rna_Curve_material_index_range(PointerRNA *ptr, int *min, int *max)
        *max= cu->totcol-1;
 }
 
+static void rna_Curve_active_textbox_index_range(PointerRNA *ptr, int *min, int *max)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       *min= 0;
+       *max= cu->totbox-1;
+}
+
+
+static void rna_Curve_dimension_set(PointerRNA *ptr, int value)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+       Nurb *nu= nurbs->first;
+
+       if(value==CU_3D) {
+               cu->flag |=  CU_3D;
+               for( ; nu; nu= nu->next) {
+                       nu->flag &= ~CU_2D;
+               }
+       }
+       else {
+               cu->flag &= ~CU_3D;
+               for( ; nu; nu= nu->next) {
+                       nu->flag |= CU_2D;
+                       test2DNurb(nu);
+
+                       /* since the handles are moved they need to be auto-located again */
+                       if(nu->type == CU_BEZIER)
+                               calchandlesNurb(nu);
+               }
+       }
+}
+
+
 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;
 }
 
+static void rna_Nurb_type_set(PointerRNA *ptr, int value)
+{
+       Nurb *nu= (Nurb*)ptr->data;
+       nu->type = value;
+       // XXX - TODO change datatypes
+}
+
 static void rna_BPoint_array_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 {
        Nurb *nu= (Nurb*)ptr->data;
-       rna_iterator_array_begin(iter, (void*)nu->bp, sizeof(BPoint*), nu->pntsv>0 ? nu->pntsu*nu->pntsv : nu->pntsu, 0, NULL);
+       rna_iterator_array_begin(iter, (void*)nu->bp, sizeof(BPoint), nu->pntsv>0 ? nu->pntsu*nu->pntsv : nu->pntsu, 0, NULL);
 }
 
-static void rna_Curve_update_data(bContext *C, PointerRNA *ptr)
+static void rna_Curve_update_data_id(Main *bmain, Scene *scene, ID *id)
 {
-       ID *id= ptr->id.data;
-       
        DAG_id_flush_update(id, OB_RECALC_DATA);
-       WM_event_add_notifier(C, NC_GEOM|ND_DATA, id);
+       WM_main_add_notifier(NC_GEOM|ND_DATA, id);
+}
+
+static void rna_Curve_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       rna_Curve_update_data_id(bmain, scene, ptr->id.data);
+}
+
+static void rna_Curve_update_deps(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       DAG_scene_sort(scene);
+       rna_Curve_update_data(bmain, scene, ptr);
+}
+
+static PointerRNA rna_Curve_bevelObject_get(PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       Object *ob= cu->bevobj;
+
+       if(ob)
+               return rna_pointer_inherit_refine(ptr, &RNA_Object, ob);
+
+       return rna_pointer_inherit_refine(ptr, NULL, NULL);
+}
+
+static void rna_Curve_bevelObject_set(PointerRNA *ptr, PointerRNA value)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       Object *ob= (Object*)value.data;
+
+       if (ob) {
+               /* if bevel object has got the save curve, as object, for which it's */
+               /* set as bevobj, there could be infinity loop in displist calculation */
+               if (ob->type == OB_CURVE && ob->data != cu) {
+                       cu->bevobj = ob;
+               }
+       } else {
+               cu->bevobj = NULL;
+       }
+}
+
+static PointerRNA rna_Curve_taperObject_get(PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       Object *ob= cu->taperobj;
+
+       if(ob)
+               return rna_pointer_inherit_refine(ptr, &RNA_Object, ob);
+
+       return rna_pointer_inherit_refine(ptr, NULL, NULL);
+}
+
+static void rna_Curve_taperObject_set(PointerRNA *ptr, PointerRNA value)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       Object *ob= (Object*)value.data;
+
+       if (ob) {
+               /* if taper object has got the save curve, as object, for which it's */
+               /* set as bevobj, there could be infinity loop in displist calculation */
+               if (ob->type == OB_CURVE && ob->data != cu) {
+                       cu->taperobj = ob;
+               }
+       } else {
+               cu->taperobj = NULL;
+       }
+}
+
+static void rna_Curve_resolution_u_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+       Nurb *nu= nurbs->first;
+
+       while(nu) {
+               nu->resolu= cu->resolu;
+               nu= nu->next;
+       }
+       
+       rna_Curve_update_data(bmain, scene, ptr);
+}
+
+static void rna_Curve_resolution_v_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       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);
+}
+
+/* name functions that ignore the first two ID characters */
+void rna_Curve_body_get(PointerRNA *ptr, char *value)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       BLI_strncpy(value, cu->str, cu->len+1);
+}
+
+int rna_Curve_body_length(PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->id.data;
+       return cu->len;
+}
+
+/* TODO - check UTF & python play nice */
+void rna_Curve_body_set(PointerRNA *ptr, const char *value)
+{
+       int len= strlen(value);
+       Curve *cu= (Curve*)ptr->id.data;
+
+       cu->len= cu->pos = len;
+
+       if(cu->str)             MEM_freeN(cu->str);
+       if(cu->strinfo) MEM_freeN(cu->strinfo);
+
+       cu->str = MEM_callocN(len + sizeof(wchar_t), "str");
+       cu->strinfo = MEM_callocN( (len+4) *sizeof(CharInfo), "strinfo"); /* don't know why this is +4, just duplicating load_editText() */
+
+       //wcs2utf8s(cu->str, value); // value is not wchar_t
+       BLI_strncpy(cu->str, value, len+1);
+}
+
+static void rna_Nurb_update_handle_data(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       Nurb *nu= (Nurb*)ptr->data;
+
+       if(nu->type == CU_BEZIER)
+               calchandlesNurb(nu);
+
+       rna_Curve_update_data(bmain, scene, ptr);
+}
+
+static void rna_Nurb_update_knot_u(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       Nurb *nu= (Nurb*)ptr->data;
+
+       clamp_nurb_order_u(nu);
+       makeknots(nu, 1);
+
+       rna_Curve_update_data(bmain, scene, ptr);
+}
+
+static void rna_Nurb_update_knot_v(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       Nurb *nu= (Nurb*)ptr->data;
+
+       clamp_nurb_order_v(nu);
+       makeknots(nu, 2);
+
+       rna_Curve_update_data(bmain, scene, ptr);
+}
+
+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");
+       }
+       else if(number==0) {
+               // do nothing
+       } else {
+
+               addNurbPoints(nu, number);
+
+               /* update */
+               makeknots(nu, 1);
+
+               rna_Curve_update_data_id(NULL, NULL, id);
+       }
+}
+
+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");
+       }
+       else if(number==0) {
+               // do nothing
+       } else {
+               addNurbPointsBezier(nu, number);
+
+               /* update */
+               makeknots(nu, 1);
+
+               rna_Curve_update_data_id(NULL, NULL, id);
+       }
+}
+
+static Nurb *rna_Curve_spline_new(Curve *cu, int type)
+{
+       Nurb *nu= ( Nurb * ) MEM_callocN( sizeof( Nurb ), "spline.new" );
+
+       if(type==CU_BEZIER) {
+               BezTriple *bezt= (BezTriple *)MEM_callocN(sizeof(BezTriple), "spline.new.bezt");
+               bezt->radius= 1.0;
+               nu->bezt= bezt;
+       }
+       else {
+               BPoint *bp= (BPoint *)MEM_callocN(sizeof(BPoint), "spline.new.bp");
+               bp->radius= 1.0f;
+               nu->bp= bp;
+       }
+
+       nu->type= type;
+       nu->pntsu= 1;
+       nu->pntsv= 1;
+
+       nu->orderu= nu->orderv= 4;
+       nu->resolu= nu->resolv= 12;
+       nu->flag= CU_SMOOTH;
+
+       BLI_addtail(&cu->nurb, nu);
+
+       return nu;
+}
+
+static void rna_Curve_spline_remove(Curve *cu, ReportList *reports, Nurb *nu)
+{
+       /* todo, check we're in the list */
+       int found= 0;
+       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);
+               return;
+       }
+
+       freeNurb(nu);
+       /* invalidate pointer!, no can do */
+}
+
+static PointerRNA rna_Curve_active_spline_get(PointerRNA *ptr)
+{
+       Curve *cu= (Curve*)ptr->data;
+       Nurb *nu;
+       ListBase *nurbs= BKE_curve_nurbs(cu);
+
+       // 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);
+
+       return rna_pointer_inherit_refine(ptr, NULL, NULL);
+}
+
+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
+               cu->actnu= BLI_findindex(nubase, nu);
 }
 
 #else
@@ -169,41 +517,47 @@ static void rna_def_bpoint(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       srna= RNA_def_struct(brna, "CurvePoint", NULL);
+       srna= RNA_def_struct(brna, "SplinePoint", NULL);
        RNA_def_struct_sdna(srna, "BPoint");
-       RNA_def_struct_ui_text(srna, "CurvePoint", "Curve point without handles.");
+       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 */
-       prop= RNA_def_property(srna, "point", PROP_FLOAT, PROP_TRANSLATION);
-       RNA_def_property_array(prop, 4);
+       prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_TRANSLATION);
+       RNA_def_property_array(prop, 3);
        RNA_def_property_float_sdna(prop, NULL, "vec");
        RNA_def_property_ui_text(prop, "Point", "Point coordinates");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
+       prop= RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "vec[3]");
+       RNA_def_property_ui_text(prop, "Weight", "Nurbs weight");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
        /* Number values */
        prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "alfa");
        /*RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);*/
-       RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3d View");
+       RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3D View");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "weight_softbody", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "weight");
        RNA_def_property_range(prop, 0.01f, 100.0f);
        RNA_def_property_ui_text(prop, "Weight", "Softbody goal weight");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "bevel_radius", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "radius");
        /*RNA_def_property_range(prop, 0.0f, 1.0f);*/
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
@@ -216,29 +570,29 @@ static void rna_def_beztriple(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       srna= RNA_def_struct(brna, "BezierCurvePoint", NULL);
+       srna= RNA_def_struct(brna, "BezierSplinePoint", NULL);
        RNA_def_struct_sdna(srna, "BezTriple");
-       RNA_def_struct_ui_text(srna, "Bezier Curve Point", "Bezier curve point with two handles.");
+       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 */
@@ -254,18 +608,6 @@ static void rna_def_beztriple(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Handle 2 Type", "Handle types");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "interpolation", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "ipo");
-       RNA_def_property_enum_items(prop, beztriple_interpolation_mode_items);
-       RNA_def_property_ui_text(prop, "Interpolation", "(For F-Curves Only) Interpolation to use for segment of curve starting from current BezTriple.");
-       //RNA_def_property_update(prop, 0, "rna_Curve_update_data"); // this should be an F-Curve update call instead...
-       
-       prop= RNA_def_property(srna, "keyframe_type", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "hide");
-       RNA_def_property_enum_items(prop, beztriple_keyframe_type_items);
-       RNA_def_property_ui_text(prop, "Keyframe Type", "(For F-Curves only) The type of keyframe this control point defines.");
-       //RNA_def_property_update(prop, 0, "rna_Curve_update_data"); // this should be an F-Curve update call instead...
-
        /* Vector values */
        prop= RNA_def_property(srna, "handle1", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_array(prop, 3);
@@ -273,7 +615,7 @@ static void rna_def_beztriple(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Handle 1", "Coordinates of the first handle");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "control_point", PROP_FLOAT, PROP_TRANSLATION);
+       prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_array(prop, 3);
        RNA_def_property_float_funcs(prop, "rna_BezTriple_ctrlpoint_get", "rna_BezTriple_ctrlpoint_set", NULL);
        RNA_def_property_ui_text(prop, "Control Point", "Coordinates of the control point");
@@ -289,7 +631,7 @@ static void rna_def_beztriple(BlenderRNA *brna)
        prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "alfa");
        /*RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);*/
-       RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3d View");
+       RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3D View");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
@@ -297,7 +639,7 @@ static void rna_def_beztriple(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Weight", "Softbody goal weight");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
-       prop= RNA_def_property(srna, "bevel_radius", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "radius");
        /*RNA_def_property_range(prop, 0.0f, 1.0f);*/
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
@@ -312,29 +654,34 @@ static void rna_def_path(BlenderRNA *brna, StructRNA *srna)
        /* number values */
        prop= RNA_def_property(srna, "path_length", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "pathlen");
-       RNA_def_property_range(prop, 1, 32767);
-       RNA_def_property_ui_text(prop, "Path Length", "If no speed IPO was set, the length of path in frames.");
+       RNA_def_property_range(prop, 1, MAXFRAME);
+       RNA_def_property_ui_text(prop, "Path Length", "The number of frames that are needed to traverse the path, defining the maximum value for the 'Evaluation Time' setting");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* flags */
-       prop= RNA_def_property(srna, "path", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_path", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_PATH);
-       RNA_def_property_ui_text(prop, "Path", "Enable the curve to become a translation path.");
+       RNA_def_property_ui_text(prop, "Path", "Enable the curve to become a translation path");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
-       prop= RNA_def_property(srna, "follow", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_path_follow", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FOLLOW);
-       RNA_def_property_ui_text(prop, "Follow", "Make curve path children to rotate along the path.");
+       RNA_def_property_ui_text(prop, "Follow", "Make curve path children to rotate along the path");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
-       prop= RNA_def_property(srna, "stretch", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_stretch", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_STRETCH);
-       RNA_def_property_ui_text(prop, "Stretch", "Option for curve-deform: makes deformed child to stretch along entire path.");
+       RNA_def_property_ui_text(prop, "Stretch", "Option for curve-deform: makes deformed child to stretch along entire path");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
-       prop= RNA_def_property(srna, "offset_path_distance", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_time_offset", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_OFFS_PATHDIST);
-       RNA_def_property_ui_text(prop, "Offset Path Distance", "Children will use TimeOffs value as path distance offset.");
+       RNA_def_property_ui_text(prop, "Offset Path Distance", "Children will use TimeOffs value as path distance offset");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
+       prop= RNA_def_property(srna, "use_radius", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_PATH_RADIUS);
+       RNA_def_property_ui_text(prop, "Radius", "Option for paths: apply the curve radius with path following it and deforming");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
@@ -343,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);
@@ -369,16 +716,23 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        /* Enums */
        prop= RNA_def_property(srna, "spacemode", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, prop_align_items);
-       RNA_def_property_ui_text(prop, "Text Align", "Text align from the object center.");
+       RNA_def_property_ui_text(prop, "Text Align", "Text align from the object center");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* number values */
        prop= RNA_def_property(srna, "text_size", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "fsize");
-       RNA_def_property_range(prop, 0.1f, 10.0f);
+       RNA_def_property_range(prop, 0.0001f, 10000.0f);
+       RNA_def_property_ui_range(prop, 0.01, 10, 1, 1);
        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);
@@ -406,72 +760,77 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        prop= RNA_def_property(srna, "offset_x", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "xof");
        RNA_def_property_range(prop, -50.0f, 50.0f);
-       RNA_def_property_ui_text(prop, "X Offset", "Horizontal offset from the object center");
+       RNA_def_property_ui_text(prop, "X Offset", "Horizontal offset from the object origin");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "offset_y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "yof");
        RNA_def_property_range(prop, -50.0f, 50.0f);
-       RNA_def_property_ui_text(prop, "Y Offset", "Vertical offset from the object center");
+       RNA_def_property_ui_text(prop, "Y Offset", "Vertical offset from the object origin");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "ul_position", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ulpos");
        RNA_def_property_range(prop, -0.2f, 0.8f);
-       RNA_def_property_ui_text(prop, "Underline position", "Vertical position of underline");
+       RNA_def_property_ui_text(prop, "Underline Position", "Vertical position of underline");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "ul_height", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ulheight");
        RNA_def_property_range(prop, -0.2f, 0.8f);
-       RNA_def_property_ui_text(prop, "Underline thickness", "");
+       RNA_def_property_ui_text(prop, "Underline Thickness", "");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
+       prop= RNA_def_property(srna, "textboxes", PROP_COLLECTION, PROP_NONE);
+       RNA_def_property_collection_sdna(prop, NULL, "tb", "totbox");
+       RNA_def_property_struct_type(prop, "TextBox");
+       RNA_def_property_ui_text(prop, "Textboxes", "");
+
        prop= RNA_def_property(srna, "active_textbox", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "actbox");
-       RNA_def_property_range(prop, 0, 100);
        RNA_def_property_ui_text(prop, "The active text box", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_int_funcs(prop, NULL, NULL, "rna_Curve_active_textbox_index_range");
        
        /* strings */
        prop= RNA_def_property(srna, "family", PROP_STRING, PROP_NONE);
        RNA_def_property_string_maxlength(prop, 21);
-       RNA_def_property_ui_text(prop, "Family", "Blender uses font from selfmade objects.");
+       RNA_def_property_ui_text(prop, "Object Font", "Use Blender Objects as font characters. Give font objects a common name followed by the character it represents, eg. familya, familyb etc, and turn on Verts Duplication");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
-       prop= RNA_def_property(srna, "str", PROP_STRING, PROP_NONE);
+       prop= RNA_def_property(srna, "body", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "str");
-       RNA_def_property_ui_text(prop, "String", "");
-       RNA_def_property_string_funcs(prop, "rna_ID_name_get", "rna_ID_name_length", "rna_ID_name_set");
+       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);
        RNA_def_property_pointer_sdna(prop, NULL, "textoncurve");
        RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Text on Curve", "Curve deforming text object.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_ui_text(prop, "Text on Curve", "Curve deforming text object");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_deps");
        
        prop= RNA_def_property(srna, "font", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "vfont");
        RNA_def_property_ui_text(prop, "Font", "");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
-       
-       prop= RNA_def_property(srna, "textbox", PROP_POINTER, PROP_NONE);
-       RNA_def_property_pointer_sdna(prop, NULL, "tb");
-       RNA_def_property_ui_text(prop, "Textbox", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
-       
+
        prop= RNA_def_property(srna, "edit_format", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "curinfo");
-       RNA_def_property_ui_text(prop, "Edit Format", "Editing settings character formatting.");
+       RNA_def_property_ui_text(prop, "Edit Format", "Editing settings character formatting");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* flags */
        prop= RNA_def_property(srna, "fast", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FAST);
-       RNA_def_property_ui_text(prop, "Fast", "Don't fill polygons while editing.");
+       RNA_def_property_ui_text(prop, "Fast", "Don't fill polygons while editing");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
@@ -481,7 +840,8 @@ static void rna_def_textbox(BlenderRNA *brna)
        PropertyRNA *prop;
        
        srna= RNA_def_struct(brna, "TextBox", NULL);
-       RNA_def_struct_ui_text(srna, "Text Box", "Text bounding box for layout.");
+       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);
@@ -516,32 +876,33 @@ static void rna_def_charinfo(BlenderRNA *brna)
        
        srna= RNA_def_struct(brna, "TextCharacterFormat", NULL);
        RNA_def_struct_sdna(srna, "CharInfo");
-       RNA_def_struct_ui_text(srna, "Text Character Format", "Text character formatting settings.");
+       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");
 }
 
@@ -551,7 +912,7 @@ static void rna_def_surface(BlenderRNA *brna)
        
        srna= RNA_def_struct(brna, "SurfaceCurve", "Curve");
        RNA_def_struct_sdna(srna, "Curve");
-       RNA_def_struct_ui_text(srna, "Surface Curve", "Curve datablock used for storing surfaces.");
+       RNA_def_struct_ui_text(srna, "Surface Curve", "Curve datablock used for storing surfaces");
        RNA_def_struct_ui_icon(srna, ICON_SURFACE_DATA);
 
        rna_def_nurbs(brna, srna);
@@ -563,34 +924,149 @@ static void rna_def_text(BlenderRNA *brna)
        
        srna= RNA_def_struct(brna, "TextCurve", "Curve");
        RNA_def_struct_sdna(srna, "Curve");
-       RNA_def_struct_ui_text(srna, "Text Curve", "Curve datablock used for storing text.");
+       RNA_def_struct_ui_text(srna, "Text Curve", "Curve datablock used for storing text");
        RNA_def_struct_ui_icon(srna, ICON_FONT_DATA);
 
        rna_def_font(brna, srna);
        rna_def_nurbs(brna, srna);
 }
 
+
+/* curve.splines[0].points */
+static void rna_def_curve_spline_points(BlenderRNA *brna, PropertyRNA *cprop)
+{
+       StructRNA *srna;
+       //PropertyRNA *prop;
+
+       FunctionRNA *func;
+       PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "SplinePoints");
+       srna= RNA_def_struct(brna, "SplinePoints", NULL);
+       RNA_def_struct_sdna(srna, "Nurb");
+       RNA_def_struct_ui_text(srna, "Spline Points", "Collection of spline points");
+
+       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_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);
+
+       /*
+       func= RNA_def_function(srna, "remove", "rna_Curve_spline_remove");
+       RNA_def_function_ui_description(func, "Remove a spline from a curve.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS);
+       parm= RNA_def_pointer(func, "spline", "Spline", "", "The spline to remove.");
+       RNA_def_property_flag(parm, PROP_REQUIRED);
+       */
+}
+
+static void rna_def_curve_spline_bezpoints(BlenderRNA *brna, PropertyRNA *cprop)
+{
+       StructRNA *srna;
+       //PropertyRNA *prop;
+
+       FunctionRNA *func;
+       PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "SplineBezierPoints");
+       srna= RNA_def_struct(brna, "SplineBezierPoints", NULL);
+       RNA_def_struct_sdna(srna, "Nurb");
+       RNA_def_struct_ui_text(srna, "Spline Bezier Points", "Collection of spline bezirt points");
+
+       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_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);
+
+       /*
+       func= RNA_def_function(srna, "remove", "rna_Curve_spline_remove");
+       RNA_def_function_ui_description(func, "Remove a spline from a curve.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS);
+       parm= RNA_def_pointer(func, "spline", "Spline", "", "The spline to remove.");
+       RNA_def_property_flag(parm, PROP_REQUIRED);
+       */
+}
+
+/* curve.splines */
+static void rna_def_curve_splines(BlenderRNA *brna, PropertyRNA *cprop)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       FunctionRNA *func;
+       PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "CurveSplines");
+       srna= RNA_def_struct(brna, "CurveSplines", NULL);
+       RNA_def_struct_sdna(srna, "Curve");
+       RNA_def_struct_ui_text(srna, "Curve Splines", "Collection of curve splines");
+
+       func= RNA_def_function(srna, "new", "rna_Curve_spline_new");
+       RNA_def_function_ui_description(func, "Add a new spline to the curve.");
+       parm= RNA_def_enum(func, "type", curve_type_items, CU_POLY, "", "type for the new spline.");
+       RNA_def_property_flag(parm, PROP_REQUIRED);
+       parm= RNA_def_pointer(func, "spline", "Spline", "", "The newly created spline.");
+       RNA_def_function_return(func, parm);
+
+       func= RNA_def_function(srna, "remove", "rna_Curve_spline_remove");
+       RNA_def_function_ui_description(func, "Remove a spline from a curve.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS);
+       parm= RNA_def_pointer(func, "spline", "Spline", "", "The spline to remove.");
+       RNA_def_property_flag(parm, PROP_REQUIRED);
+
+       prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "Object");
+       RNA_def_property_pointer_funcs(prop, "rna_Curve_active_spline_get", "rna_Curve_active_spline_set", NULL);
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Active Spline", "Active curve spline");
+       /* Could call: ED_base_object_activate(C, scene->basact);
+        * but would be a bad level call and it seems the notifier is enough */
+       RNA_def_property_update(prop, NC_SCENE|ND_OB_ACTIVE, NULL);
+}
+
+
 static void rna_def_curve(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
        
+       static EnumPropertyItem curve_twist_mode_items[] = {
+                       {CU_TWIST_Z_UP, "Z_UP", 0, "Z-Up", "Use Z-Up axis to calculate the curve twist at each point"},
+                       {CU_TWIST_MINIMUM, "MINIMUM", 0, "Minimum", "Use the least twist over the entire curve"},
+                       {CU_TWIST_TANGENT, "TANGENT", 0, "Tangent", "Use the tangent to calculate twist"},
+                       {0, NULL, 0, NULL, NULL}};
+
+       static const EnumPropertyItem curve_axis_items[]= {
+               {0, "2D", 0, "2D", "Clamp the Z axis of of the curve"},
+               {CU_3D, "3D", 0, "3D", "Allow editing on the Z axis of this curve, also alows tilt and curve radius to be used"},
+               {0, NULL, 0, NULL, NULL}};
+                       
        srna= RNA_def_struct(brna, "Curve", "ID");
-       RNA_def_struct_ui_text(srna, "Curve", "Curve datablock storing curves, splines and NURBS.");
+       RNA_def_struct_ui_text(srna, "Curve", "Curve datablock storing curves, splines and NURBS");
        RNA_def_struct_ui_icon(srna, ICON_CURVE_DATA);
        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");
        RNA_def_property_ui_text(prop, "Shape Keys", "");
 
-       prop= RNA_def_property(srna, "curves", PROP_COLLECTION, PROP_NONE);
+       prop= RNA_def_property(srna, "splines", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "nurb", NULL);
-       RNA_def_property_struct_type(prop, "Nurb");
-       RNA_def_property_ui_text(prop, "Curves", "Collection of curves in this curve data object.");
+       RNA_def_property_struct_type(prop, "Spline");
+       RNA_def_property_ui_text(prop, "Splines", "Collection of splines in this curve data object");
+       rna_def_curve_splines(brna, prop);
+
+       prop= RNA_def_property(srna, "draw_handles", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "drawflag", CU_HIDE_HANDLES);
+       RNA_def_property_ui_text(prop, "Draw Handles", "Display bezier handles in editmode");
+       RNA_def_property_update(prop, NC_GEOM|ND_DATA, NULL);
+
+       prop= RNA_def_property(srna, "draw_normals", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "drawflag", CU_HIDE_NORMALS);
+       RNA_def_property_ui_text(prop, "Draw Normals", "Display 3D curve normals in editmode");
+       RNA_def_property_update(prop, NC_GEOM|ND_DATA, NULL);
 
        rna_def_path(brna, srna);
        
@@ -599,88 +1075,150 @@ static void rna_def_curve(BlenderRNA *brna)
        RNA_def_property_int_sdna(prop, NULL, "bevresol");
        RNA_def_property_range(prop, 0, 32);
        RNA_def_property_ui_range(prop, 0, 32, 1.0, 0);
-       RNA_def_property_ui_text(prop, "Bevel Resolution", "Bevel resolution when depth is non-zero and no specific bevel object has been defined.");
+       RNA_def_property_ui_text(prop, "Bevel Resolution", "Bevel resolution when depth is non-zero and no specific bevel object has been defined");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "width", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "width");
        RNA_def_property_ui_range(prop, 0, 2.0, 0.1, 0);
-       RNA_def_property_ui_text(prop, "Width", "Scale the original width (1.0) based on given factor.");
+       RNA_def_property_ui_text(prop, "Width", "Scale the original width (1.0) based on given factor");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "extrude", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ext1");
        RNA_def_property_ui_range(prop, 0, 100.0, 0.1, 0);
-       RNA_def_property_ui_text(prop, "Extrude", "Amount of curve extrusion when not using a bevel object.");
+       RNA_def_property_range(prop, 0.0, FLT_MAX);
+       RNA_def_property_ui_text(prop, "Extrude", "Amount of curve extrusion when not using a bevel object");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "bevel_depth", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ext2");
        RNA_def_property_ui_range(prop, 0, 100.0, 0.1, 0);
-       RNA_def_property_ui_text(prop, "Bevel Depth", "Bevel depth when not using a bevel object.");
+       RNA_def_property_ui_text(prop, "Bevel Depth", "Bevel depth when not using a bevel object");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu");
-       RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
-       RNA_def_property_ui_text(prop, "Resolution U", "Surface resolution in U direction.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_range(prop, 1, INT_MAX);
+       RNA_def_property_ui_range(prop, 1, 64, 1, 0);
+       RNA_def_property_ui_text(prop, "Resolution U", "Surface resolution in U direction");
+       RNA_def_property_update(prop, 0, "rna_Curve_resolution_u_update_data");
        
        prop= RNA_def_property(srna, "resolution_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolv");
-       RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
-       RNA_def_property_ui_text(prop, "Resolution V", "Surface resolution in V direction.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_ui_range(prop, 1, 64, 1, 0);
+       RNA_def_property_range(prop, 1, INT_MAX);
+       RNA_def_property_ui_text(prop, "Resolution V", "Surface resolution in V direction");
+       RNA_def_property_update(prop, 0, "rna_Curve_resolution_v_update_data");
        
        prop= RNA_def_property(srna, "render_resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu_ren");
-       RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
-       RNA_def_property_ui_text(prop, "Render Resolution U", "Surface resolution in U direction used while rendering. Zero skips this property.");
+       RNA_def_property_range(prop, 0, INT_MAX);
+       RNA_def_property_ui_range(prop, 0, 64, 1, 0);
+       RNA_def_property_ui_text(prop, "Render Resolution U", "Surface resolution in U direction used while rendering. Zero skips this property");
        
        prop= RNA_def_property(srna, "render_resolution_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolv_ren");
-       RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
-       RNA_def_property_ui_text(prop, "Render Resolution V", "Surface resolution in V direction used while rendering. Zero skips this property.");
+       RNA_def_property_ui_range(prop, 0, 64, 1, 0);
+       RNA_def_property_range(prop, 0, INT_MAX);
+       RNA_def_property_ui_text(prop, "Render Resolution V", "Surface resolution in V direction used while rendering. Zero skips this property");
        
        
        prop= RNA_def_property(srna, "eval_time", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ctime");
-       RNA_def_property_ui_text(prop, "Evaluation Time", "Parametric position along the length of the curve that Objects 'following' it should be at.");
+       RNA_def_property_ui_text(prop, "Evaluation Time", "Parametric position along the length of the curve that Objects 'following' it should be at. Position is evaluated by dividing by the 'Path Length' value");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* pointers */
        prop= RNA_def_property(srna, "bevel_object", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "Object");
        RNA_def_property_pointer_sdna(prop, NULL, "bevobj");
        RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Bevel Object", "Curve object name that defines the bevel shape.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
-       
+       RNA_def_property_ui_text(prop, "Bevel Object", "Curve object name that defines the bevel shape");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_deps");
+       RNA_def_property_pointer_funcs(prop, "rna_Curve_bevelObject_get", "rna_Curve_bevelObject_set", NULL);
+
        prop= RNA_def_property(srna, "taper_object", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "Object");
        RNA_def_property_pointer_sdna(prop, NULL, "taperobj");
        RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Taper Object", "Curve object name that defines the taper (width).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
-       
+       RNA_def_property_ui_text(prop, "Taper Object", "Curve object name that defines the taper (width)");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_deps");
+       RNA_def_property_pointer_funcs(prop, "rna_Curve_taperObject_get", "rna_Curve_taperObject_set", NULL);
+
        /* Flags */
-       prop= RNA_def_property(srna, "curve_2d", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", CU_3D);
-       RNA_def_property_ui_text(prop, "2D Curve", "Define curve in two dimensions only. Note that fill only works when this is enabled.");
+
+       prop= RNA_def_property(srna, "dimensions", PROP_ENUM, PROP_NONE); /* as an enum */
+       RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
+       RNA_def_property_enum_items(prop, curve_axis_items);
+       RNA_def_property_enum_funcs(prop, NULL, "rna_Curve_dimension_set", NULL);
+       RNA_def_property_ui_text(prop, "Dimensions", "Select 2D or 3D curve type");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "front", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FRONT);
-       RNA_def_property_ui_text(prop, "Front", "Draw filled front for extruded/beveled curves.");
+       RNA_def_property_ui_text(prop, "Front", "Draw filled front for extruded/beveled curves");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "back", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_BACK);
-       RNA_def_property_ui_text(prop, "Back", "Draw filled back for extruded/beveled curves.");
+       RNA_def_property_ui_text(prop, "Back", "Draw filled back for extruded/beveled curves");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
+       prop= RNA_def_property(srna, "twist_mode", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "twist_mode");
+       RNA_def_property_enum_items(prop, curve_twist_mode_items);
+       RNA_def_property_ui_text(prop, "Twist Method", "The type of tilt calculation for 3D Curves");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
+       // XXX - would be nice to have a better way to do this, only add for testing.
+       prop= RNA_def_property(srna, "twist_smooth", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "twist_smooth");
+       RNA_def_property_ui_range(prop, 0, 100.0, 0.1, 0);
+       RNA_def_property_ui_text(prop, "Twist Smooth", "Smoothing iteration for tangents");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+
+       prop= RNA_def_property(srna, "use_deform_fill", PROP_BOOLEAN, PROP_NONE);
+       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, "retopo", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_RETOPO);
-       RNA_def_property_ui_text(prop, "Retopo", "Turn on the re-topology tool.");
+       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)
@@ -695,41 +1233,50 @@ static void rna_def_curve_nurb(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       srna= RNA_def_struct(brna, "Nurb", NULL);
-       RNA_def_struct_ui_text(srna, "Nurb", "Element of a curve, either Nurb, Bezier or Polyline or a character with text objects.");
+       srna= RNA_def_struct(brna, "Spline", NULL);
+       RNA_def_struct_sdna(srna, "Nurb");
+       RNA_def_struct_ui_text(srna, "Spline", "Element of a curve, either Nurbs, Bezier or Polyline or a character with text objects");
 
        prop= RNA_def_property(srna, "points", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "bp", NULL);
-       RNA_def_property_struct_type(prop, "CurvePoint");
-       RNA_def_property_collection_funcs(prop, "rna_BPoint_array_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_Nurb_length", 0, 0, 0, 0);
-       RNA_def_property_ui_text(prop, "Points", "Collection of points for Poly and Nurbs curves.");
+       RNA_def_property_struct_type(prop, "SplinePoint");
+       RNA_def_property_collection_funcs(prop, "rna_BPoint_array_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_Nurb_length", 0, 0);
+       RNA_def_property_ui_text(prop, "Points", "Collection of points that make up this poly or nurbs spline");
+       rna_def_curve_spline_points(brna, prop);
 
        prop= RNA_def_property(srna, "bezier_points", PROP_COLLECTION, PROP_NONE);
-       RNA_def_property_struct_type(prop, "BezierCurvePoint");
+       RNA_def_property_struct_type(prop, "BezierSplinePoint");
        RNA_def_property_collection_sdna(prop, NULL, "bezt", "pntsu");
-       RNA_def_property_ui_text(prop, "Bezier Points", "Collection of points bezier curves only.");
+       RNA_def_property_ui_text(prop, "Bezier Points", "Collection of points for bezier curves only");
+       rna_def_curve_spline_bezpoints(brna, prop);
 
        
        prop= RNA_def_property(srna, "tilt_interpolation", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "tilt_interp");
        RNA_def_property_enum_items(prop, spline_interpolation_items);
-       RNA_def_property_ui_text(prop, "Tilt Interpolation", "The type of tilt interpolation for 3D, Bezier curves.");
+       RNA_def_property_ui_text(prop, "Tilt Interpolation", "The type of tilt interpolation for 3D, Bezier curves");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "radius_interpolation", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "radius_interp");
        RNA_def_property_enum_items(prop, spline_interpolation_items);
-       RNA_def_property_ui_text(prop, "Radius Interpolation", "The type of radius interpolation for Bezier curves.");
+       RNA_def_property_ui_text(prop, "Radius Interpolation", "The type of radius interpolation for Bezier curves");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
+       // XXX - switching type probably needs comprehensive recalc of data like in 2.4x
+       prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, curve_type_items);
+       RNA_def_property_enum_funcs(prop, NULL, "rna_Nurb_type_set", NULL);
+       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");
@@ -739,69 +1286,71 @@ static void rna_def_curve_nurb(BlenderRNA *brna)
        prop= RNA_def_property(srna, "order_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "orderu");
        RNA_def_property_range(prop, 2, 6);
-       RNA_def_property_ui_text(prop, "Order U", "Nurbs order in the U direction (For curves and surfaces), Higher values let points influence a greater area");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_ui_text(prop, "Order U", "Nurbs order in the U direction (For splines and surfaces), Higher values let points influence a greater area");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_u");
 
        prop= RNA_def_property(srna, "order_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "orderv");
        RNA_def_property_range(prop, 2, 6);
        RNA_def_property_ui_text(prop, "Order V", "Nurbs order in the V direction (For surfaces only), Higher values let points influence a greater area");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_v");
 
 
        prop= RNA_def_property(srna, "resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu");
-       RNA_def_property_range(prop, 1, 1024);
+       RNA_def_property_range(prop, 1, INT_MAX);
+       RNA_def_property_ui_range(prop, 1, 64, 1, 0);
        RNA_def_property_ui_text(prop, "Resolution U", "Curve or Surface subdivisions per segment");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "resolution_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolv");
-       RNA_def_property_range(prop, 1, 1024);
+       RNA_def_property_range(prop, 1, INT_MAX);
+       RNA_def_property_ui_range(prop, 1, 64, 1, 0);
        RNA_def_property_ui_text(prop, "Resolution V", "Surface subdivisions per segment");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "cyclic_u", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagu", CU_CYCLIC);
-       RNA_def_property_ui_text(prop, "Cyclic U", "Make this curve or surface a closed loop in the U direction.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagu", CU_NURB_CYCLIC);
+       RNA_def_property_ui_text(prop, "Cyclic U", "Make this curve or surface a closed loop in the U direction");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_handle_data"); /* only needed for cyclic_u because cyclic_v cant do bezier */
 
        prop= RNA_def_property(srna, "cyclic_v", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagv", CU_CYCLIC);
-       RNA_def_property_ui_text(prop, "Cyclic V", "Make this surface a closed loop in the V direction.");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagv", CU_NURB_CYCLIC);
+       RNA_def_property_ui_text(prop, "Cyclic V", "Make this surface a closed loop in the V direction");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        /* Note, endpoint and bezier flags should never be on at the same time! */
        prop= RNA_def_property(srna, "endpoint_u", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagu", 2);
-       RNA_def_property_ui_text(prop, "Endpoint U", "Make this nurbs curve or surface meet the endpoints in the U direction (Cyclic U must be disabled).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagu", CU_NURB_ENDPOINT);
+       RNA_def_property_ui_text(prop, "Endpoint U", "Make this nurbs curve or surface meet the endpoints in the U direction (Cyclic U must be disabled)");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_u");
 
        prop= RNA_def_property(srna, "endpoint_v", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagv", 2);
-       RNA_def_property_ui_text(prop, "Endpoint V", "Make this nurbs surface meet the endpoints in the V direction (Cyclic V must be disabled).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagv", CU_NURB_ENDPOINT);
+       RNA_def_property_ui_text(prop, "Endpoint V", "Make this nurbs surface meet the endpoints in the V direction (Cyclic V must be disabled)");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_v");
 
        prop= RNA_def_property(srna, "bezier_u", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagu", 4);
-       RNA_def_property_ui_text(prop, "Bezier U", "Make this nurbs curve or surface act like a bezier spline in the U direction (Order U must be 3 or 4, Cyclic U must be disabled).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagu", CU_NURB_BEZIER);
+       RNA_def_property_ui_text(prop, "Bezier U", "Make this nurbs curve or surface act like a bezier spline in the U direction (Order U must be 3 or 4, Cyclic U must be disabled)");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_u");
 
        prop= RNA_def_property(srna, "bezier_v", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flagv", 4);
-       RNA_def_property_ui_text(prop, "Bezier V", "Make this nurbs surface act like a bezier spline in the V direction (Order V must be 3 or 4, Cyclic V must be disabled).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
+       RNA_def_property_boolean_sdna(prop, NULL, "flagv", CU_NURB_BEZIER);
+       RNA_def_property_ui_text(prop, "Bezier V", "Make this nurbs surface act like a bezier spline in the V direction (Order V must be 3 or 4, Cyclic V must be disabled)");
+       RNA_def_property_update(prop, 0, "rna_Nurb_update_knot_v");
 
 
        prop= RNA_def_property(srna, "smooth", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_SMOOTH);
-       RNA_def_property_ui_text(prop, "Smooth", "Smooth the normals of the surface or beveled curve.");
+       RNA_def_property_ui_text(prop, "Smooth", "Smooth the normals of the surface or beveled curve");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 1);
-       RNA_def_property_ui_text(prop, "Hide", "Hide this curve in editmode.");
+       RNA_def_property_ui_text(prop, "Hide", "Hide this curve in editmode");
        RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "material_index", PROP_INT, PROP_UNSIGNED);