Merge branch 'master' into blender2.8
authorCampbell Barton <ideasman42@gmail.com>
Thu, 5 Jul 2018 20:46:04 +0000 (22:46 +0200)
committerCampbell Barton <ideasman42@gmail.com>
Thu, 5 Jul 2018 20:46:04 +0000 (22:46 +0200)
39 files changed:
1  2 
intern/cycles/device/device_cuda.cpp
intern/cycles/render/image.cpp
source/blender/makesrna/intern/rna_ID.c
source/blender/makesrna/intern/rna_animation.c
source/blender/makesrna/intern/rna_armature.c
source/blender/makesrna/intern/rna_brush.c
source/blender/makesrna/intern/rna_color.c
source/blender/makesrna/intern/rna_curve.c
source/blender/makesrna/intern/rna_depsgraph.c
source/blender/makesrna/intern/rna_dynamicpaint.c
source/blender/makesrna/intern/rna_fcurve.c
source/blender/makesrna/intern/rna_gpencil.c
source/blender/makesrna/intern/rna_image.c
source/blender/makesrna/intern/rna_internal.h
source/blender/makesrna/intern/rna_lattice.c
source/blender/makesrna/intern/rna_main.c
source/blender/makesrna/intern/rna_mesh.c
source/blender/makesrna/intern/rna_meta.c
source/blender/makesrna/intern/rna_modifier.c
source/blender/makesrna/intern/rna_nla.c
source/blender/makesrna/intern/rna_nodetree.c
source/blender/makesrna/intern/rna_object_force.c
source/blender/makesrna/intern/rna_particle.c
source/blender/makesrna/intern/rna_pose.c
source/blender/makesrna/intern/rna_rigidbody.c
source/blender/makesrna/intern/rna_rna.c
source/blender/makesrna/intern/rna_scene.c
source/blender/makesrna/intern/rna_screen.c
source/blender/makesrna/intern/rna_sculpt_paint.c
source/blender/makesrna/intern/rna_sequencer.c
source/blender/makesrna/intern/rna_smoke.c
source/blender/makesrna/intern/rna_sound.c
source/blender/makesrna/intern/rna_space.c
source/blender/makesrna/intern/rna_texture.c
source/blender/makesrna/intern/rna_tracking.c
source/blender/makesrna/intern/rna_ui.c
source/blender/makesrna/intern/rna_userdef.c
source/blender/makesrna/intern/rna_wm.c
source/blender/makesrna/intern/rna_wm_manipulator.c

Simple merge
Simple merge
index f1ff038ddd7fe5f5f31146d81cc7905224c2b02c,c6b18d8d387c23298a2c70d2d95e105a3c12bb43..a18442df08578f2c7db51905ceccafd41f4be82c
  
  #ifdef RNA_RUNTIME
  
 +#include "BLI_iterator.h"
 +
 +#include "BKE_anim.h"
 +
  #include "DEG_depsgraph_build.h"
  #include "DEG_depsgraph_debug.h"
- static int rna_DepsgraphUpdate_is_dirty_transform_get(PointerRNA *ptr)
 +#include "DEG_depsgraph_query.h"
 +
 +#include "MEM_guardedalloc.h"
 +
 +/* **************** Object Instance **************** */
 +
 +static PointerRNA rna_DepsgraphObjectInstance_object_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      return rna_pointer_inherit_refine(ptr, &RNA_Object, iterator->current);
 +}
 +
 +static PointerRNA rna_DepsgraphObjectInstance_instance_object_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      Object *instance_object = NULL;
 +      if (deg_iter->dupli_object_current != NULL) {
 +              instance_object = deg_iter->dupli_object_current->ob;
 +      }
 +      return rna_pointer_inherit_refine(ptr, &RNA_Object, instance_object);
 +}
 +
 +static PointerRNA rna_DepsgraphObjectInstance_parent_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      Object *dupli_parent = NULL;
 +      if (deg_iter->dupli_object_current != NULL) {
 +              dupli_parent = deg_iter->dupli_parent;
 +      }
 +      return rna_pointer_inherit_refine(ptr, &RNA_Object, dupli_parent);
 +}
 +
 +static PointerRNA rna_DepsgraphObjectInstance_particle_system_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      return rna_pointer_inherit_refine(ptr, &RNA_ParticleSystem,
 +              deg_iter->dupli_object_current->particle_system);
 +}
 +
 +static void rna_DepsgraphObjectInstance_persistent_id_get(PointerRNA *ptr, int *persistent_id)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      memcpy(persistent_id, deg_iter->dupli_object_current->persistent_id,
 +             sizeof(deg_iter->dupli_object_current->persistent_id));
 +}
 +
 +static void rna_DepsgraphObjectInstance_orco_get(PointerRNA *ptr, float *orco)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      memcpy(orco, deg_iter->dupli_object_current->orco,
 +             sizeof(deg_iter->dupli_object_current->orco));
 +}
 +
 +static unsigned int rna_DepsgraphObjectInstance_random_id_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      return deg_iter->dupli_object_current->random_id;
 +}
 +
 +static void rna_DepsgraphObjectInstance_uv_get(PointerRNA *ptr, float *uv)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      memcpy(uv, deg_iter->dupli_object_current->uv,
 +             sizeof(deg_iter->dupli_object_current->uv));
 +}
 +
 +static int rna_DepsgraphObjectInstance_is_instance_get(PointerRNA *ptr)
 +{
 +      BLI_Iterator *iterator = ptr->data;
 +      DEGObjectIterData *deg_iter = (DEGObjectIterData *)iterator->data;
 +      return (deg_iter->dupli_object_current != NULL);
 +}
 +
 +/* ******************** Sorted  ***************** */
 +
 +static int rna_Depsgraph_mode_get(PointerRNA *ptr)
 +{
 +      Depsgraph *depsgraph = ptr->data;
 +      return DEG_get_mode(depsgraph);
 +}
 +
 +/* ******************** Updates ***************** */
 +
 +static PointerRNA rna_DepsgraphUpdate_id_get(PointerRNA *ptr)
 +{
 +      return rna_pointer_inherit_refine(ptr, &RNA_ID, ptr->data);
 +}
 +
- static int rna_DepsgraphUpdate_is_dirty_geometry_get(PointerRNA *ptr)
++static bool rna_DepsgraphUpdate_is_dirty_transform_get(PointerRNA *ptr)
 +{
 +      ID *id = ptr->data;
 +      return ((id->recalc & ID_RECALC_TRANSFORM) == 0);
 +}
 +
++static bool rna_DepsgraphUpdate_is_dirty_geometry_get(PointerRNA *ptr)
 +{
 +      ID *id = ptr->data;
 +      if (id->recalc & ID_RECALC_GEOMETRY) {
 +              return false;
 +      }
 +      if (GS(id->name) != ID_OB) {
 +              return true;
 +      }
 +      Object *object = (Object *)id;
 +      ID *data = object->data;
 +      if (data == NULL) {
 +              return true;
 +      }
 +      return ((data->recalc & ID_RECALC_ALL) == 0);
 +}
 +
 +/* **************** Depsgraph **************** */
  
  static void rna_Depsgraph_debug_relations_graphviz(Depsgraph *depsgraph,
                                                     const char *filename)
index 2570f88d09fe31c2304d4f46d69216d07e38125c,018a4765cd01fbb9badb98b430f9a7aaf1069228..3d12debe0b50ebb9f19931e545f6aaaff62fac26
@@@ -72,7 -70,20 +72,7 @@@ static const EnumPropertyItem image_sou
  #include "IMB_imbuf.h"
  #include "IMB_imbuf_types.h"
  
- static int rna_Image_is_stereo_3d_get(PointerRNA *ptr)
 -static void rna_Image_animated_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 -{
 -      Image *ima = (Image *)ptr->data;
 -      int nr;
 -
 -      if (ima->flag & IMA_TWINANIM) {
 -              nr = ima->xrep * ima->yrep;
 -              if (ima->twsta >= nr) ima->twsta = 1;
 -              if (ima->twend >= nr) ima->twend = nr - 1;
 -              if (ima->twsta > ima->twend) ima->twsta = 1;
 -      }
 -}
 -
+ static bool rna_Image_is_stereo_3d_get(PointerRNA *ptr)
  {
        return BKE_image_is_stereo((Image *)ptr->data);
  }
index d664415b8adc219dab2097cfb5edc6350ddd7efe,0b8f90e1c68cdadbb9feba9e5bf3a6cb7f618c08..92b7fd1760f3b895cc04b9da31cc2977c26ddb3c
@@@ -881,36 -869,6 +881,36 @@@ static int rna_MeshUVLoopLayer_data_len
        return (me->edit_btmesh) ? 0 : me->totloop;
  }
  
- static int rna_MeshUVLoopLayer_active_render_get(PointerRNA *ptr)
++static bool rna_MeshUVLoopLayer_active_render_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV, 1);
 +}
 +
- static int rna_MeshUVLoopLayer_active_get(PointerRNA *ptr)
++static bool rna_MeshUVLoopLayer_active_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV, 0);
 +}
 +
- static int rna_MeshUVLoopLayer_clone_get(PointerRNA *ptr)
++static bool rna_MeshUVLoopLayer_clone_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_clone_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV);
 +}
 +
- static void rna_MeshUVLoopLayer_active_render_set(PointerRNA *ptr, int value)
++static void rna_MeshUVLoopLayer_active_render_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV, 1);
 +}
 +
- static void rna_MeshUVLoopLayer_active_set(PointerRNA *ptr, int value)
++static void rna_MeshUVLoopLayer_active_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV, 0);
 +}
 +
- static void rna_MeshUVLoopLayer_clone_set(PointerRNA *ptr, int value)
++static void rna_MeshUVLoopLayer_clone_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_clone_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV);
 +}
 +
  /* face uv_textures */
  
  DEFINE_CUSTOMDATA_LAYER_COLLECTION(tessface_uv_texture, fdata, CD_MTFACE)
index 874f3a8049d9d5f2a7e98d4f50d9b9a9c682b96d,7eb48272c56b1e9953ba19b0fa1eab585a954655..866ea771b0f4df3f30ba41d80687772793d98bd7
@@@ -591,14 -588,7 +591,14 @@@ static bool rna_Property_animatable_get
        return (prop->flag & PROP_ANIMATABLE) != 0;
  }
  
- static int rna_Property_overridable_get(PointerRNA *ptr)
++static bool rna_Property_overridable_get(PointerRNA *ptr)
 +{
 +      PropertyRNA *prop = (PropertyRNA *)ptr->data;
 +
 +      return (prop->flag_override & PROPOVERRIDE_OVERRIDABLE_STATIC) != 0;
 +}
 +
- static int rna_Property_use_output_get(PointerRNA *ptr)
+ static bool rna_Property_use_output_get(PointerRNA *ptr)
  {
        PropertyRNA *prop = (PropertyRNA *)ptr->data;
        return (prop->flag_parameter & PARM_OUTPUT) != 0;
index 512b99bdd79bdbd268a7b656b704c596365ce2c3,3c8cc9ee2be7d2e8beb2815e6eee4664048fbb41..72245e8feb92dc312f52f9651190f75726d01faa
@@@ -1456,63 -1513,139 +1456,63 @@@ static void rna_RenderSettings_engine_u
        ED_render_engine_changed(bmain);
  }
  
- static int rna_RenderSettings_multiple_engines_get(PointerRNA *UNUSED(ptr))
 -static void rna_Scene_glsl_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
++static bool rna_RenderSettings_multiple_engines_get(PointerRNA *UNUSED(ptr))
  {
 -      Scene *scene = (Scene *)ptr->id.data;
 -
 -      DAG_id_tag_update(&scene->id, 0);
 +      return (BLI_listbase_count(&R_engines) > 1);
  }
  
