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 <campbell@blender.org>2022-03-14 12:41:05 +0300
committerCampbell Barton <campbell@blender.org>2022-03-14 12:42:12 +0300
commitc6642f06ab2655e47705e69bc6c0f0f35d964ada (patch)
tree45badfb673519bf3266ff18cd320e1c41b89fcb0 /release
parent82e7956f12aa4ee06cb27d902cc5c518af1ef177 (diff)
Fix T96395: NDOF entries prevent loading of custom keymaps in 3.2
Even though the default key-map didn't use NDOF types some key-maps did.
Diffstat (limited to 'release')
-rw-r--r--release/scripts/modules/bl_keymap_utils/versioning.py18
1 files changed, 16 insertions, 2 deletions
diff --git a/release/scripts/modules/bl_keymap_utils/versioning.py b/release/scripts/modules/bl_keymap_utils/versioning.py
index 402c21f8ef1..59ea2e62d3b 100644
--- a/release/scripts/modules/bl_keymap_utils/versioning.py
+++ b/release/scripts/modules/bl_keymap_utils/versioning.py
@@ -14,11 +14,11 @@ def keyconfig_update(keyconfig_data, keyconfig_version):
# Version the key-map.
import copy
+ # Only copy once.
has_copy = False
# Default repeat to false.
if keyconfig_version <= (2, 92, 0):
- # Only copy once.
if not has_copy:
keyconfig_data = copy.deepcopy(keyconfig_data)
has_copy = True
@@ -31,7 +31,6 @@ def keyconfig_update(keyconfig_data, keyconfig_version):
item_event["repeat"] = True
if keyconfig_version <= (3, 2, 5):
- # Only copy once.
if not has_copy:
keyconfig_data = copy.deepcopy(keyconfig_data)
has_copy = True
@@ -48,4 +47,19 @@ def keyconfig_update(keyconfig_data, keyconfig_version):
item_event["direction"] = value
item_event["value"] = 'CLICK_DRAG'
+ if keyconfig_version <= (3, 2, 6):
+ if not has_copy:
+ keyconfig_data = copy.deepcopy(keyconfig_data)
+ has_copy = True
+
+ for _km_name, _km_parms, km_items_data in keyconfig_data:
+ for (_item_op, item_event, _item_prop) in km_items_data["items"]:
+ if ty_new := {
+ 'NDOF_BUTTON_ESC': 'ESC',
+ 'NDOF_BUTTON_ALT': 'LEFT_ALT',
+ 'NDOF_BUTTON_SHIFT': 'LEFT_SHIFT',
+ 'NDOF_BUTTON_CTRL': 'LEFT_CTRL',
+ }.get(item_event.get("type")):
+ item_event["type"] = ty_new
+
return keyconfig_data