merge with/from trunk at r35190
[blender.git] / source / blender / makesrna / intern / rna_userdef.c
index 1e6d656d7ce915e1a5a6d8bbb6b3f9a56fd422a5..1376786469aa36750f28fd8f26a2d2f8ad4cf276 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * $Id$
  *
  * ***** BEGIN GPL LICENSE BLOCK *****
 #include "DNA_space_types.h"
 #include "DNA_userdef_types.h"
 #include "DNA_brush_types.h"
+#include "DNA_view3d_types.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
 
-#include "BKE_utildefines.h"
+#include "BLI_utildefines.h"
 
 #include "BKE_sound.h"
 
 #ifdef RNA_RUNTIME
 
-#include "BKE_main.h"
+#include "DNA_object_types.h"
+#include "DNA_screen_types.h"
+
 #include "BKE_DerivedMesh.h"
 #include "BKE_depsgraph.h"
-#include "DNA_object_types.h"
-#include "GPU_draw.h"
 #include "BKE_global.h"
+#include "BKE_main.h"
+
+#include "GPU_draw.h"
+
+#include "BLF_api.h"
 
 #include "MEM_guardedalloc.h"
 #include "MEM_CacheLimiterC-Api.h"
@@ -58,6 +64,34 @@ static void rna_userdef_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        WM_main_add_notifier(NC_WINDOW, NULL);
 }
 
+static void rna_userdef_show_manipulator_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       UserDef *userdef = (UserDef *)ptr->data;
+
+       /* lame, loop over all views and set */
+       bScreen *sc;
+       ScrArea *sa;
+       SpaceLink *sl;
+
+       /* from scene copy to the other views */
+       for(sc=bmain->screen.first; sc; sc=sc->id.next) {
+               for(sa=sc->areabase.first; sa; sa=sa->next) {
+                       for(sl=sa->spacedata.first; sl; sl=sl->next) {
+                               if(sl->spacetype==SPACE_VIEW3D) {
+                                       View3D *v3d= (View3D *)sl;
+                                       if(userdef->tw_flag & V3D_USE_MANIPULATOR)
+                                               v3d->twflag |= V3D_USE_MANIPULATOR;
+                                       else
+                                               v3d->twflag &= ~V3D_USE_MANIPULATOR;
+                               }
+                       }
+               }
+       }
+       
+       rna_userdef_update(bmain, scene, ptr);
+}
+
+
 static void rna_userdef_script_autoexec_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        UserDef *userdef = (UserDef*)ptr->data;
@@ -185,7 +219,7 @@ static void rna_UserDef_weight_color_update(Main *bmain, Scene *scene, PointerRN
 
        for(ob= bmain->object.first; ob; ob= ob->id.next) {
                if(ob->mode & OB_MODE_WEIGHT_PAINT)
-                       DAG_id_flush_update(&ob->id, OB_RECALC_DATA);
+                       DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
        }
 
        rna_userdef_update(bmain, scene, ptr);
@@ -221,8 +255,13 @@ static void rna_userdef_addon_remove(bAddon *bext)
 static void rna_userdef_temp_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        extern char btempdir[];
-       UserDef *userdef = (UserDef*)ptr->data;
-       strncpy(btempdir, userdef->tempdir, FILE_MAXDIR+FILE_MAXFILE);
+       BLI_where_is_temp(btempdir, FILE_MAX, 1);
+}
+
+static void rna_userdef_text_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       BLF_cache_clear();
+       WM_main_add_notifier(NC_WINDOW, NULL);
 }
 
 #else
@@ -334,32 +373,32 @@ static void rna_def_userdef_theme_ui_wcol(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "uiWidgetColors");
        RNA_def_struct_ui_text(srna, "Theme Widget Color Set", "Theme settings for widget color sets");
                