- static int rna_RenderSettings_use_spherical_stereo_get(PointerRNA *ptr)
 -static void rna_Scene_freestyle_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
++static bool rna_RenderSettings_use_spherical_stereo_get(PointerRNA *ptr)
  {
        Scene *scene = (Scene *)ptr->id.data;
 -
 -      DAG_id_tag_update(&scene->id, 0);
 -}
 -
 -static void rna_Scene_use_view_map_cache_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
 -{
 -#ifdef WITH_FREESTYLE
 -      FRS_free_view_map_cache();
 -#endif
 -}
 -
 -static IDProperty *rna_SceneRenderLayer_idprops(PointerRNA *ptr, bool create)
 -{
 -      SceneRenderLayer *srl = (SceneRenderLayer *)ptr->data;
 -
 -      if (create && !srl->prop) {
 -              IDPropertyTemplate val = {0};
 -              srl->prop = IDP_New(IDP_GROUP, &val, "SceneRenderLayer ID properties");
 -      }
 -
 -      return srl->prop;
 +      return BKE_scene_use_spherical_stereo(scene);
  }
  
 -static void rna_SceneRenderLayer_name_set(PointerRNA *ptr, const char *value)
 +void rna_Scene_glsl_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
  {
        Scene *scene = (Scene *)ptr->id.data;
 -      SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
 -      char oldname[sizeof(rl->name)];
 -
 -      BLI_strncpy(oldname, rl->name, sizeof(rl->name));
 -
 -      BLI_strncpy_utf8(rl->name, value, sizeof(rl->name));
 -      BLI_uniquename(&scene->r.layers, rl, DATA_("RenderLayer"), '.', offsetof(SceneRenderLayer, name), sizeof(rl->name));
  
 -      if (scene->nodetree) {
 -              bNode *node;
 -              int index = BLI_findindex(&scene->r.layers, rl);
 -
 -              for (node = scene->nodetree->nodes.first; node; node = node->next) {
 -                      if (node->type == CMP_NODE_R_LAYERS && node->id == NULL) {
 -                              if (node->custom1 == index)
 -                                      BLI_strncpy(node->name, rl->name, NODE_MAXSTR);
 -                      }
 -              }
 -      }
 -
 -      /* fix all the animation data which may link to this */
 -      BKE_animdata_fix_paths_rename_all(NULL, "render.layers", oldname, rl->name);
 +      DEG_id_tag_update(&scene->id, 0);
  }
  
 -static char *rna_SceneRenderLayer_path(PointerRNA *ptr)
 +static void rna_Scene_world_update(Main *bmain, Scene *scene, PointerRNA *ptr)
  {
 -      SceneRenderLayer *srl = (SceneRenderLayer *)ptr->data;
 -      char name_esc[sizeof(srl->name) * 2];
 +      Scene *sc = (Scene *)ptr->id.data;
  
 -      BLI_strescape(name_esc, srl->name, sizeof(name_esc));
 -      return BLI_sprintfN("render.layers[\"%s\"]", name_esc);
 +      rna_Scene_glsl_update(bmain, scene, ptr);
 +      WM_main_add_notifier(NC_WORLD | ND_WORLD, &sc->id);
  }
  
 -static void rna_SceneRenderView_name_set(PointerRNA *ptr, const char *value)
 +void rna_Scene_freestyle_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
  {
        Scene *scene = (Scene *)ptr->id.data;
 -      SceneRenderView *rv = (SceneRenderView *)ptr->data;
 -      BLI_strncpy_utf8(rv->name, value, sizeof(rv->name));
 -      BLI_uniquename(&scene->r.views, rv, DATA_("RenderView"), '.', offsetof(SceneRenderView, name), sizeof(rv->name));
 -}
 -
 -static char *rna_SceneRenderView_path(PointerRNA *ptr)
 -{
 -      SceneRenderView *srv = (SceneRenderView *)ptr->data;
 -      return BLI_sprintfN("render.views[\"%s\"]", srv->name);
 -}
 -
 -static void rna_RenderSettings_views_format_set(PointerRNA *ptr, int value)
 -{
 -      RenderData *rd = (RenderData *)ptr->data;
 -
 -      if (rd->views_format == SCE_VIEWS_FORMAT_MULTIVIEW &&
 -          value == SCE_VIEWS_FORMAT_STEREO_3D)
 -      {
 -              /* make sure the actview is visible */
 -              if (rd->actview > 1) rd->actview = 1;
 -      }
  
 -      rd->views_format = value;
 +      DEG_id_tag_update(&scene->id, 0);
  }
  
 -static bool rna_RenderSettings_multiple_engines_get(PointerRNA *UNUSED(ptr))
 +void rna_Scene_use_view_map_cache_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
  {
 -      return (BLI_listbase_count(&R_engines) > 1);
 +#ifdef WITH_FREESTYLE
 +      FRS_free_view_map_cache();
 +#endif
  }
  
 -static bool rna_RenderSettings_use_shading_nodes_get(PointerRNA *ptr)
 +void rna_ViewLayer_name_set(PointerRNA *ptr, const char *value)
  {
        Scene *scene = (Scene *)ptr->id.data;
 -      return BKE_scene_use_new_shading_nodes(scene);
 +      ViewLayer *view_layer = (ViewLayer *)ptr->data;
 +      BLI_assert(BKE_id_is_in_gobal_main(&scene->id));
 +      BKE_view_layer_rename(G_MAIN, scene, view_layer, value);
  }
  
 -static bool rna_RenderSettings_use_spherical_stereo_get(PointerRNA *ptr)
 +static void rna_SceneRenderView_name_set(PointerRNA *ptr, const char *value)
  {
        Scene *scene = (Scene *)ptr->id.data;
 -      return BKE_scene_use_spherical_stereo(scene);
 -}
 -
 -static bool rna_RenderSettings_use_game_engine_get(PointerRNA *ptr)
 -{
 -      RenderData *rd = (RenderData *)ptr->data;
 -      RenderEngineType *type;
 -
 -      for (type = R_engines.first; type; type = type->next)
 -              if (STREQ(type->idname, rd->engine))
 -                      return (type->flag & RE_GAME) != 0;
 -
 -      return 0;
 -}
 -
 -static void rna_SceneRenderLayer_layer_set(PointerRNA *ptr, const bool *values)
 -{
 -      SceneRenderLayer *rl = (SceneRenderLayer *)ptr->data;
 -      rl->lay = ED_view3d_scene_layer_set(rl->lay, values, NULL);
 +      SceneRenderView *rv = (SceneRenderView *)ptr->data;
 +      BLI_strncpy_utf8(rv->name, value, sizeof(rv->name));
 +      BLI_uniquename(&scene->r.views, rv, DATA_("RenderView"), '.', offsetof(SceneRenderView, name), sizeof(rv->name));
  }
  
 -static void rna_SceneRenderLayer_pass_update(Main *bmain, Scene *activescene, PointerRNA *ptr)
 +void rna_ViewLayer_pass_update(Main *bmain, Scene *activescene, PointerRNA *ptr)
  {
        Scene *scene = (Scene *)ptr->id.data;
  
@@@ -2018,117 -2162,28 +2018,117 @@@ static void rna_Stereo3dFormat_update(M
        }
  }
  
