Merging r41246 through r41535 from trunk into soc-2011-tomato
[blender.git] / source / blender / makesrna / intern / rna_userdef.c
index 66c4e7245c4657e3eecbe5df4445789104d8d2f5..e4e1c78ab3eb5432fab570422320eaf20a24c377 100644 (file)
@@ -1,6 +1,4 @@
 /*
- * $Id$
- *
  * ***** BEGIN GPL LICENSE BLOCK *****
  *
  * This program is free software; you can redistribute it and/or
@@ -44,6 +42,7 @@
 #include "WM_types.h"
 
 #include "BLI_utildefines.h"
+#include "BLF_translation.h"
 
 #include "BKE_sound.h"
 
 #include "MEM_guardedalloc.h"
 #include "MEM_CacheLimiterC-Api.h"
 
+#include "UI_interface.h"
+
 static void rna_userdef_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
 {
        WM_main_add_notifier(NC_WINDOW, NULL);
 }
 
-static void rna_userdef_dpi_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+static void rna_userdef_dpi_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
 {
        U.widget_unit = (U.dpi * 20 + 36)/72;
        WM_main_add_notifier(NC_WINDOW, NULL);          /* full redraw */
        WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);        /* refresh region sizes */
 }
 
+static void rna_userdef_language_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
+{
+       BLF_cache_clear();
+       BLF_lang_set(NULL);
+       UI_reinit_font();
+}
+
 static void rna_userdef_show_manipulator_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        UserDef *userdef = (UserDef *)ptr->data;
@@ -285,8 +293,7 @@ static void rna_userdef_addon_remove(bAddon *bext)
 
 static void rna_userdef_temp_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
 {
-       extern char btempdir[];
-       BLI_where_is_temp(btempdir, FILE_MAX, 1);
+       BLI_init_temporary_dir(U.tempdir);
 }
 
 static void rna_userdef_text_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