-       prop= RNA_def_property(srna, "outline", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "outline", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Outline", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "inner", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Inner", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "inner_sel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_sel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Inner Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "item", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "item", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Item", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "text_sel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "text_sel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Text Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -389,32 +428,32 @@ static void rna_def_userdef_theme_ui_wcol_state(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "uiWidgetStateColors");
        RNA_def_struct_ui_text(srna, "Theme Widget State Color", "Theme settings for widget state colors");
                
-       prop= RNA_def_property(srna, "inner_anim", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_anim", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Animated", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "inner_anim_sel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_anim_sel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Animated Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "inner_key", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_key", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Keyframe", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "inner_key_sel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_key_sel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Keyframe Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "inner_driven", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_driven", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Driven", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "inner_driven_sel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "inner_driven_sel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Driven Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -566,60 +605,60 @@ static void rna_def_userdef_theme_spaces_main(StructRNA *srna, int spacetype)
        PropertyRNA *prop;
 
        /* window */
-       prop= RNA_def_property(srna, "back", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "back", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Window Background", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "title", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "title", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Title", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "text_hi", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "text_hi", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Text Highlight", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        /* header */
-       prop= RNA_def_property(srna, "header", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "header", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Header", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "header_text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "header_text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Header Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "header_text_hi", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "header_text_hi", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Header Text Highlight", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
        /* buttons */
 //     if(! ELEM(spacetype, SPACE_BUTS, SPACE_OUTLINER)) {
-       prop= RNA_def_property(srna, "button", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "button", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Region Background", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "button_title", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "button_title", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Region Text Titles", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "button_text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "button_text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Region Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "button_text_hi", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "button_text_hi", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Region Text Highlight", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -627,22 +666,22 @@ static void rna_def_userdef_theme_spaces_main(StructRNA *srna, int spacetype)
        
        /* list/channels */
        if(ELEM5(spacetype, SPACE_IPO, SPACE_ACTION, SPACE_NLA, SPACE_NODE, SPACE_FILE)) {
-               prop= RNA_def_property(srna, "list", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "list", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Source List", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
                
-               prop= RNA_def_property(srna, "list_title", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "list_title", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Source List Title", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
                
-               prop= RNA_def_property(srna, "list_text", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "list_text", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Source List Text", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
                
-               prop= RNA_def_property(srna, "list_text_hi", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "list_text_hi", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Source List Text Highlight", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -653,12 +692,12 @@ static void rna_def_userdef_theme_spaces_vertex(StructRNA *srna)
 {
        PropertyRNA *prop;
 
-       prop= RNA_def_property(srna, "vertex", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "vertex", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Vertex", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "vertex_select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "vertex_select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Vertex Select", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -673,27 +712,27 @@ static void rna_def_userdef_theme_spaces_edge(StructRNA *srna)
 {
        PropertyRNA *prop;
 
-       prop= RNA_def_property(srna, "edge_select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "edge_select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Edge Select", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "edge_seam", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "edge_seam", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Edge Seam", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "edge_sharp", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "edge_sharp", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Edge Sharp", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "edge_crease", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "edge_crease", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Edge Crease", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "edge_facesel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "edge_facesel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Edge UV Face Select", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -703,17 +742,17 @@ static void rna_def_userdef_theme_spaces_face(StructRNA *srna)
 {
        PropertyRNA *prop;
 
-       prop= RNA_def_property(srna, "face", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "face", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Face", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "face_select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "face_select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Face Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "face_dot", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "face_dot", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Face Dot Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -729,86 +768,86 @@ static void rna_def_userdef_theme_spaces_curves(StructRNA *srna, short incl_nurb
        PropertyRNA *prop;
        
        if (incl_nurbs) {
-               prop= RNA_def_property(srna, "nurb_uline", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "nurb_uline", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_float_sdna(prop, NULL, "nurb_uline");
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Nurb U-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-               prop= RNA_def_property(srna, "nurb_vline", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "nurb_vline", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_float_sdna(prop, NULL, "nurb_vline");
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Nurb V-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-               prop= RNA_def_property(srna, "nurb_sel_uline", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "nurb_sel_uline", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_float_sdna(prop, NULL, "nurb_sel_uline");
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Nurb active U-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-               prop= RNA_def_property(srna, "nurb_sel_vline", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "nurb_sel_vline", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_float_sdna(prop, NULL, "nurb_sel_vline");
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Nurb active V-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-               prop= RNA_def_property(srna, "act_spline", PROP_FLOAT, PROP_COLOR);
+               prop= RNA_def_property(srna, "act_spline", PROP_FLOAT, PROP_COLOR_GAMMA);
                RNA_def_property_float_sdna(prop, NULL, "act_spline");
                RNA_def_property_array(prop, 3);
                RNA_def_property_ui_text(prop, "Active spline", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
        }
 
-       prop= RNA_def_property(srna, "handle_free", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_free", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_free");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Free handle color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_auto", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_auto", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_auto");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Auto handle color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_vect", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_vect", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_vect");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Vector handle color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_align", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_align", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_align");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Align handle color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_sel_free", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_sel_free", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_sel_free");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Free handle selected color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_sel_auto", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_sel_auto", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_sel_auto");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Auto handle selected color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_sel_vect", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_sel_vect", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_sel_vect");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Vector handle selected color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_sel_align", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_sel_align", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "handle_sel_align");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Align handle selected color", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "lastsel_point", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "lastsel_point", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "lastsel_point");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Last selected point", "");
@@ -828,51 +867,51 @@ static void rna_def_userdef_theme_space_view3d(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_VIEW3D);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Panel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "wire", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "wire", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Wire", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "lamp", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "lamp", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Lamp", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "object_selected", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "object_selected", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Object Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "object_active", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "object_active", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "active");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active Object", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "object_grouped", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "object_grouped", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Object Grouped", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "object_grouped_active", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "object_grouped_active", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group_active");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Object Grouped Active", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "transform", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "transform", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Transform", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -882,38 +921,53 @@ static void rna_def_userdef_theme_space_view3d(BlenderRNA *brna)
        rna_def_userdef_theme_spaces_face(srna);
        rna_def_userdef_theme_spaces_curves(srna, 1);
 
-       prop= RNA_def_property(srna, "editmesh_active", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "extra_edge_len", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Edge Length Text", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "extra_face_angle", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Face Angle Text", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "extra_face_area", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Face Area Text", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "editmesh_active", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Active Vert/Edge/Face", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "normal", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "normal", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Face Normal", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "vertex_normal", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "vertex_normal", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Vertex Normal", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "bone_solid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "bone_solid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Bone Solid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "bone_pose", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "bone_pose", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Bone Pose", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "pin", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "pin", PROP_INT, PROP_COLOR);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Pin", "");
        RNA_def_property_update(prop, NC_WINDOW, NULL);
@@ -937,23 +991,23 @@ static void rna_def_userdef_theme_space_graph(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_IPO);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Panel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Window Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "channels_region", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "channels_region", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Channels Region", "");
@@ -962,18 +1016,18 @@ static void rna_def_userdef_theme_space_graph(BlenderRNA *brna)
        rna_def_userdef_theme_spaces_vertex(srna);
        rna_def_userdef_theme_spaces_curves(srna, 0);
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_vertex", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_vertex", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Handle Vertex", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "handle_vertex_select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "handle_vertex_select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Handle Vertex Select", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -983,25 +1037,25 @@ static void rna_def_userdef_theme_space_graph(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Handle Vertex Size", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "channel_group", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "channel_group", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Channel Group", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "active_channels_group", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "active_channels_group", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group_active");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active Channel Group", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "dopesheet_channel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "dopesheet_channel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "ds_channel");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "DopeSheet Channel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "dopesheet_subchannel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "dopesheet_subchannel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "ds_subchannel");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "DopeSheet Sub-Channel", "");
@@ -1021,37 +1075,37 @@ static void rna_def_userdef_theme_space_file(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_FILE);
 
-       prop= RNA_def_property(srna, "selected_file", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "selected_file", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "hilite");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Selected File", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "tiles", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "tiles", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "panel");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Tiles", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "scrollbar", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "scrollbar", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Scrollbar", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "scroll_handle", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "scroll_handle", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Scroll Handle", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "active_file", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "active_file", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "active");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active File", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "active_file_text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "active_file_text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "grid");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active File Text", "");
@@ -1097,31 +1151,31 @@ static void rna_def_userdef_theme_space_console(BlenderRNA *brna)
        
        rna_def_userdef_theme_spaces_main(srna, SPACE_CONSOLE);
        
-       prop= RNA_def_property(srna, "line_output", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "line_output", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "console_output");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Line Output", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "line_input", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "line_input", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "console_input");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Line Input", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "line_info", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "line_info", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "console_info");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Line Info", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "line_error", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "line_error", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "console_error");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Line Error", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "cursor", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "cursor", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "console_cursor");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Cursor", "");
@@ -1155,55 +1209,55 @@ static void rna_def_userdef_theme_space_text(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_TEXT);
 
-       prop= RNA_def_property(srna, "line_numbers_background", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "line_numbers_background", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "grid");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Line Numbers Background", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "scroll_bar", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "scroll_bar", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Scroll Bar", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "selected_text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "selected_text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Selected Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "cursor", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "cursor", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "hilite");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Cursor", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "syntax_builtin", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "syntax_builtin", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxb");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Syntax Built-in", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "syntax_special", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "syntax_special", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxv");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Syntax Special", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "syntax_comment", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "syntax_comment", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxc");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Syntax Comment", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "syntax_string", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "syntax_string", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxl");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Syntax String", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "syntax_numbers", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "syntax_numbers", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxn");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Syntax Numbers", "");
@@ -1223,49 +1277,49 @@ static void rna_def_userdef_theme_space_node(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_NODE);
 
-       prop= RNA_def_property(srna, "wire", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "wire", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "wire");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Wires", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "wire_select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "wire_select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "edge_select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Wire Select", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "selected_text", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "selected_text", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Selected Text", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "node_backdrop", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "node_backdrop", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxl");
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Node Backdrop", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "in_out_node", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "in_out_node", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxn");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "In/Out Node", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "converter_node", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "converter_node", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxv");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Converter Node", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "operator_node", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "operator_node", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxb");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Operator Node", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "group_node", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "group_node", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "syntaxc");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Group Node", "");
@@ -1285,7 +1339,7 @@ static void rna_def_userdef_theme_space_logic(BlenderRNA *brna)
        
        rna_def_userdef_theme_spaces_main(srna, SPACE_LOGIC);
        
-       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Panel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -1305,7 +1359,7 @@ static void rna_def_userdef_theme_space_buts(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_BUTS);
 
-       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "panel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Panel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -1324,12 +1378,12 @@ static void rna_def_userdef_theme_space_time(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_TIME);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
@@ -1349,18 +1403,18 @@ static void rna_def_userdef_theme_space_sound(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_SOUND);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Window Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
@@ -1382,12 +1436,12 @@ static void rna_def_userdef_theme_space_image(BlenderRNA *brna)
        rna_def_userdef_theme_spaces_vertex(srna);
        rna_def_userdef_theme_spaces_face(srna);
 
-       prop= RNA_def_property(srna, "editmesh_active", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "editmesh_active", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Active Vert/Edge/Face", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "scope_back", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "scope_back", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "preview_back");
        RNA_def_property_array(prop, 4);
        RNA_def_property_ui_text(prop, "Scope region background color", "");
@@ -1407,78 +1461,78 @@ static void rna_def_userdef_theme_space_seq(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_IMAGE);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "window_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Window Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "movie_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "movie_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "movie");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Movie Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "image_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "image_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "image");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Image Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "scene_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "scene_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "scene");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Scene Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "audio_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "audio_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "audio");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Audio Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "effect_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "effect_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "effect");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Effect Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "plugin_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "plugin_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "plugin");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Plugin Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "transition_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "transition_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "transition");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Transition Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "meta_strip", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "meta_strip", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "meta");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Meta Strip", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "keyframe", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "keyframe", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "vertex_select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Keyframe", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "draw_action", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "draw_action", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "bone_pose");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Draw Action", "");
@@ -1498,72 +1552,72 @@ static void rna_def_userdef_theme_space_action(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_ACTION);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "value_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "value_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "face");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Value Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "view_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "view_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "View Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "channels", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "channels", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Channels", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "channels_selected", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "channels_selected", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "hilite");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Channels Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "channel_group", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "channel_group", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Channel Group", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "active_channels_group", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "active_channels_group", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "group_active");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active Channel Group", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "long_key", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "long_key", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "strip");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Long Key", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "long_key_selected", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "long_key_selected", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "strip_select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Long Key Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "dopesheet_channel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "dopesheet_channel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "ds_channel");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "DopeSheet Channel", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "dopesheet_subchannel", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "dopesheet_subchannel", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "ds_subchannel");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "DopeSheet Sub-Channel", "");
@@ -1583,42 +1637,42 @@ static void rna_def_userdef_theme_space_nla(BlenderRNA *brna)
 
        rna_def_userdef_theme_spaces_main(srna, SPACE_NLA);
 
