Keymap: preference for fallback-tool with RMB select
Expose a key-map preference "Fallback Tool (RMB)", disabled by default. The right mouse button uses the fallback tool (currently visible selection tool in the toolbar), instead of always tweaking. When any selection tool is active, right mouse always tweaks. To enable fallback selection on RMB, set the "Right Mouse Select Action" to "Selection Tool". Internal changes: - Add fall-back key-maps, separate key-maps needed for when the tool is run as a fall-back. This is needed so RMB-select can support fall-back tools, so left-mouse can be used when it's the active tool and RMB can be used as a fall-back action when another tool is active. - Add options field to tools so tools without gizmos can enable the full-back tool keymap. - Support multiple key-maps for keymap handlers. - Fall-back keymaps now co-exist with the tool-keymaps. So both keymaps may be active at once - using different mouse buttons. When gizmos are in use, a highlighted gizmo prioritizes the tool-keymap over the fall-back keymap. Resolves T83690. Reviewed By: JulienKaspar Ref D12493
This commit is contained in:
@@ -350,24 +350,28 @@ static void menu_types_add_from_keymap_items(bContext *C,
|
||||
|
||||
if (handler_base->poll == NULL || handler_base->poll(region, win->eventstate)) {
|
||||
wmEventHandler_Keymap *handler = (wmEventHandler_Keymap *)handler_base;
|
||||
wmKeyMap *keymap = WM_event_get_keymap_from_handler(wm, handler);
|
||||
if (keymap && WM_keymap_poll(C, keymap)) {
|
||||
LISTBASE_FOREACH (wmKeyMapItem *, kmi, &keymap->items) {
|
||||
if (kmi->flag & KMI_INACTIVE) {
|
||||
continue;
|
||||
}
|
||||
if (STR_ELEM(kmi->idname, "WM_OT_call_menu", "WM_OT_call_menu_pie")) {
|
||||
char menu_idname[MAX_NAME];
|
||||
RNA_string_get(kmi->ptr, "name", menu_idname);
|
||||
MenuType *mt = WM_menutype_find(menu_idname, false);
|
||||
wmEventHandler_KeymapResult km_result;
|
||||
WM_event_get_keymaps_from_handler(wm, handler, &km_result);
|
||||
for (int km_index = 0; km_index < km_result.keymaps_len; km_index++) {
|
||||
wmKeyMap *keymap = km_result.keymaps[km_index];
|
||||
if (keymap && WM_keymap_poll(C, keymap)) {
|
||||
LISTBASE_FOREACH (wmKeyMapItem *, kmi, &keymap->items) {
|
||||
if (kmi->flag & KMI_INACTIVE) {
|
||||
continue;
|
||||
}
|
||||
if (STR_ELEM(kmi->idname, "WM_OT_call_menu", "WM_OT_call_menu_pie")) {
|
||||
char menu_idname[MAX_NAME];
|
||||
RNA_string_get(kmi->ptr, "name", menu_idname);
|
||||
MenuType *mt = WM_menutype_find(menu_idname, false);
|
||||
|
||||
if (mt && BLI_gset_add(menu_tagged, mt)) {
|
||||
/* Unlikely, but possible this will be included twice. */
|
||||
BLI_linklist_prepend(menuid_stack_p, mt);
|
||||
if (mt && BLI_gset_add(menu_tagged, mt)) {
|
||||
/* Unlikely, but possible this will be included twice. */
|
||||
BLI_linklist_prepend(menuid_stack_p, mt);
|
||||
|
||||
void **kmi_p;
|
||||
if (!BLI_ghash_ensure_p(menu_to_kmi, mt, &kmi_p)) {
|
||||
*kmi_p = kmi;
|
||||
void **kmi_p;
|
||||
if (!BLI_ghash_ensure_p(menu_to_kmi, mt, &kmi_p)) {
|
||||
*kmi_p = kmi;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -461,7 +461,7 @@ void MESH_GGT_spin(struct wmGizmoGroupType *gzgt)
|
||||
gzgt->name = "Mesh Spin Init";
|
||||
gzgt->idname = "MESH_GGT_spin";
|
||||
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_3D;
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP | WM_GIZMOGROUPTYPE_3D;
|
||||
|
||||
gzgt->gzmap_params.spaceid = SPACE_VIEW3D;
|
||||
gzgt->gzmap_params.regionid = RGN_TYPE_WINDOW;
|
||||
@@ -1063,7 +1063,7 @@ void MESH_GGT_spin_redo(struct wmGizmoGroupType *gzgt)
|
||||
gzgt->name = "Mesh Spin Redo";
|
||||
gzgt->idname = "MESH_GGT_spin_redo";
|
||||
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_3D;
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP | WM_GIZMOGROUPTYPE_3D;
|
||||
|
||||
gzgt->gzmap_params.spaceid = SPACE_VIEW3D;
|
||||
gzgt->gzmap_params.regionid = RGN_TYPE_WINDOW;
|
||||
|
||||
@@ -1735,10 +1735,14 @@ static void ed_default_handlers(
|
||||
WM_event_add_keymap_handler(handlers, keymap);
|
||||
}
|
||||
if (flag & ED_KEYMAP_TOOL) {
|
||||
WM_event_add_keymap_handler_dynamic(
|
||||
®ion->handlers, WM_event_get_keymap_from_toolsystem_fallback, area);
|
||||
WM_event_add_keymap_handler_dynamic(
|
||||
®ion->handlers, WM_event_get_keymap_from_toolsystem, area);
|
||||
if (flag & ED_KEYMAP_GIZMO) {
|
||||
WM_event_add_keymap_handler_dynamic(
|
||||
®ion->handlers, WM_event_get_keymap_from_toolsystem_fallback, area);
|
||||
}
|
||||
else {
|
||||
WM_event_add_keymap_handler_dynamic(
|
||||
®ion->handlers, WM_event_get_keymap_from_toolsystem, area);
|
||||
}
|
||||
}
|
||||
if (flag & ED_KEYMAP_FRAMES) {
|
||||
/* frame changing/jumping (for all spaces) */
|
||||
|
||||
@@ -58,7 +58,7 @@ void VIEW3D_GGT_mesh_preselect_elem(wmGizmoGroupType *gzgt)
|
||||
gzgt->name = "Mesh Preselect Element";
|
||||
gzgt->idname = "VIEW3D_GGT_mesh_preselect_elem";
|
||||
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_3D;
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP | WM_GIZMOGROUPTYPE_3D;
|
||||
|
||||
gzgt->gzmap_params.spaceid = SPACE_VIEW3D;
|
||||
gzgt->gzmap_params.regionid = RGN_TYPE_WINDOW;
|
||||
@@ -95,7 +95,7 @@ void VIEW3D_GGT_mesh_preselect_edgering(wmGizmoGroupType *gzgt)
|
||||
gzgt->name = "Mesh Preselect Edge Ring";
|
||||
gzgt->idname = "VIEW3D_GGT_mesh_preselect_edgering";
|
||||
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_3D;
|
||||
gzgt->flag = WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP | WM_GIZMOGROUPTYPE_3D;
|
||||
|
||||
gzgt->gzmap_params.spaceid = SPACE_VIEW3D;
|
||||
gzgt->gzmap_params.regionid = RGN_TYPE_WINDOW;
|
||||
|
||||
@@ -29,6 +29,15 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/** #bToolRef_Runtime.flag */
|
||||
enum {
|
||||
/**
|
||||
* This tool should use the fallback key-map.
|
||||
* Typically gizmos handle this but some tools (such as the knife tool) don't use a gizmo.
|
||||
*/
|
||||
TOOLREF_FLAG_FALLBACK_KEYMAP = (1 << 0),
|
||||
};
|
||||
|
||||
#
|
||||
#
|
||||
typedef struct bToolRef_Runtime {
|
||||
@@ -47,6 +56,8 @@ typedef struct bToolRef_Runtime {
|
||||
|
||||
/** Index when a tool is a member of a group. */
|
||||
int index;
|
||||
/** Options: `TOOLREF_FLAG_*`. */
|
||||
int flag;
|
||||
} bToolRef_Runtime;
|
||||
|
||||
/* Stored per mode. */
|
||||
|
||||
@@ -29,6 +29,7 @@
|
||||
|
||||
#include "DNA_object_types.h"
|
||||
#include "DNA_windowmanager_types.h"
|
||||
#include "DNA_workspace_types.h"
|
||||
|
||||
#include "RNA_enum_types.h" /* own include */
|
||||
|
||||
@@ -51,6 +52,7 @@ static void rna_WorkSpaceTool_setup(ID *id,
|
||||
const char *data_block,
|
||||
const char *op_idname,
|
||||
int index,
|
||||
int options,
|
||||
const char *idname_fallback,
|
||||
const char *keymap_fallback)
|
||||
{
|
||||
@@ -62,6 +64,7 @@ static void rna_WorkSpaceTool_setup(ID *id,
|
||||
STRNCPY(tref_rt.data_block, data_block);
|
||||
STRNCPY(tref_rt.op, op_idname);
|
||||
tref_rt.index = index;
|
||||
tref_rt.flag = options;
|
||||
|
||||
/* While it's logical to assign both these values from setup,
|
||||
* it's useful to stored this in DNA for re-use, exceptional case: write to the 'tref'. */
|
||||
@@ -131,6 +134,11 @@ void RNA_api_workspace_tool(StructRNA *srna)
|
||||
PropertyRNA *parm;
|
||||
FunctionRNA *func;
|
||||
|
||||
static EnumPropertyItem options_items[] = {
|
||||
{TOOLREF_FLAG_FALLBACK_KEYMAP, "KEYMAP_FALLBACK", 0, "Fallback", ""},
|
||||
{0, NULL, 0, NULL, NULL},
|
||||
};
|
||||
|
||||
func = RNA_def_function(srna, "setup", "rna_WorkSpaceTool_setup");
|
||||
RNA_def_function_flag(func, FUNC_USE_SELF_ID | FUNC_USE_CONTEXT);
|
||||
RNA_def_function_ui_description(func, "Set the tool settings");
|
||||
@@ -146,6 +154,7 @@ void RNA_api_workspace_tool(StructRNA *srna)
|
||||
RNA_def_string(func, "data_block", NULL, MAX_NAME, "Data Block", "");
|
||||
RNA_def_string(func, "operator", NULL, MAX_NAME, "Operator", "");
|
||||
RNA_def_int(func, "index", 0, INT_MIN, INT_MAX, "Index", "", INT_MIN, INT_MAX);
|
||||
RNA_def_enum_flag(func, "options", options_items, 0, "Tool Options", "");
|
||||
|
||||
RNA_def_string(func, "idname_fallback", NULL, MAX_NAME, "Fallback Identifier", "");
|
||||
RNA_def_string(func, "keymap_fallback", NULL, KMAP_MAX_NAME, "Fallback Key Map", "");
|
||||
|
||||
@@ -262,14 +262,21 @@ struct wmEventHandler_Keymap *WM_event_add_keymap_handler_priority(ListBase *han
|
||||
wmKeyMap *keymap,
|
||||
int priority);
|
||||
|
||||
typedef struct wmKeyMap *(wmEventHandler_KeymapDynamicFn)(wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler)
|
||||
ATTR_WARN_UNUSED_RESULT;
|
||||
typedef struct wmEventHandler_KeymapResult {
|
||||
wmKeyMap *keymaps[3];
|
||||
int keymaps_len;
|
||||
} wmEventHandler_KeymapResult;
|
||||
|
||||
struct wmKeyMap *WM_event_get_keymap_from_toolsystem_fallback(
|
||||
struct wmWindowManager *wm, struct wmEventHandler_Keymap *handler);
|
||||
struct wmKeyMap *WM_event_get_keymap_from_toolsystem(struct wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler);
|
||||
typedef void(wmEventHandler_KeymapDynamicFn)(wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler,
|
||||
struct wmEventHandler_KeymapResult *km_result);
|
||||
|
||||
void WM_event_get_keymap_from_toolsystem_fallback(struct wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler,
|
||||
wmEventHandler_KeymapResult *km_result);
|
||||
void WM_event_get_keymap_from_toolsystem(struct wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler,
|
||||
wmEventHandler_KeymapResult *km_result);
|
||||
|
||||
struct wmEventHandler_Keymap *WM_event_add_keymap_handler_dynamic(
|
||||
ListBase *handlers, wmEventHandler_KeymapDynamicFn *keymap_fn, void *user_data);
|
||||
@@ -281,8 +288,9 @@ void WM_event_set_keymap_handler_post_callback(struct wmEventHandler_Keymap *han
|
||||
wmKeyMapItem *kmi,
|
||||
void *user_data),
|
||||
void *user_data);
|
||||
wmKeyMap *WM_event_get_keymap_from_handler(wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler);
|
||||
void WM_event_get_keymaps_from_handler(wmWindowManager *wm,
|
||||
struct wmEventHandler_Keymap *handler,
|
||||
struct wmEventHandler_KeymapResult *km_result);
|
||||
|
||||
wmKeyMapItem *WM_event_match_keymap_item(struct bContext *C,
|
||||
wmKeyMap *keymap,
|
||||
|
||||
@@ -265,6 +265,8 @@ void WM_gizmogroup_ensure_init(const bContext *C, wmGizmoGroup *gzgroup)
|
||||
{
|
||||
/* prepare for first draw */
|
||||
if (UNLIKELY((gzgroup->init_flag & WM_GIZMOGROUP_INIT_SETUP) == 0)) {
|
||||
|
||||
gzgroup->use_fallback_keymap = true;
|
||||
gzgroup->type->setup(C, gzgroup);
|
||||
|
||||
/* Not ideal, initialize keymap here, needed for RNA runtime generated gizmos. */
|
||||
|
||||
@@ -2989,9 +2989,18 @@ static int wm_handlers_do_intern(bContext *C, wmEvent *event, ListBase *handlers
|
||||
/* Handle all types here. */
|
||||
if (handler_base->type == WM_HANDLER_TYPE_KEYMAP) {
|
||||
wmEventHandler_Keymap *handler = (wmEventHandler_Keymap *)handler_base;
|
||||
wmKeyMap *keymap = WM_event_get_keymap_from_handler(wm, handler);
|
||||
action |= wm_handlers_do_keymap_with_keymap_handler(
|
||||
C, event, handlers, handler, keymap, do_debug_handler);
|
||||
wmEventHandler_KeymapResult km_result;
|
||||
WM_event_get_keymaps_from_handler(wm, handler, &km_result);
|
||||
int action_iter = WM_HANDLER_CONTINUE;
|
||||
for (int km_index = 0; km_index < km_result.keymaps_len; km_index++) {
|
||||
wmKeyMap *keymap = km_result.keymaps[km_index];
|
||||
action_iter |= wm_handlers_do_keymap_with_keymap_handler(
|
||||
C, event, handlers, handler, keymap, do_debug_handler);
|
||||
if (action_iter & WM_HANDLER_BREAK) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
action |= action_iter;
|
||||
|
||||
/* Clear the tool-tip whenever a key binding is handled, without this tool-tips
|
||||
* are kept when a modal operators starts (annoying but otherwise harmless). */
|
||||
@@ -3905,17 +3914,34 @@ wmEventHandler_Keymap *WM_event_add_keymap_handler(ListBase *handlers, wmKeyMap
|
||||
*
|
||||
* Follow #wmEventHandler_KeymapDynamicFn signature.
|
||||
*/
|
||||
wmKeyMap *WM_event_get_keymap_from_toolsystem_fallback(wmWindowManager *wm,
|
||||
wmEventHandler_Keymap *handler)
|
||||
void WM_event_get_keymap_from_toolsystem_fallback(wmWindowManager *wm,
|
||||
wmEventHandler_Keymap *handler,
|
||||
wmEventHandler_KeymapResult *km_result)
|
||||
{
|
||||
memset(km_result, 0x0, sizeof(*km_result));
|
||||
|
||||
const char *keymap_id_list[ARRAY_SIZE(km_result->keymaps)];
|
||||
int keymap_id_list_len = 0;
|
||||
|
||||
ScrArea *area = handler->dynamic.user_data;
|
||||
handler->keymap_tool = NULL;
|
||||
bToolRef_Runtime *tref_rt = area->runtime.tool ? area->runtime.tool->runtime : NULL;
|
||||
if (tref_rt && tref_rt->keymap_fallback[0]) {
|
||||
const char *keymap_id = NULL;
|
||||
|
||||
if (tref_rt && tref_rt->keymap[0]) {
|
||||
keymap_id_list[keymap_id_list_len++] = tref_rt->keymap;
|
||||
}
|
||||
|
||||
bool is_gizmo_visible = false;
|
||||
bool is_gizmo_highlight = false;
|
||||
|
||||
if (tref_rt && tref_rt->keymap_fallback[0]) {
|
||||
bool add_keymap = false;
|
||||
/* Support for the gizmo owning the tool keymap. */
|
||||
if (tref_rt->gizmo_group[0] != '\0' && tref_rt->keymap_fallback[0] != '\0') {
|
||||
|
||||
if (tref_rt->flag & TOOLREF_FLAG_FALLBACK_KEYMAP) {
|
||||
add_keymap = true;
|
||||
}
|
||||
if (tref_rt->gizmo_group[0] != '\0') {
|
||||
wmGizmoMap *gzmap = NULL;
|
||||
wmGizmoGroup *gzgroup = NULL;
|
||||
LISTBASE_FOREACH (ARegion *, region, &area->regionbase) {
|
||||
@@ -3931,32 +3957,49 @@ wmKeyMap *WM_event_get_keymap_from_toolsystem_fallback(wmWindowManager *wm,
|
||||
if (gzgroup->type->flag & WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP) {
|
||||
/* If all are hidden, don't override. */
|
||||
if (gzgroup->use_fallback_keymap) {
|
||||
is_gizmo_visible = true;
|
||||
wmGizmo *highlight = wm_gizmomap_highlight_get(gzmap);
|
||||
if (highlight == NULL) {
|
||||
keymap_id = tref_rt->keymap_fallback;
|
||||
if (highlight) {
|
||||
is_gizmo_highlight = true;
|
||||
}
|
||||
add_keymap = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (keymap_id && keymap_id[0]) {
|
||||
wmKeyMap *km = WM_keymap_list_find_spaceid_or_empty(
|
||||
&wm->userconf->keymaps, keymap_id, area->spacetype, RGN_TYPE_WINDOW);
|
||||
/* We shouldn't use keymaps from unrelated spaces. */
|
||||
if (km != NULL) {
|
||||
handler->keymap_tool = area->runtime.tool;
|
||||
return km;
|
||||
}
|
||||
printf(
|
||||
"Keymap: '%s' not found for tool '%s'\n", tref_rt->keymap, area->runtime.tool->idname);
|
||||
if (add_keymap) {
|
||||
keymap_id_list[keymap_id_list_len++] = tref_rt->keymap_fallback;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
|
||||
if (is_gizmo_visible && !is_gizmo_highlight) {
|
||||
if (keymap_id_list_len == 2) {
|
||||
SWAP(const char *, keymap_id_list[0], keymap_id_list[1]);
|
||||
}
|
||||
}
|
||||
|
||||
for (int i = 0; i < keymap_id_list_len; i++) {
|
||||
const char *keymap_id = keymap_id_list[i];
|
||||
BLI_assert(keymap_id && keymap_id[0]);
|
||||
|
||||
wmKeyMap *km = WM_keymap_list_find_spaceid_or_empty(
|
||||
&wm->userconf->keymaps, keymap_id, area->spacetype, RGN_TYPE_WINDOW);
|
||||
/* We shouldn't use keymaps from unrelated spaces. */
|
||||
if (km == NULL) {
|
||||
printf("Keymap: '%s' not found for tool '%s'\n", keymap_id, area->runtime.tool->idname);
|
||||
continue;
|
||||
}
|
||||
handler->keymap_tool = area->runtime.tool;
|
||||
km_result->keymaps[km_result->keymaps_len++] = km;
|
||||
}
|
||||
}
|
||||
|
||||
wmKeyMap *WM_event_get_keymap_from_toolsystem(wmWindowManager *wm, wmEventHandler_Keymap *handler)
|
||||
void WM_event_get_keymap_from_toolsystem(wmWindowManager *wm,
|
||||
wmEventHandler_Keymap *handler,
|
||||
wmEventHandler_KeymapResult *km_result)
|
||||
{
|
||||
memset(km_result, 0x0, sizeof(*km_result));
|
||||
|
||||
ScrArea *area = handler->dynamic.user_data;
|
||||
handler->keymap_tool = NULL;
|
||||
bToolRef_Runtime *tref_rt = area->runtime.tool ? area->runtime.tool->runtime : NULL;
|
||||
@@ -3968,13 +4011,14 @@ wmKeyMap *WM_event_get_keymap_from_toolsystem(wmWindowManager *wm, wmEventHandle
|
||||
/* We shouldn't use keymaps from unrelated spaces. */
|
||||
if (km != NULL) {
|
||||
handler->keymap_tool = area->runtime.tool;
|
||||
return km;
|
||||
km_result->keymaps[km_result->keymaps_len++] = km;
|
||||
}
|
||||
else {
|
||||
printf(
|
||||
"Keymap: '%s' not found for tool '%s'\n", tref_rt->keymap, area->runtime.tool->idname);
|
||||
}
|
||||
printf(
|
||||
"Keymap: '%s' not found for tool '%s'\n", tref_rt->keymap, area->runtime.tool->idname);
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
struct wmEventHandler_Keymap *WM_event_add_keymap_handler_dynamic(
|
||||
@@ -5088,18 +5132,22 @@ void WM_set_locked_interface(wmWindowManager *wm, bool lock)
|
||||
/** \name Event / Keymap Matching API
|
||||
* \{ */
|
||||
|
||||
wmKeyMap *WM_event_get_keymap_from_handler(wmWindowManager *wm, wmEventHandler_Keymap *handler)
|
||||
void WM_event_get_keymaps_from_handler(wmWindowManager *wm,
|
||||
wmEventHandler_Keymap *handler,
|
||||
wmEventHandler_KeymapResult *km_result)
|
||||
{
|
||||
wmKeyMap *keymap;
|
||||
if (handler->dynamic.keymap_fn != NULL) {
|
||||
keymap = handler->dynamic.keymap_fn(wm, handler);
|
||||
handler->dynamic.keymap_fn(wm, handler, km_result);
|
||||
BLI_assert(handler->keymap == NULL);
|
||||
}
|
||||
else {
|
||||
keymap = WM_keymap_active(wm, handler->keymap);
|
||||
memset(km_result, 0x0, sizeof(*km_result));
|
||||
wmKeyMap *keymap = WM_keymap_active(wm, handler->keymap);
|
||||
BLI_assert(keymap != NULL);
|
||||
if (keymap != NULL) {
|
||||
km_result->keymaps[km_result->keymaps_len++] = keymap;
|
||||
}
|
||||
}
|
||||
return keymap;
|
||||
}
|
||||
|
||||
wmKeyMapItem *WM_event_match_keymap_item(bContext *C, wmKeyMap *keymap, const wmEvent *event)
|
||||
@@ -5128,11 +5176,15 @@ wmKeyMapItem *WM_event_match_keymap_item_from_handlers(bContext *C,
|
||||
else if (handler_base->poll == NULL || handler_base->poll(CTX_wm_region(C), event)) {
|
||||
if (handler_base->type == WM_HANDLER_TYPE_KEYMAP) {
|
||||
wmEventHandler_Keymap *handler = (wmEventHandler_Keymap *)handler_base;
|
||||
wmKeyMap *keymap = WM_event_get_keymap_from_handler(wm, handler);
|
||||
if (keymap && WM_keymap_poll(C, keymap)) {
|
||||
wmKeyMapItem *kmi = WM_event_match_keymap_item(C, keymap, event);
|
||||
if (kmi != NULL) {
|
||||
return kmi;
|
||||
wmEventHandler_KeymapResult km_result;
|
||||
WM_event_get_keymaps_from_handler(wm, handler, &km_result);
|
||||
for (int km_index = 0; km_index < km_result.keymaps_len; km_index++) {
|
||||
wmKeyMap *keymap = km_result.keymaps[km_index];
|
||||
if (WM_keymap_poll(C, keymap)) {
|
||||
wmKeyMapItem *kmi = WM_event_match_keymap_item(C, keymap, event);
|
||||
if (kmi != NULL) {
|
||||
return kmi;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -462,7 +462,9 @@ bool WM_keymap_poll(bContext *C, wmKeyMap *keymap)
|
||||
/* Empty key-maps may be missing more there may be a typo in the name.
|
||||
* Warn early to avoid losing time investigating each case.
|
||||
* When developing a customized Blender though you may want empty keymaps. */
|
||||
if (!U.app_template[0]) {
|
||||
if (!U.app_template[0] &&
|
||||
/* Fallback key-maps may be intentionally empty, don't flood the output. */
|
||||
!BLI_str_endswith(keymap->idname, " (fallback)")) {
|
||||
CLOG_WARN(WM_LOG_KEYMAPS, "empty keymap '%s'", keymap->idname);
|
||||
}
|
||||
}
|
||||
@@ -1402,15 +1404,19 @@ static wmKeyMapItem *wm_keymap_item_find_handlers(const bContext *C,
|
||||
LISTBASE_FOREACH (wmEventHandler *, handler_base, handlers) {
|
||||
if (handler_base->type == WM_HANDLER_TYPE_KEYMAP) {
|
||||
wmEventHandler_Keymap *handler = (wmEventHandler_Keymap *)handler_base;
|
||||
wmKeyMap *keymap = WM_event_get_keymap_from_handler(wm, handler);
|
||||
if (keymap && WM_keymap_poll((bContext *)C, keymap)) {
|
||||
wmKeyMapItem *kmi = wm_keymap_item_find_in_keymap(
|
||||
keymap, opname, properties, is_strict, params);
|
||||
if (kmi != NULL) {
|
||||
if (r_keymap) {
|
||||
*r_keymap = keymap;
|
||||
wmEventHandler_KeymapResult km_result;
|
||||
WM_event_get_keymaps_from_handler(wm, handler, &km_result);
|
||||
for (int km_index = 0; km_index < km_result.keymaps_len; km_index++) {
|
||||
wmKeyMap *keymap = km_result.keymaps[km_index];
|
||||
if (WM_keymap_poll((bContext *)C, keymap)) {
|
||||
wmKeyMapItem *kmi = wm_keymap_item_find_in_keymap(
|
||||
keymap, opname, properties, is_strict, params);
|
||||
if (kmi != NULL) {
|
||||
if (r_keymap) {
|
||||
*r_keymap = keymap;
|
||||
}
|
||||
return kmi;
|
||||
}
|
||||
return kmi;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -326,7 +326,10 @@ void WM_toolsystem_ref_set_from_runtime(struct bContext *C,
|
||||
bool use_fallback_keymap = false;
|
||||
|
||||
if (tref->idname_fallback[0] || tref->runtime->keymap_fallback[0]) {
|
||||
if (tref_rt->gizmo_group[0]) {
|
||||
if (tref_rt->flag & TOOLREF_FLAG_FALLBACK_KEYMAP) {
|
||||
use_fallback_keymap = true;
|
||||
}
|
||||
else if (tref_rt->gizmo_group[0]) {
|
||||
wmGizmoGroupType *gzgt = WM_gizmogrouptype_find(tref_rt->gizmo_group, false);
|
||||
if (gzgt) {
|
||||
if (gzgt->flag & WM_GIZMOGROUPTYPE_TOOL_FALLBACK_KEYMAP) {
|
||||
|
||||
Reference in New Issue
Block a user