- static int rna_gpu_is_hq_supported_get(PointerRNA *UNUSED(ptr))
+ static bool rna_gpu_is_hq_supported_get(PointerRNA *UNUSED(ptr))
  {
 -      return GPU_instanced_drawing_support() && GPU_geometry_shader_support();
 +      return true;
  }
  
 -#else
 -
 -/* Grease Pencil Interpolation tool settings */
 -static void rna_def_gpencil_interpolate(BlenderRNA *brna)
 +static ViewLayer *rna_ViewLayer_new(
 +        ID *id, Scene *UNUSED(sce), Main *bmain, const char *name)
  {
 -      StructRNA *srna;
 -      PropertyRNA *prop;
 +      Scene *scene = (Scene *)id;
 +      ViewLayer *view_layer = BKE_view_layer_add(scene, name);
  
 -      srna = RNA_def_struct(brna, "GPencilInterpolateSettings", NULL);
 -      RNA_def_struct_sdna(srna, "GP_Interpolate_Settings");
 -      RNA_def_struct_path_func(srna, "rna_GPencilInterpolateSettings_path");
 -      RNA_def_struct_ui_text(srna, "Grease Pencil Interpolate Settings",
 -                             "Settings for Grease Pencil interpolation tools");
 +      DEG_id_tag_update(&scene->id, 0);
 +      DEG_relations_tag_update(bmain);
 +      WM_main_add_notifier(NC_SCENE | ND_LAYER, NULL);
  
 -      /* flags */
 -      prop = RNA_def_property(srna, "interpolate_all_layers", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ALL_LAYERS);
 +      return view_layer;
 +}
 +
 +static void rna_ViewLayer_remove(
 +        ID *id, Scene *UNUSED(sce), Main *bmain, ReportList *reports, PointerRNA *sl_ptr)
 +{
 +      Scene *scene = (Scene *)id;
 +      ViewLayer *view_layer = sl_ptr->data;
 +
 +      if (ED_scene_view_layer_delete(bmain, scene, view_layer, reports)) {
 +              RNA_POINTER_INVALIDATE(sl_ptr);
 +      }
 +}
 +
 +static int rna_Scene_transform_orientation_get(PointerRNA *ptr)
 +{
 +      Scene *scene = ptr->data;
 +      /* convert to enum value */
 +      return (scene->orientation_type == V3D_MANIP_CUSTOM) ?
 +                  (scene->orientation_type + scene->orientation_index_custom) : scene->orientation_type;
 +}
 +
 +void rna_Scene_transform_orientation_set(PointerRNA *ptr, int value)
 +{
 +      Scene *scene = ptr->data;
 +      BIF_selectTransformOrientationValue(scene, value);
 +}
 +
 +static PointerRNA rna_Scene_current_orientation_get(PointerRNA *ptr)
 +{
 +      Scene *scene = ptr->data;
 +      TransformOrientation *orientation;
 +
 +      if (scene->orientation_type < V3D_MANIP_CUSTOM) {
 +              orientation = NULL;
 +      }
 +      else {
 +              orientation = BKE_scene_transform_orientation_find(scene, scene->orientation_index_custom);
 +      }
 +
 +      return rna_pointer_inherit_refine(ptr, &RNA_TransformOrientation, orientation);
 +}
 +
 +const EnumPropertyItem *rna_TransformOrientation_itemf(
 +        bContext *C, PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
 +{
 +      EnumPropertyItem tmp = {0, "", 0, "", ""};
 +      EnumPropertyItem *item = NULL;
 +      int i = V3D_MANIP_CUSTOM, totitem = 0;
 +
 +      RNA_enum_items_add(&item, &totitem, transform_orientation_items);
 +
 +      Scene *scene;
 +      if (ptr->type == &RNA_Scene) {
 +              scene = ptr->data;
 +      }
 +      else {
 +              scene = CTX_data_scene(C);
 +      }
 +      const ListBase *transform_orientations = scene ? &scene->transform_spaces : NULL;
 +
 +      if (transform_orientations && (BLI_listbase_is_empty(transform_orientations) == false)) {
 +              RNA_enum_item_add_separator(&item, &totitem);
 +
 +              for (TransformOrientation *ts = transform_orientations->first; ts; ts = ts->next) {
 +                      tmp.identifier = ts->name;
 +                      tmp.name = ts->name;
 +                      tmp.value = i++;
 +                      RNA_enum_item_add(&item, &totitem, &tmp);
 +              }
 +      }
 +
 +      RNA_enum_item_end(&item, &totitem);
 +      *r_free = true;
 +
 +      return item;
 +}
 +
 +
 +#else
 +
 +/* Grease Pencil Interpolation tool settings */
 +static void rna_def_gpencil_interpolate(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna = RNA_def_struct(brna, "GPencilInterpolateSettings", NULL);
 +      RNA_def_struct_sdna(srna, "GP_Interpolate_Settings");
 +      RNA_def_struct_path_func(srna, "rna_GPencilInterpolateSettings_path");
 +      RNA_def_struct_ui_text(srna, "Grease Pencil Interpolate Settings",
 +                             "Settings for Grease Pencil interpolation tools");
 +
 +      /* flags */
 +      prop = RNA_def_property(srna, "interpolate_all_layers", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_TOOLFLAG_INTERPOLATE_ALL_LAYERS);
        RNA_def_property_ui_text(prop, "Interpolate All Layers", "Interpolate all layers, not only active");
        RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL);
  
index d41d04a4f118a6de68f240b97e4b49074596c7ef,7ca26ab1c9feac12f3d0b233c54e31020410a62b..a6a23d6322d21a02c9de21204285f0f53ebb59a8
@@@ -68,69 -64,58 +68,69 @@@ const EnumPropertyItem rna_enum_region_
  #  include "BPY_extern.h"
  #endif
  
 -static void rna_Screen_scene_set(PointerRNA *ptr, PointerRNA value)
 -{
 -      bScreen *sc = (bScreen *)ptr->data;
  
 -      if (value.data == NULL)
 -              return;
 +static void rna_Screen_redraw_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 +{
 +      bScreen *screen = (bScreen *)ptr->data;
  
 -      sc->newscene = value.data;
 +      /* the settings for this are currently only available from a menu in the TimeLine,
 +       * hence refresh=SPACE_ACTION, as timeline is now in there
 +       */
 +      ED_screen_animation_timer_update(screen, screen->redraws_flag, SPACE_ACTION);
  }
  
- static int rna_Screen_is_animation_playing_get(PointerRNA *UNUSED(ptr))
 -static void rna_Screen_scene_update(bContext *C, PointerRNA *ptr)
++static bool rna_Screen_is_animation_playing_get(PointerRNA *UNUSED(ptr))
  {
 -      bScreen *sc = (bScreen *)ptr->data;
 -
 -      /* exception: must use context so notifier gets to the right window  */
 -      if (sc->newscene) {
 -#ifdef WITH_PYTHON
 -              BPy_BEGIN_ALLOW_THREADS;
 -#endif
 -
 -              ED_screen_set_scene(C, sc, sc->newscene);
 -
 -#ifdef WITH_PYTHON
 -              BPy_END_ALLOW_THREADS;
 -#endif
 +      /* can be NULL on file load, T42619 */
 +      wmWindowManager *wm = G_MAIN->wm.first;
 +      return wm ? (ED_screen_animation_playing(wm) != NULL) : 0;
 +}
  
 -              WM_event_add_notifier(C, NC_SCENE | ND_SCENEBROWSE, sc->newscene);
 +static int rna_region_alignment_get(PointerRNA *ptr)
 +{
 +      ARegion *region = ptr->data;
 +      return (region->alignment & ~RGN_SPLIT_PREV);
 +}
  
 -              if (G.debug & G_DEBUG)
 -                      printf("scene set %p\n", sc->newscene);
 +static void rna_Screen_layout_name_get(PointerRNA *ptr, char *value)
 +{
 +      const bScreen *screen = ptr->data;
 +      const WorkSpaceLayout *layout = BKE_workspace_layout_find_global(G_MAIN, screen, NULL);
  
 -              sc->newscene = NULL;
 +      if (layout) {
 +              const char *name = BKE_workspace_layout_name_get(layout);
 +              strcpy(value, name);
 +      }
 +      else {
 +              value[0] = '\0';
        }
  }
  
 -static void rna_Screen_redraw_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 +static int rna_Screen_layout_name_length(PointerRNA *ptr)
  {
 -      bScreen *screen = (bScreen *)ptr->data;
 +      const bScreen *screen = ptr->data;
 +      const WorkSpaceLayout *layout = BKE_workspace_layout_find_global(G_MAIN, screen, NULL);
  
 -      /* the settings for this are currently only available from a menu in the TimeLine, hence refresh=SPACE_TIME */
 -      ED_screen_animation_timer_update(screen, screen->redraws_flag, SPACE_TIME);
 -}
 +      if (layout) {
 +              const char *name = BKE_workspace_layout_name_get(layout);
 +              return strlen(name);
 +      }
  
 +      return 0;
 +}
  
 -static bool rna_Screen_is_animation_playing_get(PointerRNA *UNUSED(ptr))
 +static void rna_Screen_layout_name_set(PointerRNA *ptr, const char *value)
  {
 -      /* can be NULL on file load, T42619 */
 -      wmWindowManager *wm = G_MAIN->wm.first;
 -      return wm ? (ED_screen_animation_playing(wm) != NULL) : 0;
 +      bScreen *screen = ptr->data;
 +      WorkSpace *workspace;
 +      WorkSpaceLayout *layout = BKE_workspace_layout_find_global(G_MAIN, screen, &workspace);
 +
 +      if (layout) {
 +              BKE_workspace_layout_name_set(workspace, layout, value);
 +      }
  }
  
- static int rna_Screen_fullscreen_get(PointerRNA *ptr)
+ static bool rna_Screen_fullscreen_get(PointerRNA *ptr)
  {
        bScreen *sc = (bScreen *)ptr->data;
        return (sc->state == SCREENMAXIMIZED);
index 6f3a1afc156fc4b9f5e8dfc36324fefea9df235f,c111263cb7d397c6865efcf8a8039dee7fbf8226..5b2a3c9c4f4963e246725ba90c8e4df6b65a7a19
@@@ -227,9 -218,13 +227,9 @@@ static bool rna_ParticleEdit_editable_g
  {
        ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
  
 -      if (pset->object != NULL && pset->scene != NULL) {
 -              BLI_assert(BKE_id_is_in_gobal_main(&pset->object->id));
 -              BLI_assert(BKE_id_is_in_gobal_main(&pset->scene->id));
 -      }
 -      return (pset->object && pset->scene && PE_get_current(G_MAIN, pset->scene, pset->object));
 +      return (pset->object && pset->scene && PE_get_current(pset->scene, pset->object));
  }
- static int rna_ParticleEdit_hair_get(PointerRNA *ptr)
+ static bool rna_ParticleEdit_hair_get(PointerRNA *ptr)
  {
        ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
  
index 239203bd38438e6e334d46ec6f06bba952164f2d,813e847aae6b95b0193dd64eed1bb69733c03c6d..6a368fa4b410213d8a60c99419020009c8bf1c2f
@@@ -967,13 -823,10 +967,13 @@@ static bool rna_SpaceImageEditor_show_u
  {
        SpaceImage *sima = (SpaceImage *)(ptr->data);
        bScreen *sc = (bScreen *)ptr->id.data;
 -      return ED_space_image_show_uvedit(sima, sc->scene->obedit);
 +      wmWindow *win = ED_screen_window_find(sc, G_MAIN->wm.first);
 +      ViewLayer *view_layer = WM_window_get_active_view_layer(win);
 +      Object *obedit = OBEDIT_FROM_VIEW_LAYER(view_layer);
 +      return ED_space_image_show_uvedit(sima, obedit);
  }
  
- static int rna_SpaceImageEditor_show_maskedit_get(PointerRNA *ptr)
+ static bool rna_SpaceImageEditor_show_maskedit_get(PointerRNA *ptr)
  {
        SpaceImage *sima = (SpaceImage *)(ptr->data);
        bScreen *sc = (bScreen *)ptr->id.data;
@@@ -1814,18 -1696,6 +1814,18 @@@ static int rna_FileBrowser_FSMenuEntry_
        return fsm->save ? PROP_EDITABLE : 0;
  }
  
- static int rna_FileBrowser_FSMenuEntry_use_save_get(PointerRNA *ptr)
++static bool rna_FileBrowser_FSMenuEntry_use_save_get(PointerRNA *ptr)
 +{
 +      FSMenuEntry *fsm = ptr->data;
 +      return fsm->save;
 +}
 +
- static int rna_FileBrowser_FSMenuEntry_is_valid_get(PointerRNA *ptr)
++static bool rna_FileBrowser_FSMenuEntry_is_valid_get(PointerRNA *ptr)
 +{
 +      FSMenuEntry *fsm = ptr->data;
 +      return fsm->valid;
 +}
 +
  static void rna_FileBrowser_FSMenu_next(CollectionPropertyIterator *iter)
  {
        ListBaseIterator *internal = &iter->internal.listbase;
index 9d13cb8f7f07d0a58a5d1df25ab8b2fb91cd45c3,782d39bcb7e9ba6dfc6feaec419fb6ce830b4179..7bec598351e0d6bf31f3cf77871ed4340a74d2ff
@@@ -943,36 -889,6 +943,36 @@@ static void rna_UILayout_scale_y_set(Po
        uiLayoutSetScaleY(ptr->data, value);
  }
  
- static int rna_UILayout_property_split_get(PointerRNA *ptr)
 +static int rna_UILayout_emboss_get(PointerRNA *ptr)
 +{
 +      return uiLayoutGetEmboss(ptr->data);
 +}
 +
 +static void rna_UILayout_emboss_set(PointerRNA *ptr, int value)
 +{
 +      uiLayoutSetEmboss(ptr->data, value);
 +}
 +
- static void rna_UILayout_property_split_set(PointerRNA *ptr, int value)
++static bool rna_UILayout_property_split_get(PointerRNA *ptr)
 +{
 +      return uiLayoutGetPropSep(ptr->data);
 +}
 +
- static int rna_UILayout_property_decorate_get(PointerRNA *ptr)
++static void rna_UILayout_property_split_set(PointerRNA *ptr, bool value)
 +{
 +      uiLayoutSetPropSep(ptr->data, value);
 +}
 +
- static void rna_UILayout_property_decorate_set(PointerRNA *ptr, int value)
++static bool rna_UILayout_property_decorate_get(PointerRNA *ptr)
 +{
 +      return uiLayoutGetPropDecorate(ptr->data);
 +}
 +
++static void rna_UILayout_property_decorate_set(PointerRNA *ptr, bool value)
 +{
 +      uiLayoutSetPropDecorate(ptr->data, value);
 +}
 +
  #else /* RNA_RUNTIME */
  
  static void rna_def_ui_layout(BlenderRNA *brna)
index 347283cd529ed51f6b348c88dcd6482408541902,487f62cdfe619622a2121c976bc24fdec9207eb6..364a5694a073131d911fe5bf267e641f9ccc0b34
@@@ -652,136 -679,6 +652,136 @@@ static StructRNA *rna_AddonPref_refine(
        return (ptr->type) ? ptr->type : &RNA_AddonPreferences;
  }
  
- static int rna_UserDef_studiolight_is_user_defined_get(PointerRNA *ptr)
 +static float rna_ThemeUI_roundness_get(PointerRNA *ptr)
 +{
 +      /* Remap from relative radius to 0..1 range. */
 +      uiWidgetColors *tui = (uiWidgetColors *)ptr->data;
 +      return tui->roundness * 2.0f;
 +}
 +
 +static void rna_ThemeUI_roundness_set(PointerRNA *ptr, float value)
 +{
 +      uiWidgetColors *tui = (uiWidgetColors *)ptr->data;
 +      tui->roundness = value * 0.5f;
 +}
 +
 +/* Studio Light */
 +static void rna_UserDef_studiolight_begin(CollectionPropertyIterator *iter, PointerRNA *UNUSED(ptr))
 +{
 +      rna_iterator_listbase_begin(iter, BKE_studiolight_listbase(), NULL);
 +}
 +
 +static void rna_StudioLights_refresh(UserDef *UNUSED(userdef))
 +{
 +      BKE_studiolight_refresh();
 +}
 +
 +static void rna_StudioLights_remove(UserDef *UNUSED(userdef), StudioLight *studio_light)
 +{
 +      BKE_studiolight_remove(studio_light);
 +}
 +
 +static StudioLight *rna_StudioLights_new(UserDef *UNUSED(userdef), const char *path, int orientation)
 +{
 +      return BKE_studiolight_new(path, orientation);
 +}
 +
 +/* StudioLight.name */
 +static void rna_UserDef_studiolight_name_get(PointerRNA *ptr, char *value)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      BLI_strncpy(value, sl->name, FILE_MAXFILE);
 +}
 +
 +static int rna_UserDef_studiolight_name_length(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      return strlen(sl->name);
 +}
 +
 +/* StudioLight.path */
 +static void rna_UserDef_studiolight_path_get(PointerRNA *ptr, char *value)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      BLI_strncpy(value, sl->path, FILE_MAX);
 +}
 +
 +static int rna_UserDef_studiolight_path_length(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      return strlen(sl->path);
 +}
 +
 +/* StudioLight.path_irr_cache */
 +static void rna_UserDef_studiolight_path_irr_cache_get(PointerRNA *ptr, char *value)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      if (sl->path_irr_cache) {
 +              BLI_strncpy(value, sl->path_irr_cache, FILE_MAX);
 +      }
 +      value[0] = 0x00;
 +}
 +
 +static int rna_UserDef_studiolight_path_irr_cache_length(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      if (sl->path_irr_cache) {
 +              return strlen(sl->path_irr_cache);
 +      }
 +      return 0;
 +}
 +
 +/* StudioLight.path_sh_cache */
 +static void rna_UserDef_studiolight_path_sh_cache_get(PointerRNA *ptr, char *value)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      if (sl->path_sh_cache) {
 +              BLI_strncpy(value, sl->path_sh_cache, FILE_MAX);
 +      }
 +      value[0] = 0x00;
 +}
 +
 +static int rna_UserDef_studiolight_path_sh_cache_length(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      if (sl->path_sh_cache) {
 +              return strlen(sl->path_sh_cache);
 +      }
 +      return 0;
 +}
 +
 +/* StudioLight.index */
 +static int rna_UserDef_studiolight_index_get(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      return sl->index;
 +}
 +
 +/* StudioLight.is_user_defined */
++static bool rna_UserDef_studiolight_is_user_defined_get(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      return (sl->flag & STUDIOLIGHT_USER_DEFINED) > 0;
 +}
 +
 +/* StudioLight.orientation */
 +
 +static int rna_UserDef_studiolight_orientation_get(PointerRNA *ptr)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      return sl->flag & STUDIOLIGHT_FLAG_ORIENTATIONS;
 +}
 +
 +static void rna_UserDef_studiolight_spherical_harmonics_coefficients_get(PointerRNA *ptr, float *values)
 +{
 +      StudioLight *sl = (StudioLight *)ptr->data;
 +      float *value = values;
 +      for (int i = 0; i < STUDIOLIGHT_SPHERICAL_HARMONICS_COMPONENTS; i++) {
 +              copy_v3_v3(value, sl->spherical_harmonics_coefs[i]);
 +              value += 3;
 +      }
 +}
 +
  #else
  
  /* TODO(sergey): This technically belongs to blenlib, but we don't link
index 6cfee512ff7cdf4500474a7f3feafee74b7535e4,0000000000000000000000000000000000000000..6d9a4bbe6c9402a11003d592b111a3f319f4a48d
mode 100644,000000..100644
--- /dev/null
@@@ -1,1328 -1,0 +1,1328 @@@
- static int rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +/*
 + * ***** BEGIN GPL LICENSE BLOCK *****
 + *
 + * This program is free software; you can redistribute it and/or
 + * modify it under the terms of the GNU General Public License
 + * as published by the Free Software Foundation; either version 2
 + * of the License, or (at your option) any later version.
 + *
 + * This program is distributed in the hope that it will be useful,
 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 + * GNU General Public License for more details.
 + *
 + * You should have received a copy of the GNU General Public License
 + * along with this program; if not, write to the Free Software Foundation,
 + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 + *
 + * ***** END GPL LICENSE BLOCK *****
 + */
 +
 +/** \file blender/makesrna/intern/rna_wm_manipulator.c
 + *  \ingroup RNA
 + */
 +
 +#include <stdlib.h>
 +
 +#include "DNA_screen_types.h"
 +#include "DNA_space_types.h"
 +#include "DNA_userdef_types.h"
 +#include "DNA_view3d_types.h"
 +#include "DNA_windowmanager_types.h"
 +
 +#include "BLI_utildefines.h"
 +#include "BLI_string_utils.h"
 +
 +#include "BLT_translation.h"
 +
 +#include "RNA_access.h"
 +#include "RNA_define.h"
 +#include "RNA_enum_types.h"
 +
 +#include "rna_internal.h"
 +
 +#include "WM_types.h"
 +
 +#ifdef RNA_RUNTIME
 +/* enum definitions */
 +#endif /* RNA_RUNTIME */
 +
 +#ifdef RNA_RUNTIME
 +
 +#include <assert.h>
 +
 +#include "WM_api.h"
 +
 +#include "DNA_workspace_types.h"
 +
 +#include "ED_screen.h"
 +
 +#include "UI_interface.h"
 +
 +#include "BKE_global.h"
 +#include "BKE_idprop.h"
 +#include "BKE_workspace.h"
 +
 +#include "MEM_guardedalloc.h"
 +
 +#ifdef WITH_PYTHON
 +#  include "BPY_extern.h"
 +#endif
 +
 +/* -------------------------------------------------------------------- */
 +
 +/** \name Manipulator API
 + * \{ */
 +
 +#ifdef WITH_PYTHON
 +static void rna_manipulator_draw_cb(
 +        const struct bContext *C, struct wmManipulator *mpr)
 +{
 +      extern FunctionRNA rna_Manipulator_draw_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "draw"); */
 +      func = &rna_Manipulator_draw_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +      RNA_parameter_list_free(&list);
 +}
 +
 +static void rna_manipulator_draw_select_cb(
 +        const struct bContext *C, struct wmManipulator *mpr, int select_id)
 +{
 +      extern FunctionRNA rna_Manipulator_draw_select_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "draw_select"); */
 +      func = &rna_Manipulator_draw_select_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      RNA_parameter_set_lookup(&list, "select_id", &select_id);
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +      RNA_parameter_list_free(&list);
 +}
 +
 +static int rna_manipulator_test_select_cb(
 +        struct bContext *C, struct wmManipulator *mpr, const struct wmEvent *event)
 +{
 +      extern FunctionRNA rna_Manipulator_test_select_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "test_select"); */
 +      func = &rna_Manipulator_test_select_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      RNA_parameter_set_lookup(&list, "event", &event);
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +
 +      void *ret;
 +      RNA_parameter_get_lookup(&list, "intersect_id", &ret);
 +      int intersect_id = *(int *)ret;
 +
 +      RNA_parameter_list_free(&list);
 +      return intersect_id;
 +}
 +
 +static int rna_manipulator_modal_cb(
 +        struct bContext *C, struct wmManipulator *mpr, const struct wmEvent *event,
 +        eWM_ManipulatorTweak tweak_flag)
 +{
 +      extern FunctionRNA rna_Manipulator_modal_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      const int tweak_flag_int = tweak_flag;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "modal"); */
 +      func = &rna_Manipulator_modal_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      RNA_parameter_set_lookup(&list, "event", &event);
 +      RNA_parameter_set_lookup(&list, "tweak", &tweak_flag_int);
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +
 +      void *ret;
 +      RNA_parameter_get_lookup(&list, "result", &ret);
 +      int ret_enum = *(int *)ret;
 +
 +      RNA_parameter_list_free(&list);
 +      return ret_enum;
 +}
 +
 +static void rna_manipulator_setup_cb(
 +        struct wmManipulator *mpr)
 +{
 +      extern FunctionRNA rna_Manipulator_setup_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "setup"); */
 +      func = &rna_Manipulator_setup_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      mgroup->type->ext.call((bContext *)NULL, &mpr_ptr, func, &list);
 +      RNA_parameter_list_free(&list);
 +}
 +
 +
 +static int rna_manipulator_invoke_cb(
 +        struct bContext *C, struct wmManipulator *mpr, const struct wmEvent *event)
 +{
 +      extern FunctionRNA rna_Manipulator_invoke_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "invoke"); */
 +      func = &rna_Manipulator_invoke_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      RNA_parameter_set_lookup(&list, "event", &event);
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +
 +      void *ret;
 +      RNA_parameter_get_lookup(&list, "result", &ret);
 +      int ret_enum = *(int *)ret;
 +
 +      RNA_parameter_list_free(&list);
 +      return ret_enum;
 +}
 +
 +static void rna_manipulator_exit_cb(
 +        struct bContext *C, struct wmManipulator *mpr, bool cancel)
 +{
 +      extern FunctionRNA rna_Manipulator_exit_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "exit"); */
 +      func = &rna_Manipulator_exit_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      {
 +              int cancel_i = cancel;
 +              RNA_parameter_set_lookup(&list, "cancel", &cancel_i);
 +      }
 +      mgroup->type->ext.call((bContext *)C, &mpr_ptr, func, &list);
 +      RNA_parameter_list_free(&list);
 +}
 +
 +static void rna_manipulator_select_refresh_cb(
 +        struct wmManipulator *mpr)
 +{
 +      extern FunctionRNA rna_Manipulator_select_refresh_func;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      PointerRNA mpr_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      RNA_pointer_create(NULL, mpr->type->ext.srna, mpr, &mpr_ptr);
 +      /* RNA_struct_find_function(&mpr_ptr, "select_refresh"); */
 +      func = &rna_Manipulator_select_refresh_func;
 +      RNA_parameter_list_create(&list, &mpr_ptr, func);
 +      mgroup->type->ext.call((bContext *)NULL, &mpr_ptr, func, &list);
 +      RNA_parameter_list_free(&list);
 +}
 +
 +#endif  /* WITH_PYTHON */
 +
 +/* just to work around 'const char *' warning and to ensure this is a python op */
 +static void rna_Manipulator_bl_idname_set(PointerRNA *ptr, const char *value)
 +{
 +      wmManipulator *data = ptr->data;
 +      char *str = (char *)data->type->idname;
 +      if (!str[0]) {
 +              BLI_strncpy(str, value, MAX_NAME);    /* utf8 already ensured */
 +      }
 +      else {
 +              assert(!"setting the bl_idname on a non-builtin operator");
 +      }
 +}
 +
 +static wmManipulator *rna_ManipulatorProperties_find_operator(PointerRNA *ptr)
 +{
 +#if 0
 +      wmWindowManager *wm = ptr->id.data;
 +#endif
 +
 +      /* We could try workaruond this lookup, but not trivial. */
 +      for (bScreen *screen = G_MAIN->screen.first; screen; screen = screen->id.next) {
 +              IDProperty *properties = ptr->data;
 +              for (ScrArea *sa = screen->areabase.first; sa; sa = sa->next) {
 +                      for (ARegion *ar = sa->regionbase.first; ar; ar = ar->next) {
 +                              if (ar->manipulator_map) {
 +                                      wmManipulatorMap *mmap = ar->manipulator_map;
 +                                      for (wmManipulatorGroup *mgroup = WM_manipulatormap_group_list(mmap)->first;
 +                                           mgroup;
 +                                           mgroup = mgroup->next)
 +                                      {
 +                                              for (wmManipulator *mpr = mgroup->manipulators.first; mpr; mpr = mpr->next) {
 +                                                      if (mpr->properties == properties) {
 +                                                              return mpr;
 +                                                      }
 +                                              }
 +                                      }
 +                              }
 +                      }
 +              }
 +      }
 +      return NULL;
 +}
 +
 +static StructRNA *rna_ManipulatorProperties_refine(PointerRNA *ptr)
 +{
 +      wmManipulator *mpr = rna_ManipulatorProperties_find_operator(ptr);
 +
 +      if (mpr)
 +              return mpr->type->srna;
 +      else
 +              return ptr->type;
 +}
 +
 +static IDProperty *rna_ManipulatorProperties_idprops(PointerRNA *ptr, bool create)
 +{
 +      if (create && !ptr->data) {
 +              IDPropertyTemplate val = {0};
 +              ptr->data = IDP_New(IDP_GROUP, &val, "RNA_ManipulatorProperties group");
 +      }
 +
 +      return ptr->data;
 +}
 +
 +static PointerRNA rna_Manipulator_properties_get(PointerRNA *ptr)
 +{
 +      wmManipulator *mpr = ptr->data;
 +      return rna_pointer_inherit_refine(ptr, mpr->type->srna, mpr->properties);
 +}
 +
 +/* wmManipulator.float */
 +#define RNA_MANIPULATOR_GENERIC_FLOAT_RW_DEF(func_id, member_id) \
 +static float rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      return mpr->member_id; \
 +} \
 +static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, float value) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      mpr->member_id = value; \
 +}
 +#define RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_INDEX_RW_DEF(func_id, member_id, index) \
 +static float rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      return mpr->member_id[index]; \
 +} \
 +static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, float value) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      mpr->member_id[index] = value; \
 +}
 +/* wmManipulator.float[len] */
 +#define RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(func_id, member_id, len) \
 +static void rna_Manipulator_##func_id##_get(PointerRNA *ptr, float value[len]) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      memcpy(value, mpr->member_id, sizeof(float[len])); \
 +} \
 +static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, const float value[len]) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      memcpy(mpr->member_id, value, sizeof(float[len])); \
 +}
 +
 +/* wmManipulator.flag */
 +#define RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(func_id, member_id, flag_value) \