-       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "grid", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Grid", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "view_sliders", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "view_sliders", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "View Sliders", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
-       prop= RNA_def_property(srna, "bars", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "bars", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "shade2");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Bars", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "bars_selected", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "bars_selected", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "hilite");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Bars Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "strips", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "strips", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "strip");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Strips", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "strips_selected", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "strips_selected", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "strip_select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Strips Selected", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "frame_current", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "cframe");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Current Frame", "");
@@ -1634,19 +1688,19 @@ static void rna_def_userdef_theme_colorset(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "ThemeWireColor");
        RNA_def_struct_ui_text(srna, "Theme Bone Color Set", "Theme settings for bone color sets");
 
-       prop= RNA_def_property(srna, "normal", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "normal", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "solid");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Normal", "Color used for the surface of bones");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "select", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "select", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "select");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Select", "Color used for selected bones");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "active", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "active", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Active", "Color used for active bones");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
@@ -1664,6 +1718,7 @@ static void rna_def_userdef_themes(BlenderRNA *brna)
        
        static EnumPropertyItem active_theme_area[] = {
                {0, "USER_INTERFACE", ICON_UI, "User Interface", ""},
+               {18, "COLOR_SETS", ICON_COLOR, "Bone Color Sets", ""}, 
                {1, "VIEW_3D", ICON_VIEW3D, "3D View", ""},
                {2, "TIMELINE", ICON_TIME, "Timeline", ""},
                {3, "GRAPH_EDITOR", ICON_IPO, "Graph Editor", ""},
@@ -1679,7 +1734,7 @@ static void rna_def_userdef_themes(BlenderRNA *brna)
                {14, "USER_PREFERENCES", ICON_PREFERENCES, "User Preferences", ""},
                {15, "INFO", ICON_INFO, "Info", ""},
                {16, "FILE_BROWSER", ICON_FILESEL, "File Browser", ""},
-               {17, "CONSOLE", ICON_CONSOLE, "Console", ""},
+               {17, "CONSOLE", ICON_CONSOLE, "Python Console", ""},
                {0, NULL, 0, NULL, NULL}};
 
        srna= RNA_def_struct(brna, "Theme", NULL);