@@ -803,25 +810,25 @@ static void rna_def_userdef_theme_spaces_curves(StructRNA *srna, short incl_nurb
                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_ui_text(prop, "NURBS U-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
                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_ui_text(prop, "NURBS V-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
                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_ui_text(prop, "NURBS active U-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
                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_ui_text(prop, "NURBS active V-lines", "");
                RNA_def_property_update(prop, 0, "rna_userdef_update");
 
                prop= RNA_def_property(srna, "act_spline", PROP_FLOAT, PROP_COLOR_GAMMA);
@@ -1023,8 +1030,21 @@ static void rna_def_userdef_theme_space_view3d(BlenderRNA *brna)
        RNA_def_property_range(prop, 1, 5);
        RNA_def_property_ui_text(prop, "Outline Width", "");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "bundle_solid", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "bundle_solid");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Bundle Solid", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "camera_path", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "camera_path");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Camera Path", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
 }
 
+
 static void rna_def_userdef_theme_space_graph(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -1385,7 +1405,7 @@ static void rna_def_userdef_theme_space_logic(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
        
-       /* space_buts */
+       /* space_logic */
        
        srna= RNA_def_struct(brna, "ThemeLogicEditor", NULL);
        RNA_def_struct_sdna(srna, "ThemeSpace");
@@ -1444,37 +1464,6 @@ static void rna_def_userdef_theme_space_time(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 }
 
-static void rna_def_userdef_theme_space_sound(BlenderRNA *brna)
-{
-       StructRNA *srna;
-       PropertyRNA *prop;
-
-       /* space_sound */
-
-       srna= RNA_def_struct(brna, "ThemeAudioWindow", NULL);
-       RNA_def_struct_sdna(srna, "ThemeSpace");
-       RNA_def_struct_ui_text(srna, "Theme Audio Window", "Theme settings for the Audio Window");
-
-       rna_def_userdef_theme_spaces_main(srna, SPACE_SOUND);
-
-       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_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_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");
-}
-
 static void rna_def_userdef_theme_space_image(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -1765,6 +1754,94 @@ static void rna_def_userdef_theme_colorset(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 }
 
+static void rna_def_userdef_theme_space_clip(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       /* space_clip */
+
+       srna= RNA_def_struct(brna, "ThemeClipEditor", NULL);
+       RNA_def_struct_sdna(srna, "ThemeSpace");
+       RNA_def_struct_ui_text(srna, "Theme Clip Editor", "Theme settings for the Movie Clip Editor");
+
+       rna_def_userdef_theme_spaces_main(srna, SPACE_CLIP);
+
+       prop= RNA_def_property(srna, "marker_outline", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "marker_outline");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Marker Outline Color", "Color of marker's outile");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "marker", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "marker");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Marker Color", "Color of marker");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "active_marker", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "act_marker");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Active Marker", "Color of active marker");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "selected_marker", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "sel_marker");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Selected Marker", "Color of sleected marker");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "disabled_marker", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "dis_marker");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Disabled Marker", "Color of disabled marker");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "locked_marker", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "lock_marker");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Locked Marker", "Color of locked marker");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "path_before", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "path_before");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Path Before", "Color of path before current frame");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       prop= RNA_def_property(srna, "path_after", PROP_FLOAT, PROP_COLOR_GAMMA);
+       RNA_def_property_float_sdna(prop, NULL, "path_after");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Path After", "Color of path after current frame");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+
+       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_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_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_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");
+
+       prop= RNA_def_property(srna, "handle_vertex_size", PROP_INT, PROP_NONE);
+       RNA_def_property_range(prop, 0, 255);
+       RNA_def_property_ui_text(prop, "Handle Vertex Size", "");
+       RNA_def_property_update(prop, 0, "rna_userdef_update");
+}
+
 static void rna_def_userdef_themes(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -1789,6 +1866,7 @@ static void rna_def_userdef_themes(BlenderRNA *brna)
                {15, "INFO", ICON_INFO, "Info", ""},
                {16, "FILE_BROWSER", ICON_FILESEL, "File Browser", ""},
                {17, "CONSOLE", ICON_CONSOLE, "Python Console", ""},
+           {20, "CLIP_EDITOR", ICON_CLIP, "Movie Clip Editor", ""},
                {0, NULL, 0, NULL, NULL}};
 
        srna= RNA_def_struct(brna, "Theme", NULL);
@@ -1911,6 +1989,12 @@ static void rna_def_userdef_themes(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "tarm", "");
        RNA_def_property_struct_type(prop, "ThemeBoneColorSet");
        RNA_def_property_ui_text(prop, "Bone Color Sets", "");
+
+       prop= RNA_def_property(srna, "clip_editor", PROP_POINTER, PROP_NONE);
+       RNA_def_property_flag(prop, PROP_NEVER_NULL);
+       RNA_def_property_pointer_sdna(prop, NULL, "tclip");
+       RNA_def_property_struct_type(prop, "ThemeClipEditor");
+       RNA_def_property_ui_text(prop, "Clip Editor", "");
 }
 
 static void rna_def_userdef_addon(BlenderRNA *brna)
@@ -1949,8 +2033,8 @@ static void rna_def_userdef_dothemes(BlenderRNA *brna)
        rna_def_userdef_theme_space_info(brna);
        rna_def_userdef_theme_space_userpref(brna);
        rna_def_userdef_theme_space_console(brna);
-       rna_def_userdef_theme_space_sound(brna);
        rna_def_userdef_theme_space_logic(brna);
+       rna_def_userdef_theme_space_clip(brna);
        rna_def_userdef_theme_colorset(brna);
        rna_def_userdef_themes(brna);
 }
@@ -1959,6 +2043,7 @@ static void rna_def_userdef_solidlight(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
+       static float default_dir[3] = {0.f, 1.f, 0.f};
 
        srna= RNA_def_struct(brna, "UserSolidLight", NULL);
        RNA_def_struct_sdna(srna, "SolidLight");
@@ -1972,29 +2057,36 @@ static void rna_def_userdef_solidlight(BlenderRNA *brna)
        prop= RNA_def_property(srna, "direction", PROP_FLOAT, PROP_DIRECTION);
        RNA_def_property_float_sdna(prop, NULL, "vec");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_ui_text(prop, "Direction", "The direction that the OpenGL light is shining");
+       RNA_def_property_float_array_default(prop, default_dir);
+       RNA_def_property_ui_text(prop, "Direction", "Direction that the OpenGL light is shining");
        RNA_def_property_update(prop, 0, "rna_UserDef_viewport_lights_update");
 
        prop= RNA_def_property(srna, "diffuse_color", PROP_FLOAT, PROP_COLOR);
        RNA_def_property_float_sdna(prop, NULL, "col");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_ui_text(prop, "Diffuse Color", "The diffuse color of the OpenGL light");
+       RNA_def_property_ui_text(prop, "Diffuse Color", "Diffuse color of the OpenGL light");
        RNA_def_property_update(prop, 0, "rna_UserDef_viewport_lights_update");
 
        prop= RNA_def_property(srna, "specular_color", PROP_FLOAT, PROP_COLOR);
        RNA_def_property_float_sdna(prop, NULL, "spec");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_ui_text(prop, "Specular Color", "The color of the lights specular highlight");
+       RNA_def_property_ui_text(prop, "Specular Color", "Color of the light's specular highlight");
        RNA_def_property_update(prop, 0, "rna_UserDef_viewport_lights_update");
 }
 
 static void rna_def_userdef_view(BlenderRNA *brna)
 {
        static EnumPropertyItem timecode_styles[] = {
-               {USER_TIMECODE_MINIMAL, "MINIMAL", 0, "Minimal Info", "Most compact representation. Uses '+' as separator for sub-second frame numbers, with left and right truncation of the timecode as necessary"},
-               {USER_TIMECODE_SMPTE_FULL, "SMPTE", 0, "SMPTE (Full)", "Full SMPTE timecode. Format is HH:MM:SS:FF"},
-               {USER_TIMECODE_SMPTE_MSF, "SMPTE_COMPACT", 0, "SMPTE (Compact)", "SMPTE timecode showing minutes, seconds, and frames only. Hours are also shown if necessary, but not by default"},
-               {USER_TIMECODE_MILLISECONDS, "MILLISECONDS", 0, "Compact with Milliseconds", "Similar to SMPTE (Compact), except that instead of frames, milliseconds are shown instead"},
+               {USER_TIMECODE_MINIMAL, "MINIMAL", 0, "Minimal Info",
+                                       "Most compact representation, uses '+' as separator for sub-second frame numbers, "
+                                       "with left and right truncation of the timecode as necessary"},
+               {USER_TIMECODE_SMPTE_FULL, "SMPTE", 0, "SMPTE (Full)", "Full SMPTE timecode (format is HH:MM:SS:FF)"},
+               {USER_TIMECODE_SMPTE_MSF, "SMPTE_COMPACT", 0, "SMPTE (Compact)",
+                                         "SMPTE timecode showing minutes, seconds, and frames only - "
+                                         "hours are also shown if necessary, but not by default"},
+               {USER_TIMECODE_MILLISECONDS, "MILLISECONDS", 0, "Compact with Milliseconds",
+                                            "Similar to SMPTE (Compact), except that instead of frames, "
+                                            "milliseconds are shown instead"},
                {USER_TIMECODE_SECONDS_ONLY, "SECONDS_ONLY", 0, "Only Seconds", "Direct conversion of frame numbers to seconds"},
                {0, NULL, 0, NULL, NULL}};
        
@@ -2024,7 +2116,7 @@ static void rna_def_userdef_view(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_global_scene", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_SCENEGLOBAL);
-       RNA_def_property_ui_text(prop, "Global Scene", "Forces the current Scene to be displayed in all Screens");
+       RNA_def_property_ui_text(prop, "Global Scene", "Force the current Scene to be displayed in all Screens");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        prop= RNA_def_property(srna, "show_large_cursors", PROP_BOOLEAN, PROP_NONE);
@@ -2043,34 +2135,40 @@ static void rna_def_userdef_view(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "show_playback_fps", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_SHOW_FPS);
-       RNA_def_property_ui_text(prop, "Show Playback FPS", "Show the frames per second screen refresh rate, while animation is played back");
+       RNA_def_property_ui_text(prop, "Show Playback FPS",
+                                "Show the frames per second screen refresh rate, while animation is played back");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
        /* menus */
        prop= RNA_def_property(srna, "use_mouse_over_open", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_MENUOPENAUTO);
-       RNA_def_property_ui_text(prop, "Open On Mouse Over", "Open menu buttons and pulldowns automatically when the mouse is hovering");
+       RNA_def_property_ui_text(prop, "Open On Mouse Over",
+                                "Open menu buttons and pulldowns automatically when the mouse is hovering");
        
        prop= RNA_def_property(srna, "open_toplevel_delay", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "menuthreshold1");
        RNA_def_property_range(prop, 1, 40);
-       RNA_def_property_ui_text(prop, "Top Level Menu Open Delay", "Time delay in 1/10 seconds before automatically opening top level menus");
+       RNA_def_property_ui_text(prop, "Top Level Menu Open Delay",
+                                "Time delay in 1/10 seconds before automatically opening top level menus");
 
        prop= RNA_def_property(srna, "open_sublevel_delay", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "menuthreshold2");
        RNA_def_property_range(prop, 1, 40);
-       RNA_def_property_ui_text(prop, "Sub Level Menu Open Delay", "Time delay in 1/10 seconds before automatically opening sub level menus");
+       RNA_def_property_ui_text(prop, "Sub Level Menu Open Delay",
+                                "Time delay in 1/10 seconds before automatically opening sub level menus");
 
        /* Toolbox click-hold delay */
        prop= RNA_def_property(srna, "open_left_mouse_delay", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "tb_leftmouse");
        RNA_def_property_range(prop, 1, 40);
-       RNA_def_property_ui_text(prop, "Hold LMB Open Toolbox Delay", "Time in 1/10 seconds to hold the Left Mouse Button before opening the toolbox");
+       RNA_def_property_ui_text(prop, "Hold LMB Open Toolbox Delay",
+                                "Time in 1/10 seconds to hold the Left Mouse Button before opening the toolbox");
 
        prop= RNA_def_property(srna, "open_right_mouse_delay", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "tb_rightmouse");
        RNA_def_property_range(prop, 1, 40);
-       RNA_def_property_ui_text(prop, "Hold RMB Open Toolbox Delay", "Time in 1/10 seconds to hold the Right Mouse Button before opening the toolbox");
+       RNA_def_property_ui_text(prop, "Hold RMB Open Toolbox Delay",
+                                "Time in 1/10 seconds to hold the Right Mouse Button before opening the toolbox");
 
        prop= RNA_def_property(srna, "show_column_layout", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_PLAINMENUS);
@@ -2078,7 +2176,8 @@ static void rna_def_userdef_view(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_directional_menus", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "uiflag", USER_MENUFIXEDORDER);
-       RNA_def_property_ui_text(prop, "Contents Follow Opening Direction", "Otherwise menus, etc will always be top to bottom, left to right, no matter opening direction");
+       RNA_def_property_ui_text(prop, "Contents Follow Opening Direction",
+                                "Otherwise menus, etc will always be top to bottom, left to right, no matter opening direction");
 
        prop= RNA_def_property(srna, "use_global_pivot", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_LOCKAROUND);
@@ -2090,17 +2189,22 @@ static void rna_def_userdef_view(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_camera_lock_parent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "uiflag", USER_CAM_LOCK_NO_PARENT);
-       RNA_def_property_ui_text(prop, "Camera Parent Lock", "When the camera is locked to the view and in fly mode, transform the parent rather than the camera");
+       RNA_def_property_ui_text(prop, "Camera Parent Lock",
+                                "When the camera is locked to the view and in fly mode, "
+                                "transform the parent rather than the camera");
 
        /* view zoom */
        prop= RNA_def_property(srna, "use_zoom_to_mouse", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_ZOOM_TO_MOUSEPOS);
-       RNA_def_property_ui_text(prop, "Zoom To Mouse Position", "Zoom in towards the mouse pointer's position in the 3D view, rather than the 2D window center");
+       RNA_def_property_ui_text(prop, "Zoom To Mouse Position",
+                                "Zoom in towards the mouse pointer's position in the 3D view, rather than the 2D window center");
 
        /* view rotation */
        prop= RNA_def_property(srna, "use_auto_perspective", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_AUTOPERSP);
-       RNA_def_property_ui_text(prop, "Auto Perspective", "Automatically switch between orthographic and perspective when changing from top/front/side views");
+       RNA_def_property_ui_text(prop, "Auto Perspective",
+                                "Automatically switch between orthographic and perspective when changing "
+                                "from top/front/side views");
 
        prop= RNA_def_property(srna, "use_rotate_around_active", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_ORBIT_SELECTION);
@@ -2109,30 +2213,30 @@ static void rna_def_userdef_view(BlenderRNA *brna)
        /* mini axis */
        prop= RNA_def_property(srna, "show_mini_axis", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_SHOW_ROTVIEWICON);
-       RNA_def_property_ui_text(prop, "Show Mini Axis", "Show a small rotating 3D axis in the bottom left corner of the 3D View");
+       RNA_def_property_ui_text(prop, "Show Mini Axes", "Show a small rotating 3D axes in the bottom left corner of the 3D View");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        prop= RNA_def_property(srna, "mini_axis_size", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "rvisize");
        RNA_def_property_range(prop, 10, 64);
-       RNA_def_property_ui_text(prop, "Mini Axis Size", "The axis icon's size");
+       RNA_def_property_ui_text(prop, "Mini Axes Size", "The axes icon's size");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        prop= RNA_def_property(srna, "mini_axis_brightness", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "rvibright");
        RNA_def_property_range(prop, 0, 10);
-       RNA_def_property_ui_text(prop, "Mini Axis Brightness", "The brightness of the icon");
+       RNA_def_property_ui_text(prop, "Mini Axes Brightness", "Brightness of the icon");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        prop= RNA_def_property(srna, "smooth_view", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "smooth_viewtx");
        RNA_def_property_range(prop, 0, 1000);
-       RNA_def_property_ui_text(prop, "Smooth View", "The time to animate the view in milliseconds, zero to disable");
+       RNA_def_property_ui_text(prop, "Smooth View", "Time to animate the view in milliseconds, zero to disable");
 
        prop= RNA_def_property(srna, "rotation_angle", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "pad_rot_angle");
        RNA_def_property_range(prop, 0, 90);
-       RNA_def_property_ui_text(prop, "Rotation Angle", "The rotation step for numerical pad keys (2 4 6 8)");
+       RNA_def_property_ui_text(prop, "Rotation Angle", "Rotation step for numerical pad keys (2 4 6 8)");
 
        /* 3D transform widget */
        prop= RNA_def_property(srna, "show_manipulator", PROP_BOOLEAN, PROP_NONE);
@@ -2170,7 +2274,8 @@ static void rna_def_userdef_view(BlenderRNA *brna)
        prop= RNA_def_property(srna, "view2d_grid_spacing_min", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "v2d_min_gridsize");
        RNA_def_property_range(prop, 1, 500); // XXX: perhaps the lower range should only go down to 5?
-       RNA_def_property_ui_text(prop, "2D View Minimum Grid Spacing", "Minimum number of pixels between each gridline in 2D Viewports");
+       RNA_def_property_ui_text(prop, "2D View Minimum Grid Spacing",
+                                "Minimum number of pixels between each gridline in 2D Viewports");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
        
                // TODO: add a setter for this, so that we can bump up the minimum size as necessary...
@@ -2178,7 +2283,8 @@ static void rna_def_userdef_view(BlenderRNA *brna)
        RNA_def_property_enum_items(prop, timecode_styles);
        RNA_def_property_enum_sdna(prop, NULL, "timecode_style");
        RNA_def_property_enum_funcs(prop, NULL, "rna_userdef_timecode_style_set", NULL);
-       RNA_def_property_ui_text(prop, "TimeCode Style", "Format of Time Codes displayed when not displaying timing in terms of frames");
+       RNA_def_property_ui_text(prop, "TimeCode Style",
+                                "Format of Time Codes displayed when not displaying timing in terms of frames");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 }
 
@@ -2198,7 +2304,7 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
                {0, NULL, 0, NULL, NULL}};
                
        static const EnumPropertyItem object_align_items[]= {
-               {0, "WORLD", 0, "World", "Align newly added objects to the world coordinates"},
+               {0, "WORLD", 0, "World", "Align newly added objects to the world coordinate system"},
                {USER_ADD_VIEWALIGNED, "VIEW", 0, "View", "Align newly added objects facing the active 3D View direction"},
                {0, NULL, 0, NULL, NULL}};
 
@@ -2212,12 +2318,14 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
        prop= RNA_def_property(srna, "material_link", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
        RNA_def_property_enum_items(prop, material_link_items);
-       RNA_def_property_ui_text(prop, "Material Link To", "Toggle whether the material is linked to object data or the object block");
+       RNA_def_property_ui_text(prop, "Material Link To",
+                                "Toggle whether the material is linked to object data or the object block");
        
        prop= RNA_def_property(srna, "object_align", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
        RNA_def_property_enum_items(prop, object_align_items);
-       RNA_def_property_ui_text(prop, "Align Object To", "When adding objects from a 3D View menu, either align them to that view's direction or the world coordinates");
+       RNA_def_property_ui_text(prop, "Align Object To",
+                                "When adding objects from a 3D View menu, either align them with that view or with the world");
 
        prop= RNA_def_property(srna, "use_enter_edit_mode", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_ADD_EDITMODE);
@@ -2240,22 +2348,26 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_global_undo", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_GLOBALUNDO);
-       RNA_def_property_ui_text(prop, "Global Undo", "Global undo works by keeping a full copy of the file itself in memory, so takes extra memory");
+       RNA_def_property_ui_text(prop, "Global Undo",
+                                "Global undo works by keeping a full copy of the file itself in memory, so takes extra memory");
 
        /* auto keyframing */   
        prop= RNA_def_property(srna, "use_auto_keying", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "autokey_mode", AUTOKEY_ON);
-       RNA_def_property_ui_text(prop, "Auto Keying Enable", "Automatic keyframe insertion for Objects and Bones (default setting used for new Scenes)");
+       RNA_def_property_ui_text(prop, "Auto Keying Enable",
+                                "Automatic keyframe insertion for Objects and Bones (default setting used for new Scenes)");
        RNA_def_property_ui_icon(prop, ICON_REC, 0);
 
        prop= RNA_def_property(srna, "auto_keying_mode", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, auto_key_modes);
        RNA_def_property_enum_funcs(prop, "rna_userdef_autokeymode_get", "rna_userdef_autokeymode_set", NULL);
-       RNA_def_property_ui_text(prop, "Auto Keying Mode", "Mode of automatic keyframe insertion for Objects and Bones (default setting used for new Scenes)");
+       RNA_def_property_ui_text(prop, "Auto Keying Mode",
+                                "Mode of automatic keyframe insertion for Objects and Bones "
+                                "(default setting used for new Scenes)");
 
        prop= RNA_def_property(srna, "use_keyframe_insert_available", PROP_BOOLEAN, PROP_NONE);
        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");
+       RNA_def_property_ui_text(prop, "Auto Keyframe Insert Available", "Automatic keyframe insertion in available F-Curves");
        
        /* keyframing settings */
        prop= RNA_def_property(srna, "use_keyframe_insert_needed", PROP_BOOLEAN, PROP_NONE);
@@ -2268,12 +2380,16 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "use_insertkey_xyz_to_rgb", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "autokey_flag", AUTOKEY_FLAG_XYZ2RGB);
-       RNA_def_property_ui_text(prop, "New F-Curve Colors - XYZ to RGB", "Color for newly added transformation F-Curves (Location, Rotation, Scale) and also Color is based on the transform axis");
+       RNA_def_property_ui_text(prop, "New F-Curve Colors - XYZ to RGB",
+                                "Color for newly added transformation F-Curves (Location, Rotation, Scale) "
+                                "and also Color is based on the transform axis");
        
        prop= RNA_def_property(srna, "keyframe_new_interpolation_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, beztriple_interpolation_mode_items);
        RNA_def_property_enum_sdna(prop, NULL, "ipo_new");
-       RNA_def_property_ui_text(prop, "New Interpolation Type", "Interpolation mode used for first keyframe on newly added F-Curves. Subsequent keyframes take interpolation from preceeding keyframe");
+       RNA_def_property_ui_text(prop, "New Interpolation Type",
+                                "Interpolation mode used for first keyframe on newly added F-Curves "
+                                "(subsequent keyframes take interpolation from preceeding keyframe)");
        
        prop= RNA_def_property(srna, "keyframe_new_handle_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, keyframe_handle_type_items);
@@ -2294,7 +2410,8 @@ static void rna_def_userdef_edit(BlenderRNA *brna)
        prop= RNA_def_property(srna, "grease_pencil_euclidean_distance", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "gp_euclideandist");
        RNA_def_property_range(prop, 0, 100);
-       RNA_def_property_ui_text(prop, "Grease Pencil Euclidean Distance", "Distance moved by mouse when drawing stroke (in pixels) to include");
+       RNA_def_property_ui_text(prop, "Grease Pencil Euclidean Distance",
+                                "Distance moved by mouse when drawing stroke (in pixels) to include");
 
        prop= RNA_def_property(srna, "use_grease_pencil_smooth_stroke", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gp_settings", GP_PAINT_DOSMOOTH);
@@ -2447,10 +2564,14 @@ static void rna_def_userdef_system(BlenderRNA *brna)
 
        static EnumPropertyItem draw_method_items[] = {
                {USER_DRAW_AUTOMATIC, "AUTOMATIC", 0, "Automatic", "Automatically set based on graphics card and driver"},
-               {USER_DRAW_TRIPLE, "TRIPLE_BUFFER", 0, "Triple Buffer", "Use a third buffer for minimal redraws at the cost of more memory"},
+               {USER_DRAW_TRIPLE, "TRIPLE_BUFFER", 0, "Triple Buffer",
+                                  "Use a third buffer for minimal redraws at the cost of more memory"},
                {USER_DRAW_OVERLAP, "OVERLAP", 0, "Overlap", "Redraw all overlapping regions, minimal memory usage but more redraws"},
-               {USER_DRAW_OVERLAP_FLIP, "OVERLAP_FLIP", 0, "Overlap Flip", "Redraw all overlapping regions, minimal memory usage but more redraws (for graphics drivers that do flipping)"},
-               {USER_DRAW_FULL, "FULL", 0, "Full", "Do a full redraw each time, slow, only use for reference or when all else fails"},
+               {USER_DRAW_OVERLAP_FLIP, "OVERLAP_FLIP", 0, "Overlap Flip",
+                                        "Redraw all overlapping regions, minimal memory usage but more redraws "
+                                        "(for graphics drivers that do flipping)"},
+               {USER_DRAW_FULL, "FULL", 0, "Full",
+                                "Do a full redraw each time, slow, only use for reference or when everything else fails"},
                {0, NULL, 0, NULL, NULL}};
        
        static EnumPropertyItem color_picker_types[] = {
@@ -2461,30 +2582,41 @@ static void rna_def_userdef_system(BlenderRNA *brna)
                {0, NULL, 0, NULL, NULL}};
        
                /* hardcoded here, could become dynamic somehow */
+       /* locale according to http://www.roseindia.net/tutorials/I18N/locales-list.shtml */
+       /* if you edit here, please also edit the source/blender/blenfont/intern/blf_lang.c 's locales */
        static EnumPropertyItem language_items[] = {
-               {0, "ENGLISH", 0, "English", ""},
-               {1, "JAPANESE", 0, "Japanese", ""},
-               {2, "DUTCH", 0, "Dutch", ""},
-               {3, "ITALIAN", 0, "Italian", ""},
-               {4, "GERMAN", 0, "German", ""},
-               {5, "FINNISH", 0, "Finnish", ""},
-               {6, "SWEDISH", 0, "Swedish", ""},
-               {7, "FRENCH", 0, "French", ""},
-               {8, "SPANISH", 0, "Spanish", ""},
-               {9, "CATALAN", 0, "Catalan", ""},
-               {10, "CZECH", 0, "Czech", ""},
-               {11, "BRAZILIAN_PORTUGUESE", 0, "Brazilian Portuguese", ""},
-               {12, "SIMPLIFIED_CHINESE", 0, "Simplified Chinese", ""},
-               {13, "RUSSIAN", 0, "Russian", ""},
-               {14, "CROATIAN", 0, "Croatian", ""},
-               {15, "SERBIAN", 0, "Serbian", ""},
-               {16, "UKRAINIAN", 0, "Ukrainian", ""},
-               {17, "POLISH", 0, "Polish", ""},
-               {18, "ROMANIAN", 0, "Romanian", ""},
-               {19, "ARABIC", 0, "Arabic", ""},
-               {20, "BULGARIAN", 0, "Bulgarian", ""},
-               {21, "GREEK", 0, "Greek", ""},
-               {22, "KOREAN", 0, "Korean", ""},
+               {0, "", 0, "Nearly done", ""},
+               {0, "DEFAULT", 0, "Default (Default)", ""},
+               {1, "ENGLISH", 0, "English (English)", "en_US"},
+               {8, "FRENCH", 0, "French (Français)", "fr_FR"},
+               {9, "SPANISH", 0, "Spanish (Español)", "es_ES"},
+               {13, "SIMPLIFIED_CHINESE", 0, "Simplified Chinese (简体中文)", "zh_CN"},
+               {0, "", 0, "In progress", ""},
+               {2, "JAPANESE", 0, "Japanese (日本語)", "ja_JP"},
+               {3, "DUTCH", 0, "Dutch (Nederlandse taal)", "nl_NL"},
+               {4, "ITALIAN", 0, "Italian (Italiano)", "it_IT"},
+               {5, "GERMAN", 0, "German (Deutsch)", "de_DE"},
+               {6, "FINNISH", 0, "Finnish (Suomi)", "fi_FI"},
+               {7, "SWEDISH", 0, "Swedish (Svenska)", "sv_SE"},
+               {10, "CATALAN", 0, "Catalan (Català)", "ca_AD"},
+               {11, "CZECH", 0, "Czech (Český)", "cs_CZ"},
+               {12, "BRAZILIAN_PORTUGUESE", 0, "Brazilian Portuguese (Português do Brasil)", "pt_BR"},
+               {14, "TRADITIONAL_CHINESE", 0, "Traditional Chinese (繁體中文)", "zh_TW"},
+               {15, "RUSSIAN", 0, "Russian (Русский)", "ru_RU"},
+               {16, "CROATIAN", 0, "Croatian (Hrvatski)", "hr_HR"},
+               {17, "SERBIAN", 0, "Serbian (Српском језику)", "sr_RS"},
+               {18, "UKRAINIAN", 0, "Ukrainian (Український)", "uk_UA"},
+               {19, "POLISH", 0, "Polish (Polski)", "pl_PL"},
+               {20, "ROMANIAN", 0, "Romanian (Român)", "ro_RO"},
+               /* using the utf8 flipped form of Arabic (العربية) */
+               {21, "ARABIC", 0, "Arabic (ﺔﻴﺑﺮﻌﻟﺍ)", "ar_EG"},
+               {22, "BULGARIAN", 0, "Bulgarian (Български)", "bg_BG"},
+               {23, "GREEK", 0, "Greek (Ελληνικά)", "el_GR"},
+               {24, "KOREAN", 0, "Korean (한국 언어)", "ko_KR"},
+               /*{25, "NEPALI", 0, "Nepali (नेपाली)", "ne_NP"},*/
+               /* using the utf8 flipped form of Persian (فارسی) */
+               {26, "PERSIAN", 0, "Persian (ﯽﺳﺭﺎﻓ)", "fa_PE"},
+               {27, "INDONESIAN", 0, "Indonesian (Bahasa indonesia)", "id_ID"},
                {0, NULL, 0, NULL, NULL}};
 
        srna= RNA_def_struct(brna, "UserPreferencesSystem", NULL);
@@ -2497,7 +2629,7 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        prop= RNA_def_property(srna, "use_international_fonts", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "transopts", USER_DOTRANSLATE);
        RNA_def_property_ui_text(prop, "International Fonts", "Use international fonts");
-       RNA_def_property_update(prop, 0, "rna_userdef_update");
+       RNA_def_property_update(prop, NC_WINDOW, "rna_userdef_language_update");
 
        prop= RNA_def_property(srna, "dpi", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "dpi");
@@ -2519,22 +2651,17 @@ static void rna_def_userdef_system(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "language", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, language_items);
-       RNA_def_property_ui_text(prop, "Language", "Language use for translation");
-       RNA_def_property_update(prop, 0, "rna_userdef_update");
+       RNA_def_property_ui_text(prop, "Language", "Language used for translation");
+       RNA_def_property_update(prop, NC_WINDOW, "rna_userdef_language_update");
 
        prop= RNA_def_property(srna, "use_translate_tooltips", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "transopts", USER_TR_TOOLTIPS);
        RNA_def_property_ui_text(prop, "Translate Tooltips", "Translate Tooltips");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
-       prop= RNA_def_property(srna, "use_translate_buttons", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "transopts", USER_TR_BUTTONS);
-       RNA_def_property_ui_text(prop, "Translate Buttons", "Translate button labels");
-       RNA_def_property_update(prop, 0, "rna_userdef_update");
-
-       prop= RNA_def_property(srna, "use_translate_toolbox", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "transopts", USER_TR_MENUS);
-       RNA_def_property_ui_text(prop, "Translate Toolbox", "Translate toolbox menu");
+       prop= RNA_def_property(srna, "use_translate_interface", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "transopts", USER_TR_IFACE);
+       RNA_def_property_ui_text(prop, "Translate Interface", "Translate Interface");
        RNA_def_property_update(prop, 0, "rna_userdef_update");
 
        prop= RNA_def_property(srna, "use_textured_fonts", PROP_BOOLEAN, PROP_NONE);
@@ -2551,7 +2678,8 @@ static void rna_def_userdef_system(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "use_weight_color_range", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_CUSTOM_RANGE);
-       RNA_def_property_ui_text(prop, "Use Weight Color Range", "Enable color range used for weight visualization in weight painting mode");
+       RNA_def_property_ui_text(prop, "Use Weight Color Range",
+                                "Enable color range used for weight visualization in weight painting mode");
        RNA_def_property_update(prop, 0, "rna_UserDef_weight_color_update");
 
        prop= RNA_def_property(srna, "weight_color_range", PROP_POINTER, PROP_NONE);
@@ -2568,16 +2696,20 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "use_preview_images", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_ALLWINCODECS);
-       RNA_def_property_ui_text(prop, "Enable All Codecs", "Enables automatic saving of preview images in the .blend file (Windows only)");
+       RNA_def_property_ui_text(prop, "Enable All Codecs",
+                                "Allow user to choose any codec (Windows only, might generate instability)");
 
        prop= RNA_def_property(srna, "use_scripts_auto_execute", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", USER_SCRIPT_AUTOEXEC_DISABLE);
-       RNA_def_property_ui_text(prop, "Auto Run Python Scripts", "Allow any .blend file to run scripts automatically (unsafe with blend files from an untrusted source)");
+       RNA_def_property_ui_text(prop, "Auto Run Python Scripts",
+                                "Allow any .blend file to run scripts automatically "
+                                "(unsafe with blend files from an untrusted source)");
        RNA_def_property_update(prop, 0, "rna_userdef_script_autoexec_update");
 
        prop= RNA_def_property(srna, "use_tabs_as_spaces", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", USER_TXT_TABSTOSPACES_DISABLE);
-       RNA_def_property_ui_text(prop, "Tabs as Spaces", "Automatically converts all new tabs into spaces for new and loaded text files");
+       RNA_def_property_ui_text(prop, "Tabs as Spaces",
+                                "Automatically convert all new tabs into spaces for new and loaded text files");
 
        prop= RNA_def_property(srna, "prefetch_frames", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "prefetchframes");
@@ -2603,12 +2735,14 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "use_mipmaps", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "gameflags", USER_DISABLE_MIPMAP);
-       RNA_def_property_ui_text(prop, "Mipmaps", "Scale textures for the 3D View (looks nicer but uses more memory and slows image reloading)");
+       RNA_def_property_ui_text(prop, "Mipmaps",
+                                "Scale textures for the 3D View (looks nicer but uses more memory and slows image reloading)");
        RNA_def_property_update(prop, 0, "rna_userdef_mipmap_update");
 
        prop= RNA_def_property(srna, "use_vertex_buffer_objects", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "gameflags", USER_DISABLE_VBO);
        RNA_def_property_ui_text(prop, "VBOs", "Use Vertex Buffer Objects (or Vertex Arrays, if unsupported) for viewport rendering");
+       RNA_def_property_update(prop, NC_WINDOW, NULL); /* this isnt essential but nice to check if VBO draws any differently */
 
        prop= RNA_def_property(srna, "use_antialiasing", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "gameflags", USER_DISABLE_AA);
@@ -2618,7 +2752,8 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        RNA_def_property_enum_sdna(prop, NULL, "anisotropic_filter");
        RNA_def_property_enum_items(prop, anisotropic_items);
        RNA_def_property_enum_default(prop, 1);
-       RNA_def_property_ui_text(prop, "Anisotropic Filter", "The quality of the anisotropic filtering (values greater than 1.0 enable anisotropic filtering)");
+       RNA_def_property_ui_text(prop, "Anisotropic Filter",
+                                "Quality of the anisotropic filtering (values greater than 1.0 enable anisotropic filtering)");
        RNA_def_property_update(prop, 0, "rna_userdef_anisotropic_update");
        
        prop= RNA_def_property(srna, "gl_texture_limit", PROP_ENUM, PROP_NONE);
@@ -2630,12 +2765,15 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        prop= RNA_def_property(srna, "texture_time_out", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "textimeout");
        RNA_def_property_range(prop, 0, 3600);
-       RNA_def_property_ui_text(prop, "Texture Time Out", "Time since last access of a GL texture in seconds after which it is freed. (Set to 0 to keep textures allocated.)");
+       RNA_def_property_ui_text(prop, "Texture Time Out",
+                                "Time since last access of a GL texture in seconds after which it is freed "
+                                "(set to 0 to keep textures allocated)");
 
        prop= RNA_def_property(srna, "texture_collection_rate", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "texcollectrate");
        RNA_def_property_range(prop, 1, 3600);
-       RNA_def_property_ui_text(prop, "Texture Collection Rate", "Number of seconds between each run of the GL texture garbage collector");
+       RNA_def_property_ui_text(prop, "Texture Collection Rate",
+                                "Number of seconds between each run of the GL texture garbage collector");
 
        prop= RNA_def_property(srna, "window_draw_method", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "wmdrawmethod");
@@ -2646,31 +2784,31 @@ static void rna_def_userdef_system(BlenderRNA *brna)
        prop= RNA_def_property(srna, "audio_mixing_buffer", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "mixbufsize");
        RNA_def_property_enum_items(prop, audio_mixing_samples_items);
-       RNA_def_property_ui_text(prop, "Audio Mixing Buffer", "Sets the number of samples used by the audio mixing buffer");
+       RNA_def_property_ui_text(prop, "Audio Mixing Buffer", "Number of samples used by the audio mixing buffer");
        RNA_def_property_update(prop, 0, "rna_UserDef_audio_update");
 
        prop= RNA_def_property(srna, "audio_device", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "audiodevice");
        RNA_def_property_enum_items(prop, audio_device_items);
-       RNA_def_property_ui_text(prop, "Audio Device", "Sets the audio output device");
+       RNA_def_property_ui_text(prop, "Audio Device", "Audio output device");
        RNA_def_property_update(prop, 0, "rna_UserDef_audio_update");
 
        prop= RNA_def_property(srna, "audio_sample_rate", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "audiorate");
        RNA_def_property_enum_items(prop, audio_rate_items);
-       RNA_def_property_ui_text(prop, "Audio Sample Rate", "Sets the audio sample rate");
+       RNA_def_property_ui_text(prop, "Audio Sample Rate", "Audio sample rate");
        RNA_def_property_update(prop, 0, "rna_UserDef_audio_update");
 
        prop= RNA_def_property(srna, "audio_sample_format", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "audioformat");
        RNA_def_property_enum_items(prop, audio_format_items);
-       RNA_def_property_ui_text(prop, "Audio Sample Format", "Sets the audio sample format");
+       RNA_def_property_ui_text(prop, "Audio Sample Format", "Audio sample format");
        RNA_def_property_update(prop, 0, "rna_UserDef_audio_update");
 
        prop= RNA_def_property(srna, "audio_channels", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "audiochannels");
        RNA_def_property_enum_items(prop, audio_channel_items);
-       RNA_def_property_ui_text(prop, "Audio Channels", "Sets the audio channel count");
+       RNA_def_property_ui_text(prop, "Audio Channels", "Audio channel count");
        RNA_def_property_update(prop, 0, "rna_UserDef_audio_update");
 
        prop= RNA_def_property(srna, "screencast_fps", PROP_INT, PROP_NONE);
@@ -2691,11 +2829,11 @@ static void rna_def_userdef_system(BlenderRNA *brna)
 #if 0
        prop= RNA_def_property(srna, "verse_master", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "versemaster");
-       RNA_def_property_ui_text(prop, "Verse Master", "The Verse Master-server IP");
+       RNA_def_property_ui_text(prop, "Verse Master", "Verse Master-server IP");
 
        prop= RNA_def_property(srna, "verse_username", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "verseuser");
-       RNA_def_property_ui_text(prop, "Verse Username", "The Verse user name");
+       RNA_def_property_ui_text(prop, "Verse Username", "Verse user name");
 #endif
 }
 
@@ -2716,13 +2854,13 @@ static void rna_def_userdef_input(BlenderRNA *brna)
                
        static EnumPropertyItem view_zoom_styles[] = {
                {USER_ZOOM_CONT, "CONTINUE", 0, "Continue", "Old style zoom, continues while moving mouse up or down"},
-               {USER_ZOOM_DOLLY, "DOLLY", 0, "Dolly", "Zooms in and out based on vertical mouse movement"},
-               {USER_ZOOM_SCALE, "SCALE", 0, "Scale", "Zooms in and out like scaling the view, mouse movements relative to center"},
+               {USER_ZOOM_DOLLY, "DOLLY", 0, "Dolly", "Zoom in and out based on vertical mouse movement"},
+               {USER_ZOOM_SCALE, "SCALE", 0, "Scale", "Zoom in and out like scaling the view, mouse movements relative to center"},
                {0, NULL, 0, NULL, NULL}};
        
        static EnumPropertyItem view_zoom_axes[] = {
-               {0, "VERTICAL", 0, "Vertical", "Zooms in and out based on vertical mouse movement"},
-               {USER_ZOOM_HORIZ, "HORIZONTAL", 0, "Horizontal", "Zooms in and out based on horizontal mouse movement"},
+               {0, "VERTICAL", 0, "Vertical", "Zoom in and out based on vertical mouse movement"},
+               {USER_ZOOM_HORIZ, "HORIZONTAL", 0, "Horizontal", "Zoom in and out based on horizontal mouse movement"},
                {0, NULL, 0, NULL, NULL}};
                
        srna= RNA_def_struct(brna, "UserPreferencesInput", NULL);
@@ -2734,7 +2872,7 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
        RNA_def_property_enum_items(prop, select_mouse_items);
        RNA_def_property_enum_funcs(prop, NULL, "rna_userdef_select_mouse_set", NULL);
-       RNA_def_property_ui_text(prop, "Select Mouse", "The mouse button used for selection");
+       RNA_def_property_ui_text(prop, "Select Mouse", "Mouse button used for selection");
        
        prop= RNA_def_property(srna, "view_zoom_method", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "viewzoom");
@@ -2757,7 +2895,8 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "use_mouse_continuous", PROP_BOOLEAN, PROP_NONE);
        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)");
+       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);
@@ -2765,7 +2904,7 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        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");
 
-       /* 3D mouse settings */
+       /* 3D mouse settings */
        /* global options */
        prop= RNA_def_property(srna, "ndof_sensitivity", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, 0.25f, 4.0f);
@@ -2834,15 +2973,16 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        prop= RNA_def_property(srna, "mouse_double_click_time", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "dbl_click_time");
        RNA_def_property_range(prop, 1, 1000);
-       RNA_def_property_ui_text(prop, "Double Click Timeout", "The time (in ms) for a double click");
+       RNA_def_property_ui_text(prop, "Double Click Timeout", "Time/delay (in ms) for a double click");
 
        prop= RNA_def_property(srna, "use_mouse_emulate_3_button", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_TWOBUTTONMOUSE);
-       RNA_def_property_ui_text(prop, "Emulate 3 Button Mouse", "Emulates Middle Mouse with Alt+Left Mouse (doesn't work with Left Mouse Select option)");
+       RNA_def_property_ui_text(prop, "Emulate 3 Button Mouse",
+                                "Emulate Middle Mouse with Alt+Left Mouse (doesn't work with Left Mouse Select option)");
 
        prop= RNA_def_property(srna, "use_emulate_numpad", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", USER_NONUMPAD);
-       RNA_def_property_ui_text(prop, "Emulate Numpad", "Causes the 1 to 0 keys to act as the numpad (useful for laptops)");
+       RNA_def_property_ui_text(prop, "Emulate Numpad", "Main 1 to 0 keys act as the numpad ones (useful for laptops)");
        
        /* middle mouse button */
        prop= RNA_def_property(srna, "use_mouse_mmb_paste", PROP_BOOLEAN, PROP_NONE);
@@ -2856,7 +2996,7 @@ static void rna_def_userdef_input(BlenderRNA *brna)
        prop= RNA_def_property(srna, "wheel_scroll_lines", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "wheellinescroll");
        RNA_def_property_range(prop, 0, 32);
-       RNA_def_property_ui_text(prop, "Wheel Scroll Lines", "The number of lines scrolled at a time with the mouse wheel");
+       RNA_def_property_ui_text(prop, "Wheel Scroll Lines", "Number of lines scrolled at a time with the mouse wheel");
        
        prop= RNA_def_property(srna, "active_keyconfig", PROP_STRING, PROP_DIRPATH);
        RNA_def_property_string_sdna(prop, NULL, "keyconfigstr");
@@ -2885,7 +3025,7 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "show_hidden_files_datablocks", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_HIDE_DOT);
-       RNA_def_property_ui_text(prop, "Hide Dot Files/Datablocks", "Hide files/datablocks that start with a dot(.*)");
+       RNA_def_property_ui_text(prop, "Hide Dot Files/Datablocks", "Hide files/datablocks that start with a dot (.*)");
        
        prop= RNA_def_property(srna, "use_filter_files", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "uiflag", USER_FILTERFILEEXTS);
@@ -2933,7 +3073,9 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "script_directory", PROP_STRING, PROP_DIRPATH);
        RNA_def_property_string_sdna(prop, NULL, "pythondir");
-       RNA_def_property_ui_text(prop, "Python Scripts Directory", "Alternate script path, matching the default layout with subdirs: startup, addons & modules (requires restart)");
+       RNA_def_property_ui_text(prop, "Python Scripts Directory",
+                                "Alternate script path, matching the default layout with subdirs: "
+                                "startup, addons & modules (requires restart)");
        /* TODO, editing should reset sys.path! */
 
        prop= RNA_def_property(srna, "sound_directory", PROP_STRING, PROP_DIRPATH);
@@ -2964,11 +3106,13 @@ static void rna_def_userdef_filepaths(BlenderRNA *brna)
        prop= RNA_def_property(srna, "save_version", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "versions");
        RNA_def_property_range(prop, 0, 32);
-       RNA_def_property_ui_text(prop, "Save Versions", "The number of old versions to maintain in the current directory, when manually saving");
+       RNA_def_property_ui_text(prop, "Save Versions",
+                                "The number of old versions to maintain in the current directory, when manually saving");
 
        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 in temp directory, uses process ID");
+       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);
@@ -2994,19 +3138,19 @@ void rna_def_userdef_addon_collection(BlenderRNA *brna, PropertyRNA *cprop)
 
        RNA_def_property_srna(cprop, "Addons");
        srna= RNA_def_struct(brna, "Addons", NULL);
-       RNA_def_struct_ui_text(srna, "User Add-Ons", "Collection of add-ons");
+       RNA_def_struct_ui_text(srna, "User Addons", "Collection of addons");
 
        func= RNA_def_function(srna, "new", "rna_userdef_addon_new");
        RNA_def_function_flag(func, FUNC_NO_SELF);
        RNA_def_function_ui_description(func, "Add a new addon");
        /* return type */
-       parm= RNA_def_pointer(func, "addon", "Addon", "", "Addon datablock.");
+       parm= RNA_def_pointer(func, "addon", "Addon", "", "Addon datablock");
        RNA_def_function_return(func, parm);
 
        func= RNA_def_function(srna, "remove", "rna_userdef_addon_remove");
        RNA_def_function_flag(func, FUNC_NO_SELF);
-       RNA_def_function_ui_description(func, "Remove addon.");
-       parm= RNA_def_pointer(func, "addon", "Addon", "", "Addon to remove.");
+       RNA_def_function_ui_description(func, "Remove addon");
+       parm= RNA_def_pointer(func, "addon", "Addon", "", "Addon to remove");
        RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
 }
 
@@ -3019,7 +3163,7 @@ void RNA_def_userdef(BlenderRNA *brna)
                {USER_SECTION_INTERFACE, "INTERFACE", 0, "Interface", ""},
                {USER_SECTION_EDIT, "EDITING", 0, "Editing", ""},
                {USER_SECTION_INPUT, "INPUT", 0, "Input", ""},
-               {USER_SECTION_ADDONS, "ADDONS", 0, "Add-Ons", ""},
+               {USER_SECTION_ADDONS, "ADDONS", 0, "Addons", ""},
                {USER_SECTION_THEME, "THEMES", 0, "Themes", ""},
                {USER_SECTION_FILE, "FILES", 0, "File", ""},
                {USER_SECTION_SYSTEM, "SYSTEM", 0, "System", ""},