- static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, int value) \
++static bool rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      return (mpr->member_id & flag_value) != 0; \
 +} \
- static int rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
++static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, bool value) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      SET_FLAG_FROM_TEST(mpr->member_id, value, flag_value); \
 +}
 +
 +/* wmManipulator.flag (negative) */
 +#define RNA_MANIPULATOR_GENERIC_FLAG_NEG_RW_DEF(func_id, member_id, flag_value) \
- static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, int value) \
++static bool rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      return (mpr->member_id & flag_value) == 0; \
 +} \
- static void rna_Manipulator_state_select_set(struct PointerRNA *ptr, int value)
++static void rna_Manipulator_##func_id##_set(PointerRNA *ptr, bool value) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      SET_FLAG_FROM_TEST(mpr->member_id, !value, flag_value); \
 +}
 +
 +#define RNA_MANIPULATOR_FLAG_RO_DEF(func_id, member_id, flag_value) \
 +static int rna_Manipulator_##func_id##_get(PointerRNA *ptr) \
 +{ \
 +      wmManipulator *mpr = ptr->data; \
 +      return (mpr->member_id & flag_value) != 0; \
 +}
 +
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(color, color, 3);
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(color_hi, color_hi, 3);
 +
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_INDEX_RW_DEF(alpha, color, 3);
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_INDEX_RW_DEF(alpha_hi, color_hi, 3);
 +
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(matrix_space, matrix_space, 16);
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(matrix_basis, matrix_basis, 16);
 +RNA_MANIPULATOR_GENERIC_FLOAT_ARRAY_RW_DEF(matrix_offset, matrix_offset, 16);
 +
 +static void rna_Manipulator_matrix_world_get(PointerRNA *ptr, float value[16])
 +{
 +      wmManipulator *mpr = ptr->data;
 +      WM_manipulator_calc_matrix_final(mpr, (float (*)[4])value);
 +}
 +
 +RNA_MANIPULATOR_GENERIC_FLOAT_RW_DEF(scale_basis, scale_basis);
 +RNA_MANIPULATOR_GENERIC_FLOAT_RW_DEF(line_width, line_width);
 +
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_use_draw_hover, flag, WM_MANIPULATOR_DRAW_HOVER);
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_use_draw_modal, flag, WM_MANIPULATOR_DRAW_MODAL);
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_use_draw_value, flag, WM_MANIPULATOR_DRAW_VALUE);
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_use_draw_offset_scale, flag, WM_MANIPULATOR_DRAW_OFFSET_SCALE);
 +RNA_MANIPULATOR_GENERIC_FLAG_NEG_RW_DEF(flag_use_draw_scale, flag, WM_MANIPULATOR_DRAW_OFFSET_SCALE);
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_hide, flag, WM_MANIPULATOR_HIDDEN);
 +RNA_MANIPULATOR_GENERIC_FLAG_RW_DEF(flag_use_grab_cursor, flag, WM_MANIPULATOR_GRAB_CURSOR);
 +
 +/* wmManipulator.state */
 +RNA_MANIPULATOR_FLAG_RO_DEF(state_is_highlight, state, WM_MANIPULATOR_STATE_HIGHLIGHT);
 +RNA_MANIPULATOR_FLAG_RO_DEF(state_is_modal, state, WM_MANIPULATOR_STATE_MODAL);
 +RNA_MANIPULATOR_FLAG_RO_DEF(state_select, state, WM_MANIPULATOR_STATE_SELECT);
 +