@@ -1904,6 +1959,10 @@ static void rna_def_userdef_view(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_TOOLTIPS);
        RNA_def_property_ui_text(prop, "Tooltips", "Display tooltips");
 
+       prop= RNA_def_property(srna, "show_tooltips_python", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", USER_TOOLTIPS_PYTHON);
+       RNA_def_property_ui_text(prop, "Show Python Tooltips", "Show Python references in tooltips");
+
        prop= RNA_def_property(srna, "show_object_info", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_DRAWVIEWINFO);
        RNA_def_property_ui_text(prop, "Display Object Info", "Display objects name and frame number in 3D view");
@@ -2019,9 +2078,9 @@ static void rna_def_userdef_view(BlenderRNA *brna)
 
        /* 3D transform widget */
        prop= RNA_def_property(srna, "show_manipulator", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "tw_flag", 1);
+       RNA_def_property_boolean_sdna(prop, NULL, "tw_flag", V3D_USE_MANIPULATOR);
        RNA_def_property_ui_text(prop, "Manipulator", "Use 3D transform manipulator");
-       RNA_def_property_update(prop, 0, "rna_userdef_update");
+       RNA_def_property_update(prop, 0, "rna_userdef_show_manipulator_update");
 
        prop= RNA_def_property(srna, "manipulator_size", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "tw_size");
@@ -2105,7 +2164,7 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_drag_immediately", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_RELEASECONFIRM);
-       RNA_def_property_ui_text(prop, "Release confirm", "Moving things with a mouse drag confirms when releasing the button");
+       RNA_def_property_ui_text(prop, "Release confirms", "Moving things with a mouse drag confirms when releasing the button");
        
        /* Undo */
        prop= RNA_def_property(srna, "undo_steps", PROP_INT, PROP_NONE);
@@ -2137,10 +2196,6 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "autokey_flag", AUTOKEY_FLAG_INSERTAVAIL);
        RNA_def_property_ui_text(prop, "Auto Keyframe Insert Available", "Automatic keyframe insertion in available curves");
        
