Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2019-04-17 07:17:24 +0300
committerCampbell Barton <ideasman42@gmail.com>2019-04-17 07:21:24 +0300
commite12c08e8d170b7ca40f204a5b0423c23a9fbc2c1 (patch)
tree8cf3453d12edb177a218ef8009357518ec6cab6a /source/blender/windowmanager/intern/wm_keymap_utils.c
parentb3dabc200a4b0399ec6b81f2ff2730d07b44fcaa (diff)
ClangFormat: apply to source, most of intern
Apply clang format as proposed in T53211. For details on usage and instructions for migrating branches without conflicts, see: https://wiki.blender.org/wiki/Tools/ClangFormat
Diffstat (limited to 'source/blender/windowmanager/intern/wm_keymap_utils.c')
-rw-r--r--source/blender/windowmanager/intern/wm_keymap_utils.c698
1 files changed, 368 insertions, 330 deletions
diff --git a/source/blender/windowmanager/intern/wm_keymap_utils.c b/source/blender/windowmanager/intern/wm_keymap_utils.c
index 7a5c0d4d2b8..37a7ed4d751 100644
--- a/source/blender/windowmanager/intern/wm_keymap_utils.c
+++ b/source/blender/windowmanager/intern/wm_keymap_utils.c
@@ -43,53 +43,64 @@
* \{ */
/* menu wrapper for WM_keymap_add_item */
-wmKeyMapItem *WM_keymap_add_menu(wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
+wmKeyMapItem *WM_keymap_add_menu(
+ wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
{
- wmKeyMapItem *kmi = WM_keymap_add_item(keymap, "WM_OT_call_menu", type, val, modifier, keymodifier);
- RNA_string_set(kmi->ptr, "name", idname);
- return kmi;
+ wmKeyMapItem *kmi = WM_keymap_add_item(
+ keymap, "WM_OT_call_menu", type, val, modifier, keymodifier);
+ RNA_string_set(kmi->ptr, "name", idname);
+ return kmi;
}
-wmKeyMapItem *WM_keymap_add_menu_pie(wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
+wmKeyMapItem *WM_keymap_add_menu_pie(
+ wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
{
- wmKeyMapItem *kmi = WM_keymap_add_item(keymap, "WM_OT_call_menu_pie", type, val, modifier, keymodifier);
- RNA_string_set(kmi->ptr, "name", idname);
- return kmi;
+ wmKeyMapItem *kmi = WM_keymap_add_item(
+ keymap, "WM_OT_call_menu_pie", type, val, modifier, keymodifier);
+ RNA_string_set(kmi->ptr, "name", idname);
+ return kmi;
}
-wmKeyMapItem *WM_keymap_add_panel(wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
+wmKeyMapItem *WM_keymap_add_panel(
+ wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
{
- wmKeyMapItem *kmi = WM_keymap_add_item(keymap, "WM_OT_call_panel", type, val, modifier, keymodifier);
- RNA_string_set(kmi->ptr, "name", idname);
- /* TODO: we might want to disable this. */
- RNA_boolean_set(kmi->ptr, "keep_open", false);
- return kmi;
+ wmKeyMapItem *kmi = WM_keymap_add_item(
+ keymap, "WM_OT_call_panel", type, val, modifier, keymodifier);
+ RNA_string_set(kmi->ptr, "name", idname);
+ /* TODO: we might want to disable this. */
+ RNA_boolean_set(kmi->ptr, "keep_open", false);
+ return kmi;
}
/* tool wrapper for WM_keymap_add_item */
-wmKeyMapItem *WM_keymap_add_tool(wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
+wmKeyMapItem *WM_keymap_add_tool(
+ wmKeyMap *keymap, const char *idname, int type, int val, int modifier, int keymodifier)
{
- wmKeyMapItem *kmi = WM_keymap_add_item(keymap, "WM_OT_tool_set_by_id", type, val, modifier, keymodifier);
- RNA_string_set(kmi->ptr, "name", idname);
- return kmi;
+ wmKeyMapItem *kmi = WM_keymap_add_item(
+ keymap, "WM_OT_tool_set_by_id", type, val, modifier, keymodifier);
+ RNA_string_set(kmi->ptr, "name", idname);
+ return kmi;
}
/** Useful for mapping numbers to an enum. */
-void WM_keymap_add_context_enum_set_items(
- wmKeyMap *keymap, const EnumPropertyItem *items, const char *data_path,
- int type_start, int val, int modifier, int keymodifier)
+void WM_keymap_add_context_enum_set_items(wmKeyMap *keymap,
+ const EnumPropertyItem *items,
+ const char *data_path,
+ int type_start,
+ int val,
+ int modifier,
+ int keymodifier)
{
- for (int i = 0, type_offset = 0; items[i].identifier; i++) {
- if (items[i].identifier[0] == '\0') {
- continue;
- }
- wmKeyMapItem *kmi = WM_keymap_add_item(
- keymap, "WM_OT_context_set_enum",
- type_start + type_offset, val, modifier, keymodifier);
- RNA_string_set(kmi->ptr, "data_path", data_path);
- RNA_string_set(kmi->ptr, "value", items[i].identifier);
- type_offset += 1;
- }
+ for (int i = 0, type_offset = 0; items[i].identifier; i++) {
+ if (items[i].identifier[0] == '\0') {
+ continue;
+ }
+ wmKeyMapItem *kmi = WM_keymap_add_item(
+ keymap, "WM_OT_context_set_enum", type_start + type_offset, val, modifier, keymodifier);
+ RNA_string_set(kmi->ptr, "data_path", data_path);
+ RNA_string_set(kmi->ptr, "value", items[i].identifier);
+ type_offset += 1;
+ }
}
/** \} */
@@ -100,320 +111,347 @@ void WM_keymap_add_context_enum_set_items(
wmKeyMap *WM_keymap_guess_from_context(const bContext *C)
{
- SpaceLink *sl = CTX_wm_space_data(C);
- const char *km_id = NULL;
- if (sl->spacetype == SPACE_VIEW3D) {
- const enum eContextObjectMode mode = CTX_data_mode_enum(C);
- switch (mode) {
- case CTX_MODE_EDIT_MESH: km_id = "Mesh"; break;
- case CTX_MODE_EDIT_CURVE: km_id = "Curve"; break;
- case CTX_MODE_EDIT_SURFACE: km_id = "Curve"; break;
- case CTX_MODE_EDIT_TEXT: km_id = "Font"; break;
- case CTX_MODE_EDIT_ARMATURE: km_id = "Armature"; break;
- case CTX_MODE_EDIT_METABALL: km_id = "Metaball"; break;
- case CTX_MODE_EDIT_LATTICE: km_id = "Lattice"; break;
- case CTX_MODE_POSE: km_id = "Pose"; break;
- case CTX_MODE_SCULPT: km_id = "Sculpt"; break;
- case CTX_MODE_PAINT_WEIGHT: km_id = "Weight Paint"; break;
- case CTX_MODE_PAINT_VERTEX: km_id = "Vertex Paint"; break;
- case CTX_MODE_PAINT_TEXTURE: km_id = "Image Paint"; break;
- case CTX_MODE_PARTICLE: km_id = "Particle"; break;
- case CTX_MODE_OBJECT: km_id = "Object Mode"; break;
- case CTX_MODE_PAINT_GPENCIL: km_id = "Grease Pencil Stroke Paint Mode"; break;
- case CTX_MODE_EDIT_GPENCIL: km_id = "Grease Pencil Stroke Edit Mode"; break;
- case CTX_MODE_SCULPT_GPENCIL: km_id = "Grease Pencil Stroke Sculpt Mode"; break;
- case CTX_MODE_WEIGHT_GPENCIL: km_id = "Grease Pencil Stroke Weight Mode"; break;
- }
- }
- else if (sl->spacetype == SPACE_IMAGE) {
- const SpaceImage *sima = (SpaceImage *)sl;
- const eSpaceImage_Mode mode = sima->mode;
- switch (mode) {
- case SI_MODE_VIEW: km_id = "Image"; break;
- case SI_MODE_PAINT: km_id = "Image Paint"; break;
- case SI_MODE_MASK: km_id = "Mask Editing"; break;
- case SI_MODE_UV: km_id = "UV Editor"; break;
- }
- }
- else {
- return NULL;
- }
+ SpaceLink *sl = CTX_wm_space_data(C);
+ const char *km_id = NULL;
+ if (sl->spacetype == SPACE_VIEW3D) {
+ const enum eContextObjectMode mode = CTX_data_mode_enum(C);
+ switch (mode) {
+ case CTX_MODE_EDIT_MESH:
+ km_id = "Mesh";
+ break;
+ case CTX_MODE_EDIT_CURVE:
+ km_id = "Curve";
+ break;
+ case CTX_MODE_EDIT_SURFACE:
+ km_id = "Curve";
+ break;
+ case CTX_MODE_EDIT_TEXT:
+ km_id = "Font";
+ break;
+ case CTX_MODE_EDIT_ARMATURE:
+ km_id = "Armature";
+ break;
+ case CTX_MODE_EDIT_METABALL:
+ km_id = "Metaball";
+ break;
+ case CTX_MODE_EDIT_LATTICE:
+ km_id = "Lattice";
+ break;
+ case CTX_MODE_POSE:
+ km_id = "Pose";
+ break;
+ case CTX_MODE_SCULPT:
+ km_id = "Sculpt";
+ break;
+ case CTX_MODE_PAINT_WEIGHT:
+ km_id = "Weight Paint";
+ break;
+ case CTX_MODE_PAINT_VERTEX:
+ km_id = "Vertex Paint";
+ break;
+ case CTX_MODE_PAINT_TEXTURE:
+ km_id = "Image Paint";
+ break;
+ case CTX_MODE_PARTICLE:
+ km_id = "Particle";
+ break;
+ case CTX_MODE_OBJECT:
+ km_id = "Object Mode";
+ break;
+ case CTX_MODE_PAINT_GPENCIL:
+ km_id = "Grease Pencil Stroke Paint Mode";
+ break;
+ case CTX_MODE_EDIT_GPENCIL:
+ km_id = "Grease Pencil Stroke Edit Mode";
+ break;
+ case CTX_MODE_SCULPT_GPENCIL:
+ km_id = "Grease Pencil Stroke Sculpt Mode";
+ break;
+ case CTX_MODE_WEIGHT_GPENCIL:
+ km_id = "Grease Pencil Stroke Weight Mode";
+ break;
+ }
+ }
+ else if (sl->spacetype == SPACE_IMAGE) {
+ const SpaceImage *sima = (SpaceImage *)sl;
+ const eSpaceImage_Mode mode = sima->mode;
+ switch (mode) {
+ case SI_MODE_VIEW:
+ km_id = "Image";
+ break;
+ case SI_MODE_PAINT:
+ km_id = "Image Paint";
+ break;
+ case SI_MODE_MASK:
+ km_id = "Mask Editing";
+ break;
+ case SI_MODE_UV:
+ km_id = "UV Editor";
+ break;
+ }
+ }
+ else {
+ return NULL;
+ }
- wmKeyMap *km = WM_keymap_find_all(C, km_id, 0, 0);
- BLI_assert(km);
- return km;
+ wmKeyMap *km = WM_keymap_find_all(C, km_id, 0, 0);
+ BLI_assert(km);
+ return km;
}
/* Guess an appropriate keymap from the operator name */
/* Needs to be kept up to date with Keymap and Operator naming */
wmKeyMap *WM_keymap_guess_opname(const bContext *C, const char *opname)
{
- /* Op types purposely skipped for now:
- * BRUSH_OT
- * BOID_OT
- * BUTTONS_OT
- * CONSTRAINT_OT
- * PAINT_OT
- * ED_OT
- * FLUID_OT
- * TEXTURE_OT
- * UI_OT
- * VIEW2D_OT
- * WORLD_OT
- */
+ /* Op types purposely skipped for now:
+ * BRUSH_OT
+ * BOID_OT
+ * BUTTONS_OT
+ * CONSTRAINT_OT
+ * PAINT_OT
+ * ED_OT
+ * FLUID_OT
+ * TEXTURE_OT
+ * UI_OT
+ * VIEW2D_OT
+ * WORLD_OT
+ */
- wmKeyMap *km = NULL;
- SpaceLink *sl = CTX_wm_space_data(C);
+ wmKeyMap *km = NULL;
+ SpaceLink *sl = CTX_wm_space_data(C);
- /* Window */
- if (STRPREFIX(opname, "WM_OT") ||
- STRPREFIX(opname, "ED_OT_undo"))
- {
- if (STREQ(opname, "WM_OT_tool_set_by_id")) {
- km = WM_keymap_guess_from_context(C);
- }
+ /* Window */
+ if (STRPREFIX(opname, "WM_OT") || STRPREFIX(opname, "ED_OT_undo")) {
+ if (STREQ(opname, "WM_OT_tool_set_by_id")) {
+ km = WM_keymap_guess_from_context(C);
+ }
- if (km == NULL) {
- km = WM_keymap_find_all(C, "Window", 0, 0);
- }
- }
- /* Screen & Render */
- else if (STRPREFIX(opname, "SCREEN_OT") ||
- STRPREFIX(opname, "RENDER_OT") ||
- STRPREFIX(opname, "SOUND_OT") ||
- STRPREFIX(opname, "SCENE_OT"))
- {
- km = WM_keymap_find_all(C, "Screen", 0, 0);
- }
- /* Grease Pencil */
- else if (STRPREFIX(opname, "GPENCIL_OT")) {
- km = WM_keymap_find_all(C, "Grease Pencil", 0, 0);
- }
- /* Markers */
- else if (STRPREFIX(opname, "MARKER_OT")) {
- km = WM_keymap_find_all(C, "Markers", 0, 0);
- }
- /* Import/Export*/
- else if (STRPREFIX(opname, "IMPORT_") ||
- STRPREFIX(opname, "EXPORT_"))
- {
- km = WM_keymap_find_all(C, "Window", 0, 0);
- }
+ if (km == NULL) {
+ km = WM_keymap_find_all(C, "Window", 0, 0);
+ }
+ }
+ /* Screen & Render */
+ else if (STRPREFIX(opname, "SCREEN_OT") || STRPREFIX(opname, "RENDER_OT") ||
+ STRPREFIX(opname, "SOUND_OT") || STRPREFIX(opname, "SCENE_OT")) {
+ km = WM_keymap_find_all(C, "Screen", 0, 0);
+ }
+ /* Grease Pencil */
+ else if (STRPREFIX(opname, "GPENCIL_OT")) {
+ km = WM_keymap_find_all(C, "Grease Pencil", 0, 0);
+ }
+ /* Markers */
+ else if (STRPREFIX(opname, "MARKER_OT")) {
+ km = WM_keymap_find_all(C, "Markers", 0, 0);
+ }
+ /* Import/Export*/
+ else if (STRPREFIX(opname, "IMPORT_") || STRPREFIX(opname, "EXPORT_")) {
+ km = WM_keymap_find_all(C, "Window", 0, 0);
+ }
+ /* 3D View */
+ else if (STRPREFIX(opname, "VIEW3D_OT")) {
+ km = WM_keymap_find_all(C, "3D View", sl->spacetype, 0);
+ }
+ else if (STRPREFIX(opname, "OBJECT_OT")) {
+ /* exception, this needs to work outside object mode too */
+ if (STRPREFIX(opname, "OBJECT_OT_mode_set")) {
+ km = WM_keymap_find_all(C, "Object Non-modal", 0, 0);
+ }
+ else {
+ km = WM_keymap_find_all(C, "Object Mode", 0, 0);
+ }
+ }
+ /* Object mode related */
+ else if (STRPREFIX(opname, "GROUP_OT") || STRPREFIX(opname, "MATERIAL_OT") ||
+ STRPREFIX(opname, "PTCACHE_OT") || STRPREFIX(opname, "RIGIDBODY_OT")) {
+ km = WM_keymap_find_all(C, "Object Mode", 0, 0);
+ }
- /* 3D View */
- else if (STRPREFIX(opname, "VIEW3D_OT")) {
- km = WM_keymap_find_all(C, "3D View", sl->spacetype, 0);
- }
- else if (STRPREFIX(opname, "OBJECT_OT")) {
- /* exception, this needs to work outside object mode too */
- if (STRPREFIX(opname, "OBJECT_OT_mode_set")) {
- km = WM_keymap_find_all(C, "Object Non-modal", 0, 0);
- }
- else {
- km = WM_keymap_find_all(C, "Object Mode", 0, 0);
- }
- }
- /* Object mode related */
- else if (STRPREFIX(opname, "GROUP_OT") ||
- STRPREFIX(opname, "MATERIAL_OT") ||
- STRPREFIX(opname, "PTCACHE_OT") ||
- STRPREFIX(opname, "RIGIDBODY_OT"))
- {
- km = WM_keymap_find_all(C, "Object Mode", 0, 0);
- }
+ /* Editing Modes */
+ else if (STRPREFIX(opname, "MESH_OT")) {
+ km = WM_keymap_find_all(C, "Mesh", 0, 0);
- /* Editing Modes */
- else if (STRPREFIX(opname, "MESH_OT")) {
- km = WM_keymap_find_all(C, "Mesh", 0, 0);
+ /* some mesh operators are active in object mode too, like add-prim */
+ if (km && !WM_keymap_poll((bContext *)C, km)) {
+ km = WM_keymap_find_all(C, "Object Mode", 0, 0);
+ }
+ }
+ else if (STRPREFIX(opname, "CURVE_OT") || STRPREFIX(opname, "SURFACE_OT")) {
+ km = WM_keymap_find_all(C, "Curve", 0, 0);
- /* some mesh operators are active in object mode too, like add-prim */
- if (km && !WM_keymap_poll((bContext *)C, km)) {
- km = WM_keymap_find_all(C, "Object Mode", 0, 0);
- }
- }
- else if (STRPREFIX(opname, "CURVE_OT") ||
- STRPREFIX(opname, "SURFACE_OT"))
- {
- km = WM_keymap_find_all(C, "Curve", 0, 0);
+ /* some curve operators are active in object mode too, like add-prim */
+ if (km && !WM_keymap_poll((bContext *)C, km)) {
+ km = WM_keymap_find_all(C, "Object Mode", 0, 0);
+ }
+ }
+ else if (STRPREFIX(opname, "ARMATURE_OT") || STRPREFIX(opname, "SKETCH_OT")) {
+ km = WM_keymap_find_all(C, "Armature", 0, 0);
+ }
+ else if (STRPREFIX(opname, "POSE_OT") || STRPREFIX(opname, "POSELIB_OT")) {
+ km = WM_keymap_find_all(C, "Pose", 0, 0);
+ }
+ else if (STRPREFIX(opname, "SCULPT_OT")) {
+ switch (CTX_data_mode_enum(C)) {
+ case CTX_MODE_SCULPT:
+ km = WM_keymap_find_all(C, "Sculpt", 0, 0);
+ break;
+ case CTX_MODE_EDIT_MESH:
+ km = WM_keymap_find_all(C, "UV Sculpt", 0, 0);
+ break;
+ default:
+ break;
+ }
+ }
+ else if (STRPREFIX(opname, "MBALL_OT")) {
+ km = WM_keymap_find_all(C, "Metaball", 0, 0);
- /* some curve operators are active in object mode too, like add-prim */
- if (km && !WM_keymap_poll((bContext *)C, km)) {
- km = WM_keymap_find_all(C, "Object Mode", 0, 0);
- }
- }
- else if (STRPREFIX(opname, "ARMATURE_OT") ||
- STRPREFIX(opname, "SKETCH_OT"))
- {
- km = WM_keymap_find_all(C, "Armature", 0, 0);
- }
- else if (STRPREFIX(opname, "POSE_OT") ||
- STRPREFIX(opname, "POSELIB_OT"))
- {
- km = WM_keymap_find_all(C, "Pose", 0, 0);
- }
- else if (STRPREFIX(opname, "SCULPT_OT")) {
- switch (CTX_data_mode_enum(C)) {
- case CTX_MODE_SCULPT:
- km = WM_keymap_find_all(C, "Sculpt", 0, 0);
- break;
- case CTX_MODE_EDIT_MESH:
- km = WM_keymap_find_all(C, "UV Sculpt", 0, 0);
- break;
- default:
- break;
- }
- }
- else if (STRPREFIX(opname, "MBALL_OT")) {
- km = WM_keymap_find_all(C, "Metaball", 0, 0);
+ /* some mball operators are active in object mode too, like add-prim */
+ if (km && !WM_keymap_poll((bContext *)C, km)) {
+ km = WM_keymap_find_all(C, "Object Mode", 0, 0);
+ }
+ }
+ else if (STRPREFIX(opname, "LATTICE_OT")) {
+ km = WM_keymap_find_all(C, "Lattice", 0, 0);
+ }
+ else if (STRPREFIX(opname, "PARTICLE_OT")) {
+ km = WM_keymap_find_all(C, "Particle", 0, 0);
+ }
+ else if (STRPREFIX(opname, "FONT_OT")) {
+ km = WM_keymap_find_all(C, "Font", 0, 0);
+ }
+ /* Paint Face Mask */
+ else if (STRPREFIX(opname, "PAINT_OT_face_select")) {
+ km = WM_keymap_find_all(C, "Face Mask", 0, 0);
+ }
+ else if (STRPREFIX(opname, "PAINT_OT")) {
+ /* check for relevant mode */
+ switch (CTX_data_mode_enum(C)) {
+ case CTX_MODE_PAINT_WEIGHT:
+ km = WM_keymap_find_all(C, "Weight Paint", 0, 0);
+ break;
+ case CTX_MODE_PAINT_VERTEX:
+ km = WM_keymap_find_all(C, "Vertex Paint", 0, 0);
+ break;
+ case CTX_MODE_PAINT_TEXTURE:
+ km = WM_keymap_find_all(C, "Image Paint", 0, 0);
+ break;
+ case CTX_MODE_SCULPT:
+ km = WM_keymap_find_all(C, "Sculpt", 0, 0);
+ break;
+ default:
+ break;
+ }
+ }
+ /* Image Editor */
+ else if (STRPREFIX(opname, "IMAGE_OT")) {
+ km = WM_keymap_find_all(C, "Image", sl->spacetype, 0);
+ }
+ /* Clip Editor */
+ else if (STRPREFIX(opname, "CLIP_OT")) {
+ km = WM_keymap_find_all(C, "Clip", sl->spacetype, 0);
+ }
+ else if (STRPREFIX(opname, "MASK_OT")) {
+ km = WM_keymap_find_all(C, "Mask Editing", 0, 0);
+ }
+ /* UV Editor */
+ else if (STRPREFIX(opname, "UV_OT")) {
+ /* Hack to allow using UV unwrapping ops from 3DView/editmode.
+ * Mesh keymap is probably not ideal, but best place I could find to put those. */
+ if (sl->spacetype == SPACE_VIEW3D) {
+ km = WM_keymap_find_all(C, "Mesh", 0, 0);
+ if (km && !WM_keymap_poll((bContext *)C, km)) {
+ km = NULL;
+ }
+ }
+ if (!km) {
+ km = WM_keymap_find_all(C, "UV Editor", 0, 0);
+ }
+ }
+ /* Node Editor */
+ else if (STRPREFIX(opname, "NODE_OT")) {
+ km = WM_keymap_find_all(C, "Node Editor", sl->spacetype, 0);
+ }
+ /* Animation Editor Channels */
+ else if (STRPREFIX(opname, "ANIM_OT_channels")) {
+ km = WM_keymap_find_all(C, "Animation Channels", 0, 0);
+ }
+ /* Animation Generic - after channels */
+ else if (STRPREFIX(opname, "ANIM_OT")) {
+ km = WM_keymap_find_all(C, "Animation", 0, 0);
+ }
+ /* Graph Editor */
+ else if (STRPREFIX(opname, "GRAPH_OT")) {
+ km = WM_keymap_find_all(C, "Graph Editor", sl->spacetype, 0);
+ }
+ /* Dopesheet Editor */
+ else if (STRPREFIX(opname, "ACTION_OT")) {
+ km = WM_keymap_find_all(C, "Dopesheet", sl->spacetype, 0);
+ }
+ /* NLA Editor */
+ else if (STRPREFIX(opname, "NLA_OT")) {
+ km = WM_keymap_find_all(C, "NLA Editor", sl->spacetype, 0);
+ }
+ /* Script */
+ else if (STRPREFIX(opname, "SCRIPT_OT")) {
+ km = WM_keymap_find_all(C, "Script", sl->spacetype, 0);
+ }
+ /* Text */
+ else if (STRPREFIX(opname, "TEXT_OT")) {
+ km = WM_keymap_find_all(C, "Text", sl->spacetype, 0);
+ }
+ /* Sequencer */
+ else if (STRPREFIX(opname, "SEQUENCER_OT")) {
+ km = WM_keymap_find_all(C, "Sequencer", sl->spacetype, 0);
+ }
+ /* Console */
+ else if (STRPREFIX(opname, "CONSOLE_OT")) {
+ km = WM_keymap_find_all(C, "Console", sl->spacetype, 0);
+ }
+ /* Console */
+ else if (STRPREFIX(opname, "INFO_OT")) {
+ km = WM_keymap_find_all(C, "Info", sl->spacetype, 0);
+ }
+ /* File browser */
+ else if (STRPREFIX(opname, "FILE_OT")) {
+ km = WM_keymap_find_all(C, "File Browser", sl->spacetype, 0);
+ }
+ /* Logic Editor */
+ else if (STRPREFIX(opname, "LOGIC_OT")) {
+ km = WM_keymap_find_all(C, "Logic Editor", sl->spacetype, 0);
+ }
+ /* Outliner */
+ else if (STRPREFIX(opname, "OUTLINER_OT")) {
+ km = WM_keymap_find_all(C, "Outliner", sl->spacetype, 0);
+ }
+ /* Transform */
+ else if (STRPREFIX(opname, "TRANSFORM_OT")) {
+ /* check for relevant editor */
+ switch (sl->spacetype) {
+ case SPACE_VIEW3D:
+ km = WM_keymap_find_all(C, "3D View", sl->spacetype, 0);
+ break;
+ case SPACE_GRAPH:
+ km = WM_keymap_find_all(C, "Graph Editor", sl->spacetype, 0);
+ break;
+ case SPACE_ACTION:
+ km = WM_keymap_find_all(C, "Dopesheet", sl->spacetype, 0);
+ break;
+ case SPACE_NLA:
+ km = WM_keymap_find_all(C, "NLA Editor", sl->spacetype, 0);
+ break;
+ case SPACE_IMAGE:
+ km = WM_keymap_find_all(C, "UV Editor", 0, 0);
+ break;
+ case SPACE_NODE:
+ km = WM_keymap_find_all(C, "Node Editor", sl->spacetype, 0);
+ break;
+ case SPACE_SEQ:
+ km = WM_keymap_find_all(C, "Sequencer", sl->spacetype, 0);
+ break;
+ }
+ }
- /* some mball operators are active in object mode too, like add-prim */
- if (km && !WM_keymap_poll((bContext *)C, km)) {
- km = WM_keymap_find_all(C, "Object Mode", 0, 0);
- }
- }
- else if (STRPREFIX(opname, "LATTICE_OT")) {
- km = WM_keymap_find_all(C, "Lattice", 0, 0);
- }
- else if (STRPREFIX(opname, "PARTICLE_OT")) {
- km = WM_keymap_find_all(C, "Particle", 0, 0);
- }
- else if (STRPREFIX(opname, "FONT_OT")) {
- km = WM_keymap_find_all(C, "Font", 0, 0);
- }
- /* Paint Face Mask */
- else if (STRPREFIX(opname, "PAINT_OT_face_select")) {
- km = WM_keymap_find_all(C, "Face Mask", 0, 0);
- }
- else if (STRPREFIX(opname, "PAINT_OT")) {
- /* check for relevant mode */
- switch (CTX_data_mode_enum(C)) {
- case CTX_MODE_PAINT_WEIGHT:
- km = WM_keymap_find_all(C, "Weight Paint", 0, 0);
- break;
- case CTX_MODE_PAINT_VERTEX:
- km = WM_keymap_find_all(C, "Vertex Paint", 0, 0);
- break;
- case CTX_MODE_PAINT_TEXTURE:
- km = WM_keymap_find_all(C, "Image Paint", 0, 0);
- break;
- case CTX_MODE_SCULPT:
- km = WM_keymap_find_all(C, "Sculpt", 0, 0);
- break;
- default:
- break;
- }
- }
- /* Image Editor */
- else if (STRPREFIX(opname, "IMAGE_OT")) {
- km = WM_keymap_find_all(C, "Image", sl->spacetype, 0);
- }
- /* Clip Editor */
- else if (STRPREFIX(opname, "CLIP_OT")) {
- km = WM_keymap_find_all(C, "Clip", sl->spacetype, 0);
- }
- else if (STRPREFIX(opname, "MASK_OT")) {
- km = WM_keymap_find_all(C, "Mask Editing", 0, 0);
- }
- /* UV Editor */
- else if (STRPREFIX(opname, "UV_OT")) {
- /* Hack to allow using UV unwrapping ops from 3DView/editmode.
- * Mesh keymap is probably not ideal, but best place I could find to put those. */
- if (sl->spacetype == SPACE_VIEW3D) {
- km = WM_keymap_find_all(C, "Mesh", 0, 0);
- if (km && !WM_keymap_poll((bContext *)C, km)) {
- km = NULL;
- }
- }
- if (!km) {
- km = WM_keymap_find_all(C, "UV Editor", 0, 0);
- }
- }
- /* Node Editor */
- else if (STRPREFIX(opname, "NODE_OT")) {
- km = WM_keymap_find_all(C, "Node Editor", sl->spacetype, 0);
- }
- /* Animation Editor Channels */
- else if (STRPREFIX(opname, "ANIM_OT_channels")) {
- km = WM_keymap_find_all(C, "Animation Channels", 0, 0);
- }
- /* Animation Generic - after channels */
- else if (STRPREFIX(opname, "ANIM_OT")) {
- km = WM_keymap_find_all(C, "Animation", 0, 0);
- }
- /* Graph Editor */
- else if (STRPREFIX(opname, "GRAPH_OT")) {
- km = WM_keymap_find_all(C, "Graph Editor", sl->spacetype, 0);
- }
- /* Dopesheet Editor */
- else if (STRPREFIX(opname, "ACTION_OT")) {
- km = WM_keymap_find_all(C, "Dopesheet", sl->spacetype, 0);
- }
- /* NLA Editor */
- else if (STRPREFIX(opname, "NLA_OT")) {
- km = WM_keymap_find_all(C, "NLA Editor", sl->spacetype, 0);
- }
- /* Script */
- else if (STRPREFIX(opname, "SCRIPT_OT")) {
- km = WM_keymap_find_all(C, "Script", sl->spacetype, 0);
- }
- /* Text */
- else if (STRPREFIX(opname, "TEXT_OT")) {
- km = WM_keymap_find_all(C, "Text", sl->spacetype, 0);
- }
- /* Sequencer */
- else if (STRPREFIX(opname, "SEQUENCER_OT")) {
- km = WM_keymap_find_all(C, "Sequencer", sl->spacetype, 0);
- }
- /* Console */
- else if (STRPREFIX(opname, "CONSOLE_OT")) {
- km = WM_keymap_find_all(C, "Console", sl->spacetype, 0);
- }
- /* Console */
- else if (STRPREFIX(opname, "INFO_OT")) {
- km = WM_keymap_find_all(C, "Info", sl->spacetype, 0);
- }
- /* File browser */
- else if (STRPREFIX(opname, "FILE_OT")) {
- km = WM_keymap_find_all(C, "File Browser", sl->spacetype, 0);
- }
- /* Logic Editor */
- else if (STRPREFIX(opname, "LOGIC_OT")) {
- km = WM_keymap_find_all(C, "Logic Editor", sl->spacetype, 0);
- }
- /* Outliner */
- else if (STRPREFIX(opname, "OUTLINER_OT")) {
- km = WM_keymap_find_all(C, "Outliner", sl->spacetype, 0);
- }
- /* Transform */
- else if (STRPREFIX(opname, "TRANSFORM_OT")) {
- /* check for relevant editor */
- switch (sl->spacetype) {
- case SPACE_VIEW3D:
- km = WM_keymap_find_all(C, "3D View", sl->spacetype, 0);
- break;
- case SPACE_GRAPH:
- km = WM_keymap_find_all(C, "Graph Editor", sl->spacetype, 0);
- break;
- case SPACE_ACTION:
- km = WM_keymap_find_all(C, "Dopesheet", sl->spacetype, 0);
- break;
- case SPACE_NLA:
- km = WM_keymap_find_all(C, "NLA Editor", sl->spacetype, 0);
- break;
- case SPACE_IMAGE:
- km = WM_keymap_find_all(C, "UV Editor", 0, 0);
- break;
- case SPACE_NODE:
- km = WM_keymap_find_all(C, "Node Editor", sl->spacetype, 0);
- break;
- case SPACE_SEQ:
- km = WM_keymap_find_all(C, "Sequencer", sl->spacetype, 0);
- break;
- }
- }
-
- return km;
+ return km;
}
void WM_keymap_fix_linking(void)