- static int rna_ManipulatorGroup_has_reports_get(PointerRNA *ptr)
++static void rna_Manipulator_state_select_set(struct PointerRNA *ptr, bool value)
 +{
 +      wmManipulator *mpr = ptr->data;
 +      wmManipulatorGroup *mgroup = mpr->parent_mgroup;
 +      WM_manipulator_select_set(mgroup->parent_mmap, mpr, value);
 +}
 +
 +static PointerRNA rna_Manipulator_group_get(PointerRNA *ptr)
 +{
 +      wmManipulator *mpr = ptr->data;
 +      return rna_pointer_inherit_refine(ptr, &RNA_ManipulatorGroup, mpr->parent_mgroup);
 +}
 +
 +#ifdef WITH_PYTHON
 +
 +static void rna_Manipulator_unregister(struct Main *bmain, StructRNA *type);
 +void BPY_RNA_manipulator_wrapper(wmManipulatorType *wgt, void *userdata);
 +
 +static StructRNA *rna_Manipulator_register(
 +        Main *bmain, ReportList *reports, void *data, const char *identifier,
 +        StructValidateFunc validate, StructCallbackFunc call, StructFreeFunc free)
 +{
 +      struct {
 +              char idname[MAX_NAME];
 +      } temp_buffers;
 +
 +      wmManipulatorType dummywt = {NULL};
 +      wmManipulator dummymnp = {NULL};
 +      PointerRNA mnp_ptr;
 +
 +      /* Two sets of functions. */
 +      int have_function[8];
 +
 +      /* setup dummy manipulator & manipulator type to store static properties in */
 +      dummymnp.type = &dummywt;
 +      dummywt.idname = temp_buffers.idname;
 +      RNA_pointer_create(NULL, &RNA_Manipulator, &dummymnp, &mnp_ptr);
 +
 +      /* Clear so we can detect if it's left unset. */
 +      temp_buffers.idname[0] = '\0';
 +
 +      /* validate the python class */
 +      if (validate(&mnp_ptr, data, have_function) != 0)
 +              return NULL;
 +
 +      if (strlen(identifier) >= sizeof(temp_buffers.idname)) {
 +              BKE_reportf(reports, RPT_ERROR, "Registering manipulator class: '%s' is too long, maximum length is %d",
 +                          identifier, (int)sizeof(temp_buffers.idname));
 +              return NULL;
 +      }
 +
 +      /* check if we have registered this manipulator type before, and remove it */
 +      {
 +              const wmManipulatorType *wt = WM_manipulatortype_find(dummywt.idname, true);
 +              if (wt && wt->ext.srna) {
 +                      rna_Manipulator_unregister(bmain, wt->ext.srna);
 +              }
 +      }
 +      if (!RNA_struct_available_or_report(reports, dummywt.idname)) {
 +              return NULL;
 +      }
 +
 +      {   /* allocate the idname */
 +              /* For multiple strings see ManipulatorGroup. */
 +              dummywt.idname = BLI_strdup(temp_buffers.idname);
 +      }
 +
 +      /* create a new manipulator type */
 +      dummywt.ext.srna = RNA_def_struct_ptr(&BLENDER_RNA, dummywt.idname, &RNA_Manipulator);
 +      /* manipulator properties are registered separately */
 +      RNA_def_struct_flag(dummywt.ext.srna, STRUCT_NO_IDPROPERTIES);
 +      dummywt.ext.data = data;
 +      dummywt.ext.call = call;
 +      dummywt.ext.free = free;
 +
 +      {
 +              int i = 0;
 +              dummywt.draw = (have_function[i++]) ? rna_manipulator_draw_cb : NULL;
 +              dummywt.draw_select = (have_function[i++]) ? rna_manipulator_draw_select_cb : NULL;
 +              dummywt.test_select = (have_function[i++]) ? rna_manipulator_test_select_cb : NULL;
 +              dummywt.modal = (have_function[i++]) ? rna_manipulator_modal_cb : NULL;
 +//            dummywt.property_update = (have_function[i++]) ? rna_manipulator_property_update : NULL;
 +//            dummywt.position_get = (have_function[i++]) ? rna_manipulator_position_get : NULL;
 +              dummywt.setup = (have_function[i++]) ? rna_manipulator_setup_cb : NULL;
 +              dummywt.invoke = (have_function[i++]) ? rna_manipulator_invoke_cb : NULL;
 +              dummywt.exit = (have_function[i++]) ? rna_manipulator_exit_cb : NULL;
 +              dummywt.select_refresh = (have_function[i++]) ? rna_manipulator_select_refresh_cb : NULL;
 +
 +              BLI_assert(i == ARRAY_SIZE(have_function));
 +      }
 +
 +      WM_manipulatortype_append_ptr(BPY_RNA_manipulator_wrapper, (void *)&dummywt);
 +
 +      /* update while blender is running */
 +      WM_main_add_notifier(NC_SCREEN | NA_EDITED, NULL);
 +
 +      return dummywt.ext.srna;
 +}
 +
 +static void rna_Manipulator_unregister(struct Main *bmain, StructRNA *type)
 +{
 +      wmManipulatorType *wt = RNA_struct_blender_type_get(type);
 +
 +      if (!wt)
 +              return;
 +
 +      RNA_struct_free_extension(type, &wt->ext);
 +      RNA_struct_free(&BLENDER_RNA, type);
 +
 +      WM_main_add_notifier(NC_SCREEN | NA_EDITED, NULL);
 +
 +      WM_manipulatortype_remove_ptr(NULL, bmain, wt);
 +}
 +
 +static void **rna_Manipulator_instance(PointerRNA *ptr)
 +{
 +      wmManipulator *mpr = ptr->data;
 +      return &mpr->py_instance;
 +}
 +
 +#endif  /* WITH_PYTHON */
 +
 +
 +static StructRNA *rna_Manipulator_refine(PointerRNA *mnp_ptr)
 +{
 +      wmManipulator *mpr = mnp_ptr->data;
 +      return (mpr->type && mpr->type->ext.srna) ? mpr->type->ext.srna : &RNA_Manipulator;
 +}
 +
 +/** \} */
 +
 +/** \name Manipulator Group API
 + * \{ */
 +
 +static wmManipulator *rna_ManipulatorGroup_manipulator_new(
 +        wmManipulatorGroup *mgroup, ReportList *reports, const char *idname)
 +{
 +      const wmManipulatorType *wt = WM_manipulatortype_find(idname, true);
 +      if (wt == NULL) {
 +              BKE_reportf(reports, RPT_ERROR, "ManipulatorType '%s' not known", idname);
 +              return NULL;
 +      }
 +      wmManipulator *mpr = WM_manipulator_new_ptr(wt, mgroup, NULL);
 +      return mpr;
 +}
 +
 +static void rna_ManipulatorGroup_manipulator_remove(
 +        wmManipulatorGroup *mgroup, bContext *C, wmManipulator *mpr)
 +{
 +      WM_manipulator_unlink(&mgroup->manipulators, mgroup->parent_mmap, mpr, C);
 +}
 +
 +static void rna_ManipulatorGroup_manipulator_clear(
 +        wmManipulatorGroup *mgroup, bContext *C)
 +{
 +      while (mgroup->manipulators.first) {
 +              WM_manipulator_unlink(&mgroup->manipulators, mgroup->parent_mmap, mgroup->manipulators.first, C);
 +      }
 +}
 +
 +static void rna_ManipulatorGroup_name_get(PointerRNA *ptr, char *value)
 +{
 +      wmManipulatorGroup *mgroup = ptr->data;
 +      strcpy(value, mgroup->type->name);
 +}
 +
 +static int rna_ManipulatorGroup_name_length(PointerRNA *ptr)
 +{
 +      wmManipulatorGroup *mgroup = ptr->data;
 +      return strlen(mgroup->type->name);
 +}
 +
 +/* just to work around 'const char *' warning and to ensure this is a python op */
 +static void rna_ManipulatorGroup_bl_idname_set(PointerRNA *ptr, const char *value)
 +{
 +      wmManipulatorGroup *data = ptr->data;
 +      char *str = (char *)data->type->idname;
 +      if (!str[0])
 +              BLI_strncpy(str, value, MAX_NAME);    /* utf8 already ensured */
 +      else
 +              assert(!"setting the bl_idname on a non-builtin operator");
 +}
 +
 +static void rna_ManipulatorGroup_bl_label_set(PointerRNA *ptr, const char *value)
 +{
 +      wmManipulatorGroup *data = ptr->data;
 +      char *str = (char *)data->type->name;
 +      if (!str[0])
 +              BLI_strncpy(str, value, MAX_NAME);    /* utf8 already ensured */
 +      else
 +              assert(!"setting the bl_label on a non-builtin operator");
 +}
 +