-       prop= RNA_def_property(srna, "use_keyframe_insert_keyingset", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "autokey_flag", AUTOKEY_FLAG_ONLYKEYINGSET);
-       RNA_def_property_ui_text(prop, "Auto Keyframe Insert Keying Set", "Automatic keyframe insertion using active Keying Set");
-       
        /* keyframing settings */
        prop= RNA_def_property(srna, "use_keyframe_insert_needed", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "autokey_flag", AUTOKEY_FLAG_INSERTNEEDED);
@@ -2195,7 +2250,7 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
 
        /* sculpt and paint */
 
-       prop= RNA_def_property(srna, "sculpt_paint_overlay_color", PROP_FLOAT, PROP_COLOR);
+       prop= RNA_def_property(srna, "sculpt_paint_overlay_color", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "sculpt_paint_overlay_col");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Sculpt/Paint Overlay Color", "Color of texture overlay");
@@ -2552,6 +2607,11 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        RNA_def_property_range(prop, 50, 1000);
        RNA_def_property_ui_text(prop, "Wait Timer (ms)", "Time in milliseconds between each frame recorded for screencast");
 
+       prop= RNA_def_property(srna, "use_text_antialiasing", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "text_render", USER_TEXT_DISABLE_AA);
+       RNA_def_property_ui_text(prop, "Text Anti-aliasing", "Draw user interface text anti-aliased");
+       RNA_def_property_update(prop, 0, "rna_userdef_text_update");
+       
 #if 0
        prop= RNA_def_property(srna, "verse_master", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "versemaster");
@@ -2623,6 +2683,12 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_CONTINUOUS_MOUSE);
        RNA_def_property_ui_text(prop, "Continuous Grab", "Allow moving the mouse outside the view on some manipulations (transform, ui control drag)");
        
+       /* tweak tablet & mouse preset */
+       prop= RNA_def_property(srna, "drag_threshold", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "dragthreshold");
+       RNA_def_property_range(prop, 3, 40);
+       RNA_def_property_ui_text(prop, "Drag Threshold", "Amount of pixels you have to drag before dragging UI items happens");
+       
        prop= RNA_def_property(srna, "ndof_pan_speed", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "ndof_pan");
        RNA_def_property_range(prop, 0, 200);
@@ -2665,6 +2731,10 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "keymaps", NULL);
        RNA_def_property_struct_type(prop, "KeyMap");
        RNA_def_property_ui_text(prop, "Edited Keymaps", "");
+       
+       prop= RNA_def_property(srna, "active_keyconfig", PROP_STRING, PROP_DIRPATH);
+       RNA_def_property_string_sdna(prop, NULL, "keyconfigstr");
+       RNA_def_property_ui_text(prop, "Key Config", "The name of the active key configuration");
 }
 
 static void rna_def_userdef_filepaths(BlenderRNA *brna)
@@ -2695,10 +2765,18 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_FILTERFILEEXTS);
        RNA_def_property_ui_text(prop, "Filter File Extensions", "Display only files with extensions in the image select window");
        