++static bool rna_ManipulatorGroup_has_reports_get(PointerRNA *ptr)
 +{
 +      wmManipulatorGroup *mgroup = ptr->data;
 +      return (mgroup->reports && mgroup->reports->list.first);
 +}
 +
 +#ifdef WITH_PYTHON
 +
 +static bool rna_manipulatorgroup_poll_cb(const bContext *C, wmManipulatorGroupType *wgt)
 +{
 +
 +      extern FunctionRNA rna_ManipulatorGroup_poll_func;
 +
 +      PointerRNA ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +      void *ret;
 +      int visible;
 +
 +      RNA_pointer_create(NULL, wgt->ext.srna, NULL, &ptr); /* dummy */
 +      func = &rna_ManipulatorGroup_poll_func; /* RNA_struct_find_function(&ptr, "poll"); */
 +
 +      RNA_parameter_list_create(&list, &ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      wgt->ext.call((bContext *)C, &ptr, func, &list);
 +
 +      RNA_parameter_get_lookup(&list, "visible", &ret);
 +      visible = *(int *)ret;
 +
 +      RNA_parameter_list_free(&list);
 +
 +      return visible;
 +}
 +
 +static void rna_manipulatorgroup_setup_cb(const bContext *C, wmManipulatorGroup *mgroup)
 +{
 +      extern FunctionRNA rna_ManipulatorGroup_setup_func;
 +
 +      PointerRNA mgroup_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +
 +      RNA_pointer_create(NULL, mgroup->type->ext.srna, mgroup, &mgroup_ptr);
 +      func = &rna_ManipulatorGroup_setup_func; /* RNA_struct_find_function(&wgroupr, "setup"); */
 +
 +      RNA_parameter_list_create(&list, &mgroup_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      mgroup->type->ext.call((bContext *)C, &mgroup_ptr, func, &list);
 +
 +      RNA_parameter_list_free(&list);
 +}
 +
 +static wmKeyMap *rna_manipulatorgroup_setup_keymap_cb(const wmManipulatorGroupType *wgt, wmKeyConfig *config)
 +{
 +      extern FunctionRNA rna_ManipulatorGroup_setup_keymap_func;
 +      void *ret;
 +
 +      PointerRNA ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +
 +      RNA_pointer_create(NULL, wgt->ext.srna, NULL, &ptr); /* dummy */
 +      func = &rna_ManipulatorGroup_setup_keymap_func; /* RNA_struct_find_function(&wgroupr, "setup_keymap"); */
 +
 +      RNA_parameter_list_create(&list, &ptr, func);
 +      RNA_parameter_set_lookup(&list, "keyconfig", &config);
 +      wgt->ext.call(NULL, &ptr, func, &list);
 +
 +      RNA_parameter_get_lookup(&list, "keymap", &ret);
 +      wmKeyMap *keymap = *(wmKeyMap **)ret;
 +
 +      RNA_parameter_list_free(&list);
 +
 +      return keymap;
 +}
 +
 +static void rna_manipulatorgroup_refresh_cb(const bContext *C, wmManipulatorGroup *mgroup)
 +{
 +      extern FunctionRNA rna_ManipulatorGroup_refresh_func;
 +
 +      PointerRNA mgroup_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +
 +      RNA_pointer_create(NULL, mgroup->type->ext.srna, mgroup, &mgroup_ptr);
 +      func = &rna_ManipulatorGroup_refresh_func; /* RNA_struct_find_function(&wgroupr, "refresh"); */
 +
 +      RNA_parameter_list_create(&list, &mgroup_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      mgroup->type->ext.call((bContext *)C, &mgroup_ptr, func, &list);
 +
 +      RNA_parameter_list_free(&list);
 +}
 +
 +static void rna_manipulatorgroup_draw_prepare_cb(const bContext *C, wmManipulatorGroup *mgroup)
 +{
 +      extern FunctionRNA rna_ManipulatorGroup_draw_prepare_func;
 +
 +      PointerRNA mgroup_ptr;
 +      ParameterList list;
 +      FunctionRNA *func;
 +
 +      RNA_pointer_create(NULL, mgroup->type->ext.srna, mgroup, &mgroup_ptr);
 +      func = &rna_ManipulatorGroup_draw_prepare_func; /* RNA_struct_find_function(&wgroupr, "draw_prepare"); */
 +
 +      RNA_parameter_list_create(&list, &mgroup_ptr, func);
 +      RNA_parameter_set_lookup(&list, "context", &C);
 +      mgroup->type->ext.call((bContext *)C, &mgroup_ptr, func, &list);
 +
 +      RNA_parameter_list_free(&list);
 +}
 +
 +void BPY_RNA_manipulatorgroup_wrapper(wmManipulatorGroupType *wgt, void *userdata);
 +static void rna_ManipulatorGroup_unregister(struct Main *bmain, StructRNA *type);
 +
 +static StructRNA *rna_ManipulatorGroup_register(
 +        Main *bmain, ReportList *reports, void *data, const char *identifier,
 +        StructValidateFunc validate, StructCallbackFunc call, StructFreeFunc free)
 +{
 +      struct {
 +              char name[MAX_NAME];
 +              char idname[MAX_NAME];
 +      } temp_buffers;
 +
 +      wmManipulatorGroupType dummywgt = {NULL};
 +      wmManipulatorGroup dummywg = {NULL};
 +      PointerRNA wgptr;
 +
 +      /* Two sets of functions. */
 +      int have_function[5];
 +
 +      /* setup dummy manipulatorgroup & manipulatorgroup type to store static properties in */
 +      dummywg.type = &dummywgt;
 +      dummywgt.name = temp_buffers.name;
 +      dummywgt.idname = temp_buffers.idname;
 +
 +      RNA_pointer_create(NULL, &RNA_ManipulatorGroup, &dummywg, &wgptr);
 +
 +      /* Clear so we can detect if it's left unset. */
 +      temp_buffers.idname[0] = temp_buffers.name[0] = '\0';
 +
 +      /* validate the python class */
 +      if (validate(&wgptr, data, have_function) != 0)
 +              return NULL;
 +
 +      if (strlen(identifier) >= sizeof(temp_buffers.idname)) {
 +              BKE_reportf(reports, RPT_ERROR, "Registering manipulatorgroup class: '%s' is too long, maximum length is %d",
 +                          identifier, (int)sizeof(temp_buffers.idname));
 +              return NULL;
 +      }
 +
 +      /* check if the area supports widgets */
 +      const struct wmManipulatorMapType_Params wmap_params = {
 +              .spaceid = dummywgt.mmap_params.spaceid,
 +              .regionid = dummywgt.mmap_params.regionid,
 +      };
 +
 +      wmManipulatorMapType *mmap_type = WM_manipulatormaptype_ensure(&wmap_params);
 +      if (mmap_type == NULL) {
 +              BKE_reportf(reports, RPT_ERROR, "Area type does not support manipulators");
 +              return NULL;
 +      }
 +
 +      /* check if we have registered this manipulatorgroup type before, and remove it */
 +      {
 +              wmManipulatorGroupType *wgt = WM_manipulatorgrouptype_find(dummywgt.idname, true);
 +              if (wgt && wgt->ext.srna) {
 +                      rna_ManipulatorGroup_unregister(bmain, wgt->ext.srna);
 +              }
 +      }
 +      if (!RNA_struct_available_or_report(reports, dummywgt.idname)) {
 +              return NULL;
 +      }
 +
 +      {   /* allocate the idname */
 +              const char *strings[] = {
 +                      temp_buffers.idname,
 +                      temp_buffers.name,
 +              };
 +              char *strings_table[ARRAY_SIZE(strings)];
 +              BLI_string_join_array_by_sep_char_with_tableN('\0', strings_table, strings, ARRAY_SIZE(strings));
 +
 +              dummywgt.idname = strings_table[0];  /* allocated string stored here */
 +              dummywgt.name = strings_table[1];
 +              BLI_assert(ARRAY_SIZE(strings) == 2);
 +      }
 +
 +      /* create a new manipulatorgroup type */
 +      dummywgt.ext.srna = RNA_def_struct_ptr(&BLENDER_RNA, dummywgt.idname, &RNA_ManipulatorGroup);
 +      RNA_def_struct_flag(dummywgt.ext.srna, STRUCT_NO_IDPROPERTIES); /* manipulatorgroup properties are registered separately */
 +      dummywgt.ext.data = data;
 +      dummywgt.ext.call = call;
 +      dummywgt.ext.free = free;
 +
 +      /* We used to register widget group types like this, now we do it similar to
 +       * operator types. Thus we should be able to do the same as operator types now. */
 +      dummywgt.poll = (have_function[0]) ? rna_manipulatorgroup_poll_cb : NULL;
 +      dummywgt.setup_keymap =     (have_function[1]) ? rna_manipulatorgroup_setup_keymap_cb : NULL;
 +      dummywgt.setup =            (have_function[2]) ? rna_manipulatorgroup_setup_cb : NULL;
 +      dummywgt.refresh =          (have_function[3]) ? rna_manipulatorgroup_refresh_cb : NULL;
 +      dummywgt.draw_prepare =     (have_function[4]) ? rna_manipulatorgroup_draw_prepare_cb : NULL;
 +
 +      wmManipulatorGroupType *wgt = WM_manipulatorgrouptype_append_ptr(
 +              BPY_RNA_manipulatorgroup_wrapper, (void *)&dummywgt);
 +
 +      {
 +              const char *owner_id = RNA_struct_state_owner_get();
 +              if (owner_id) {
 +                      BLI_strncpy(wgt->owner_id, owner_id, sizeof(wgt->owner_id));
 +              }
 +      }
 +
 +      if (wgt->flag & WM_MANIPULATORGROUPTYPE_PERSISTENT) {
 +              WM_manipulator_group_type_add_ptr_ex(wgt, mmap_type);
 +
 +              /* update while blender is running */
 +              WM_main_add_notifier(NC_SCREEN | NA_EDITED, NULL);
 +      }
 +
 +      return dummywgt.ext.srna;
 +}
 +
 +static void rna_ManipulatorGroup_unregister(struct Main *bmain, StructRNA *type)
 +{
 +      wmManipulatorGroupType *wgt = RNA_struct_blender_type_get(type);
 +
 +      if (!wgt)
 +              return;
 +
 +      RNA_struct_free_extension(type, &wgt->ext);
 +      RNA_struct_free(&BLENDER_RNA, type);
 +
 +      WM_main_add_notifier(NC_SCREEN | NA_EDITED, NULL);
 +
 +      WM_manipulator_group_type_remove_ptr(bmain, wgt);
 +}
 +
 +static void **rna_ManipulatorGroup_instance(PointerRNA *ptr)
 +{
 +      wmManipulatorGroup *mgroup = ptr->data;
 +      return &mgroup->py_instance;
 +}
 +
 +#endif  /* WITH_PYTHON */
 +
 +static StructRNA *rna_ManipulatorGroup_refine(PointerRNA *mgroup_ptr)
 +{
 +      wmManipulatorGroup *mgroup = mgroup_ptr->data;
 +      return (mgroup->type && mgroup->type->ext.srna) ? mgroup->type->ext.srna : &RNA_ManipulatorGroup;
 +}
 +
 +static void rna_ManipulatorGroup_manipulators_begin(CollectionPropertyIterator *iter, PointerRNA *mgroup_ptr)
 +{
 +      wmManipulatorGroup *mgroup = mgroup_ptr->data;
 +      rna_iterator_listbase_begin(iter, &mgroup->manipulators, NULL);
 +}
 +
 +/** \} */
 +
 +
 +#else /* RNA_RUNTIME */
 +
 +
 +/* ManipulatorGroup.manipulators */
 +static void rna_def_manipulators(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
 +
 +      RNA_def_property_srna(cprop, "Manipulators");
 +      srna = RNA_def_struct(brna, "Manipulators", NULL);
 +      RNA_def_struct_sdna(srna, "wmManipulatorGroup");
 +      RNA_def_struct_ui_text(srna, "Manipulators", "Collection of manipulators");
 +
 +      func = RNA_def_function(srna, "new", "rna_ManipulatorGroup_manipulator_new");
 +      RNA_def_function_ui_description(func, "Add manipulator");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      RNA_def_string(func, "type", "Type", 0, "", "Manipulator identifier"); /* optional */
 +      parm = RNA_def_pointer(func, "manipulator", "Manipulator", "", "New manipulator");
 +      RNA_def_function_return(func, parm);
 +
 +      func = RNA_def_function(srna, "remove", "rna_ManipulatorGroup_manipulator_remove");
 +      RNA_def_function_flag(func, FUNC_USE_CONTEXT);
 +      RNA_def_function_ui_description(func, "Delete manipulator");
 +      parm = RNA_def_pointer(func, "manipulator", "Manipulator", "", "New manipulator");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      RNA_def_parameter_clear_flags(parm, PROP_THICK_WRAP, 0);
 +
 +      func = RNA_def_function(srna, "clear", "rna_ManipulatorGroup_manipulator_clear");
 +      RNA_def_function_flag(func, FUNC_USE_CONTEXT);
 +      RNA_def_function_ui_description(func, "Delete all manipulators");
 +}
 +
 +
 +static void rna_def_manipulator(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
 +
 +      RNA_def_property_srna(cprop, "Manipulator");
 +      srna = RNA_def_struct(brna, "Manipulator", NULL);
 +      RNA_def_struct_sdna(srna, "wmManipulator");
 +      RNA_def_struct_ui_text(srna, "Manipulator", "Collection of manipulators");
 +      RNA_def_struct_refine_func(srna, "rna_Manipulator_refine");
 +
 +#ifdef WITH_PYTHON
 +      RNA_def_struct_register_funcs(
 +              srna,
 +              "rna_Manipulator_register",
 +              "rna_Manipulator_unregister",
 +              "rna_Manipulator_instance");
 +#endif
 +      RNA_def_struct_translation_context(srna, BLT_I18NCONTEXT_OPERATOR_DEFAULT);
 +
 +      prop = RNA_def_property(srna, "properties", PROP_POINTER, PROP_NONE);
 +      RNA_def_property_flag(prop, PROP_NEVER_NULL);
 +      RNA_def_property_struct_type(prop, "ManipulatorProperties");
 +      RNA_def_property_ui_text(prop, "Properties", "");
 +      RNA_def_property_pointer_funcs(prop, "rna_Manipulator_properties_get", NULL, NULL, NULL);
 +
 +      /* -------------------------------------------------------------------- */
 +      /* Registerable Variables */
 +
 +      RNA_define_verify_sdna(0); /* not in sdna */
 +
 +      prop = RNA_def_property(srna, "bl_idname", PROP_STRING, PROP_NONE);
 +      RNA_def_property_string_sdna(prop, NULL, "type->idname");
 +      RNA_def_property_string_maxlength(prop, MAX_NAME);
 +      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Manipulator_bl_idname_set");
 +      /* RNA_def_property_clear_flag(prop, PROP_EDITABLE); */
 +      RNA_def_property_flag(prop, PROP_REGISTER);
 +
 +      RNA_define_verify_sdna(1); /* not in sdna */
 +
 +      /* wmManipulator.draw */
 +      func = RNA_def_function(srna, "draw", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
 +      /* wmManipulator.draw_select */
 +      func = RNA_def_function(srna, "draw_select", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_int(func, "select_id", 0, 0, INT_MAX, "", "", 0, INT_MAX);
 +
 +      /* wmManipulator.test_select */
 +      func = RNA_def_function(srna, "test_select", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_pointer(func, "event", "Event", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_int(func, "intersect_id", 0, 0, INT_MAX, "", "", 0, INT_MAX);
 +      RNA_def_function_return(func, parm);
 +
 +      /* wmManipulator.handler */
 +      static EnumPropertyItem tweak_actions[] = {
 +              {WM_MANIPULATOR_TWEAK_PRECISE, "PRECISE", 0, "Precise", ""},
 +              {WM_MANIPULATOR_TWEAK_SNAP, "SNAP", 0, "Snap", ""},
 +              {0, NULL, 0, NULL, NULL}
 +      };
 +      func = RNA_def_function(srna, "modal", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL | FUNC_ALLOW_WRITE);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_pointer(func, "event", "Event", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      /* TODO, shuold be a enum-flag */
 +      parm = RNA_def_enum_flag(func, "tweak", tweak_actions, 0, "Tweak", "");
 +      RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
 +      parm = RNA_def_enum_flag(func, "result", rna_enum_operator_return_items, OPERATOR_CANCELLED, "result", "");
 +      RNA_def_function_return(func, parm);
 +      /* wmManipulator.property_update */
 +      /* TODO */
 +
 +      /* wmManipulator.setup */
 +      func = RNA_def_function(srna, "setup", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL | FUNC_ALLOW_WRITE);
 +
 +      /* wmManipulator.invoke */
 +      func = RNA_def_function(srna, "invoke", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL | FUNC_ALLOW_WRITE);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_pointer(func, "event", "Event", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_enum_flag(func, "result", rna_enum_operator_return_items, OPERATOR_CANCELLED, "result", "");
 +      RNA_def_function_return(func, parm);
 +
 +      /* wmManipulator.exit */
 +      func = RNA_def_function(srna, "exit", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL | FUNC_ALLOW_WRITE);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      parm = RNA_def_boolean(func, "cancel", 0, "Cancel, otherwise confirm", "");
 +      RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
 +
 +      /* wmManipulator.cursor_get */
 +      /* TODO */
 +
 +      /* wmManipulator.select_refresh */
 +      func = RNA_def_function(srna, "select_refresh", NULL);
 +      RNA_def_function_ui_description(func, "");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL | FUNC_ALLOW_WRITE);
 +
 +
 +      /* -------------------------------------------------------------------- */
 +      /* Instance Variables */
 +
 +      prop = RNA_def_property(srna, "group", PROP_POINTER, PROP_NONE);
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_struct_type(prop, "ManipulatorGroup");
 +      RNA_def_property_pointer_funcs(prop, "rna_Manipulator_group_get", NULL, NULL, NULL);
 +      RNA_def_property_ui_text(prop, "", "Manipulator group this manipulator is a member of");
 +
 +      /* Color & Alpha */
 +      prop = RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
 +      RNA_def_property_array(prop, 3);
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_color_get", "rna_Manipulator_color_set", NULL);
 +
 +      prop = RNA_def_property(srna, "alpha", PROP_FLOAT, PROP_NONE);
 +      RNA_def_property_ui_text(prop, "Alpha", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_alpha_get", "rna_Manipulator_alpha_set", NULL);
 +      RNA_def_property_range(prop, 0.0f, 1.0f);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      /* Color & Alpha (highlight) */
 +      prop = RNA_def_property(srna, "color_highlight", PROP_FLOAT, PROP_COLOR);
 +      RNA_def_property_array(prop, 3);
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_color_hi_get", "rna_Manipulator_color_hi_set", NULL);
 +
 +      prop = RNA_def_property(srna, "alpha_highlight", PROP_FLOAT, PROP_NONE);
 +      RNA_def_property_ui_text(prop, "Alpha", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_alpha_hi_get", "rna_Manipulator_alpha_hi_set", NULL);
 +      RNA_def_property_range(prop, 0.0f, 1.0f);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      prop = RNA_def_property(srna, "matrix_space", PROP_FLOAT, PROP_MATRIX);
 +      RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
 +      RNA_def_property_ui_text(prop, "Space Matrix", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_matrix_space_get", "rna_Manipulator_matrix_space_set", NULL);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      prop = RNA_def_property(srna, "matrix_basis", PROP_FLOAT, PROP_MATRIX);
 +      RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
 +      RNA_def_property_ui_text(prop, "Basis Matrix", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_matrix_basis_get", "rna_Manipulator_matrix_basis_set", NULL);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      prop = RNA_def_property(srna, "matrix_offset", PROP_FLOAT, PROP_MATRIX);
 +      RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
 +      RNA_def_property_ui_text(prop, "Offset Matrix", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_matrix_offset_get", "rna_Manipulator_matrix_offset_set", NULL);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      prop = RNA_def_property(srna, "matrix_world", PROP_FLOAT, PROP_MATRIX);
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
 +      RNA_def_property_ui_text(prop, "Final World Matrix", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_matrix_world_get", NULL, NULL);
 +
 +      prop = RNA_def_property(srna, "scale_basis", PROP_FLOAT, PROP_NONE);
 +      RNA_def_property_ui_text(prop, "Scale Basis", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_scale_basis_get", "rna_Manipulator_scale_basis_set", NULL);
 +      RNA_def_property_range(prop, 0.0f, FLT_MAX);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      prop = RNA_def_property(srna, "line_width", PROP_FLOAT, PROP_PIXEL);
 +      RNA_def_property_ui_text(prop, "Line Width", "");
 +      RNA_def_property_float_funcs(prop, "rna_Manipulator_line_width_get", "rna_Manipulator_line_width_set", NULL);
 +      RNA_def_property_range(prop, 0.0f, FLT_MAX);
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      /* wmManipulator.flag */
 +      /* WM_MANIPULATOR_HIDDEN */
 +      prop = RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_hide_get", "rna_Manipulator_flag_hide_set");
 +      RNA_def_property_ui_text(prop, "Hide", "");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +      /* WM_MANIPULATOR_GRAB_CURSOR */
 +      prop = RNA_def_property(srna, "use_grab_cursor", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_grab_cursor_get", "rna_Manipulator_flag_use_grab_cursor_set");
 +      RNA_def_property_ui_text(prop, "Grab Cursor", "");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      /* WM_MANIPULATOR_DRAW_HOVER */
 +      prop = RNA_def_property(srna, "use_draw_hover", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_draw_hover_get", "rna_Manipulator_flag_use_draw_hover_set");
 +      RNA_def_property_ui_text(prop, "Draw Hover", "");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +      /* WM_MANIPULATOR_DRAW_MODAL */
 +      prop = RNA_def_property(srna, "use_draw_modal", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_draw_modal_get", "rna_Manipulator_flag_use_draw_modal_set");
 +      RNA_def_property_ui_text(prop, "Draw Active", "Draw while dragging");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +      /* WM_MANIPULATOR_DRAW_VALUE */
 +      prop = RNA_def_property(srna, "use_draw_value", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_draw_value_get", "rna_Manipulator_flag_use_draw_value_set");
 +      RNA_def_property_ui_text(prop, "Draw Value", "Show an indicator for the current value while dragging");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +      /* WM_MANIPULATOR_DRAW_OFFSET_SCALE */
 +      prop = RNA_def_property(srna, "use_draw_offset_scale", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_draw_offset_scale_get", "rna_Manipulator_flag_use_draw_offset_scale_set");
 +      RNA_def_property_ui_text(prop, "Scale Offset", "Scale the offset matrix (use to apply screen-space offset)");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +      /* WM_MANIPULATOR_DRAW_NO_SCALE (negated) */
 +      prop = RNA_def_property(srna, "use_draw_scale", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(
 +              prop, "rna_Manipulator_flag_use_draw_scale_get", "rna_Manipulator_flag_use_draw_scale_set");
 +      RNA_def_property_ui_text(prop, "Scale", "Use scale when calculating the matrix");
 +      RNA_def_property_update(prop, NC_SCREEN | NA_EDITED, NULL);
 +
 +      /* wmManipulator.state (readonly) */
 +      /* WM_MANIPULATOR_STATE_HIGHLIGHT */
 +      prop = RNA_def_property(srna, "is_highlight", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(prop, "rna_Manipulator_state_is_highlight_get", NULL);
 +      RNA_def_property_ui_text(prop, "Highlight", "");
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      /* WM_MANIPULATOR_STATE_MODAL */
 +      prop = RNA_def_property(srna, "is_modal", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(prop, "rna_Manipulator_state_is_modal_get", NULL);
 +      RNA_def_property_ui_text(prop, "Highlight", "");
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      /* WM_MANIPULATOR_STATE_SELECT */
 +      /* (note that setting is involved, needs to handle array) */
 +      prop = RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(prop, "rna_Manipulator_state_select_get", "rna_Manipulator_state_select_set");
 +      RNA_def_property_ui_text(prop, "Select", "");
 +
 +      RNA_api_manipulator(srna);
 +
 +      srna = RNA_def_struct(brna, "ManipulatorProperties", NULL);
 +      RNA_def_struct_ui_text(srna, "Manipulator Properties", "Input properties of an Manipulator");
 +      RNA_def_struct_refine_func(srna, "rna_ManipulatorProperties_refine");
 +      RNA_def_struct_idprops_func(srna, "rna_ManipulatorProperties_idprops");
 +      RNA_def_struct_flag(srna, STRUCT_NO_DATABLOCK_IDPROPERTIES);
 +}
 +
 +static void rna_def_manipulatorgroup(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
 +
 +      srna = RNA_def_struct(brna, "ManipulatorGroup", NULL);
 +      RNA_def_struct_ui_text(srna, "ManipulatorGroup", "Storage of an operator being executed, or registered after execution");
 +      RNA_def_struct_sdna(srna, "wmManipulatorGroup");
 +      RNA_def_struct_refine_func(srna, "rna_ManipulatorGroup_refine");
 +#ifdef WITH_PYTHON
 +      RNA_def_struct_register_funcs(
 +              srna,
 +              "rna_ManipulatorGroup_register",
 +              "rna_ManipulatorGroup_unregister",
 +              "rna_ManipulatorGroup_instance");
 +#endif
 +      RNA_def_struct_translation_context(srna, BLT_I18NCONTEXT_OPERATOR_DEFAULT);
 +
 +      /* -------------------------------------------------------------------- */
 +      /* Registration */
 +
 +      RNA_define_verify_sdna(0); /* not in sdna */
 +
 +      prop = RNA_def_property(srna, "bl_idname", PROP_STRING, PROP_NONE);
 +      RNA_def_property_string_sdna(prop, NULL, "type->idname");
 +      RNA_def_property_string_maxlength(prop, MAX_NAME);
 +      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_ManipulatorGroup_bl_idname_set");
 +      RNA_def_property_flag(prop, PROP_REGISTER);
 +      RNA_def_struct_name_property(srna, prop);
 +
 +      prop = RNA_def_property(srna, "bl_label", PROP_STRING, PROP_NONE);
 +      RNA_def_property_string_sdna(prop, NULL, "type->name");
 +      RNA_def_property_string_maxlength(prop, MAX_NAME); /* else it uses the pointer size! */
 +      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_ManipulatorGroup_bl_label_set");
 +      /* RNA_def_property_clear_flag(prop, PROP_EDITABLE); */
 +      RNA_def_property_flag(prop, PROP_REGISTER);
 +
 +      prop = RNA_def_property(srna, "bl_space_type", PROP_ENUM, PROP_NONE);
 +      RNA_def_property_enum_sdna(prop, NULL, "type->mmap_params.spaceid");
 +      RNA_def_property_enum_items(prop, rna_enum_space_type_items);
 +      RNA_def_property_flag(prop, PROP_REGISTER);
 +      RNA_def_property_ui_text(prop, "Space type", "The space where the panel is going to be used in");
 +
 +      prop = RNA_def_property(srna, "bl_region_type", PROP_ENUM, PROP_NONE);
 +      RNA_def_property_enum_sdna(prop, NULL, "type->mmap_params.regionid");
 +      RNA_def_property_enum_items(prop, rna_enum_region_type_items);
 +      RNA_def_property_flag(prop, PROP_REGISTER);
 +      RNA_def_property_ui_text(prop, "Region Type", "The region where the panel is going to be used in");
 +
 +      prop = RNA_def_property(srna, "bl_owner_id", PROP_STRING, PROP_NONE);
 +      RNA_def_property_string_sdna(prop, NULL, "type->owner_id");
 +      RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL);
 +
 +      /* bl_options */
 +      static EnumPropertyItem manipulatorgroup_flag_items[] = {
 +              {WM_MANIPULATORGROUPTYPE_3D, "3D", 0, "3D",
 +               "Use in 3D viewport"},
 +              {WM_MANIPULATORGROUPTYPE_SCALE, "SCALE", 0, "Scale",
 +               "Scale to respect zoom (otherwise zoom independent draw size)"},
 +              {WM_MANIPULATORGROUPTYPE_DEPTH_3D, "DEPTH_3D", 0, "Depth 3D",
 +               "Supports culled depth by other objects in the view"},
 +              {WM_MANIPULATORGROUPTYPE_SELECT, "SELECT", 0, "Select",
 +               "Supports selection"},
 +              {WM_MANIPULATORGROUPTYPE_PERSISTENT, "PERSISTENT", 0, "Persistent",
 +               ""},
 +              {WM_MANIPULATORGROUPTYPE_DRAW_MODAL_ALL, "SHOW_MODAL_ALL", 0, "Show Modal All",
 +               "Show all while interacting"},
 +              {0, NULL, 0, NULL, NULL}
 +      };
 +      prop = RNA_def_property(srna, "bl_options", PROP_ENUM, PROP_NONE);
 +      RNA_def_property_enum_sdna(prop, NULL, "type->flag");
 +      RNA_def_property_enum_items(prop, manipulatorgroup_flag_items);
 +      RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL | PROP_ENUM_FLAG);
 +      RNA_def_property_ui_text(prop, "Options",  "Options for this operator type");
 +
 +      RNA_define_verify_sdna(1); /* not in sdna */
 +
 +
 +      /* Functions */
 +
 +      /* poll */
 +      func = RNA_def_function(srna, "poll", NULL);
 +      RNA_def_function_ui_description(func, "Test if the manipulator group can be called or not");
 +      RNA_def_function_flag(func, FUNC_NO_SELF | FUNC_REGISTER_OPTIONAL);
 +      RNA_def_function_return(func, RNA_def_boolean(func, "visible", 1, "", ""));
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
 +      /* setup_keymap */
 +      func = RNA_def_function(srna, "setup_keymap", NULL);
 +      RNA_def_function_ui_description(
 +              func,
 +              "Initialize keymaps for this manipulator group, use fallback keymap when not present");
 +      RNA_def_function_flag(func, FUNC_NO_SELF | FUNC_REGISTER_OPTIONAL);
 +      parm = RNA_def_pointer(func, "keyconfig", "KeyConfig", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      /* return */
 +      parm = RNA_def_pointer(func, "keymap", "KeyMap", "", "");
 +      RNA_def_property_flag(parm, PROP_NEVER_NULL);
 +      RNA_def_function_return(func, parm);
 +
 +      /* setup */
 +      func = RNA_def_function(srna, "setup", NULL);
 +      RNA_def_function_ui_description(func, "Create manipulators function for the manipulator group");
 +      RNA_def_function_flag(func, FUNC_REGISTER);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
 +      /* refresh */
 +      func = RNA_def_function(srna, "refresh", NULL);
 +      RNA_def_function_ui_description(func, "Refresh data (called on common state changes such as selection)");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
 +      func = RNA_def_function(srna, "draw_prepare", NULL);
 +      RNA_def_function_ui_description(func, "Run before each redraw");
 +      RNA_def_function_flag(func, FUNC_REGISTER_OPTIONAL);
 +      parm = RNA_def_pointer(func, "context", "Context", "", "");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
 +      /* -------------------------------------------------------------------- */
 +      /* Instance Variables */
 +
 +      prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_string_funcs(prop, "rna_ManipulatorGroup_name_get", "rna_ManipulatorGroup_name_length", NULL);
 +      RNA_def_property_ui_text(prop, "Name", "");
 +
 +      prop = RNA_def_property(srna, "has_reports", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* this is 'virtual' property */
 +      RNA_def_property_boolean_funcs(prop, "rna_ManipulatorGroup_has_reports_get", NULL);
 +      RNA_def_property_ui_text(prop, "Has Reports",
 +                               "ManipulatorGroup has a set of reports (warnings and errors) from last execution");
 +
 +
 +      RNA_define_verify_sdna(0); /* not in sdna */
 +
 +      prop = RNA_def_property(srna, "manipulators", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "manipulators", NULL);
 +      RNA_def_property_struct_type(prop, "Manipulator");
 +      RNA_def_property_collection_funcs(
 +              prop, "rna_ManipulatorGroup_manipulators_begin", "rna_iterator_listbase_next",
 +              "rna_iterator_listbase_end", "rna_iterator_listbase_get",
 +              NULL, NULL, NULL, NULL);
 +
 +      RNA_def_property_ui_text(prop, "Manipulators", "List of manipulators in the Manipulator Map");
 +      rna_def_manipulator(brna, prop);
 +      rna_def_manipulators(brna, prop);
 +
 +      RNA_define_verify_sdna(1); /* not in sdna */
 +
 +      RNA_api_manipulatorgroup(srna);
 +}
 +
 +void RNA_def_wm_manipulator(BlenderRNA *brna)
 +{
 +      rna_def_manipulatorgroup(brna);
 +}
 +
 +#endif /* RNA_RUNTIME */