+       prop= RNA_def_property(srna, "hide_recent_locations", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_HIDE_RECENT);
+       RNA_def_property_ui_text(prop, "Hide Recent Locations", "Hide recent locations in the file selector");
+
+       prop= RNA_def_property(srna, "show_thumbnails", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_SHOW_THUMBNAILS);
+       RNA_def_property_ui_text(prop, "Show Thumbnails", "Open in thumbnail view for images and movies");
+
        prop= RNA_def_property(srna, "use_relative_paths", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_RELPATHS);
        RNA_def_property_ui_text(prop, "Relative Paths", "Default relative path option for the file selector");
-
+       
        prop= RNA_def_property(srna, "use_file_compression", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_FILECOMPRESS);
        RNA_def_property_ui_text(prop, "Compress File", "Enable file compression when saving .blend files");
@@ -2725,7 +2803,7 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "render_output_directory", PROP_STRING, PROP_DIRPATH);
        RNA_def_property_string_sdna(prop, NULL, "renderdir");
-       RNA_def_property_ui_text(prop, "Render Output Directory", "The default directory for rendering output");
+       RNA_def_property_ui_text(prop, "Render Output Directory", "The default directory for rendering output, for new scenes");
 
        prop= RNA_def_property(srna, "script_directory", PROP_STRING, PROP_DIRPATH);
        RNA_def_property_string_sdna(prop, NULL, "pythondir");
@@ -2740,11 +2818,11 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Temporary Directory", "The directory for storing temporary save files");
        RNA_def_property_update(prop, 0, "rna_userdef_temp_update");
 
-       prop= RNA_def_property(srna, "image_editor", PROP_STRING, PROP_DIRPATH);
+       prop= RNA_def_property(srna, "image_editor", PROP_STRING, PROP_FILEPATH);
        RNA_def_property_string_sdna(prop, NULL, "image_editor");
        RNA_def_property_ui_text(prop, "Image Editor", "Path to an image editor");
        
-       prop= RNA_def_property(srna, "animation_player", PROP_STRING, PROP_DIRPATH);
+       prop= RNA_def_property(srna, "animation_player", PROP_STRING, PROP_FILEPATH);
        RNA_def_property_string_sdna(prop, NULL, "anim_player");
        RNA_def_property_ui_text(prop, "Animation Player", "Path to a custom animation/frame sequence player");
 
@@ -2763,7 +2841,7 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_auto_save_temporary_files", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_AUTOSAVE);
-       RNA_def_property_ui_text(prop, "Auto Save Temporary Files", "Automatic saving of temporary files");
+       RNA_def_property_ui_text(prop, "Auto Save Temporary Files", "Automatic saving of temporary files in temp directory, uses process ID");
        RNA_def_property_update(prop, 0, "rna_userdef_autosave_update");
 
        prop= RNA_def_property(srna, "auto_save_time", PROP_INT, PROP_NONE);