Merge branch 'fix/conf-utils-keyparser' of https://github.com/arubertoson/kitty
This commit is contained in:
commit
4de18688ca
@ -228,19 +228,28 @@ def parse_kittens_shortcut(sc):
|
|||||||
|
|
||||||
|
|
||||||
def parse_kittens_func_args(action, args_funcs):
|
def parse_kittens_func_args(action, args_funcs):
|
||||||
parts = action.split(' ', 1)
|
parts = action.strip().split(' ', 1)
|
||||||
func = parts[0]
|
func = parts[0]
|
||||||
if len(parts) == 1:
|
if len(parts) == 1:
|
||||||
return func, ()
|
return func, ()
|
||||||
rest = parts[1]
|
rest = parts[1]
|
||||||
parser = args_funcs.get(func)
|
|
||||||
if parser is not None:
|
try:
|
||||||
try:
|
parser = args_funcs[func]
|
||||||
func, args = parser(func, rest)
|
except KeyError:
|
||||||
except Exception:
|
raise KeyError(
|
||||||
raise ValueError('Unknown key action: {}'.format(action))
|
"Couldn't get valid key from {}. Check if input action: "
|
||||||
|
"{} is valid".format(parts, action)
|
||||||
|
)
|
||||||
|
|
||||||
|
try:
|
||||||
|
func, args = parser(func, rest)
|
||||||
|
except Exception:
|
||||||
|
raise ValueError('Unknown key action: {}'.format(action))
|
||||||
|
|
||||||
if not isinstance(args, (list, tuple)):
|
if not isinstance(args, (list, tuple)):
|
||||||
args = (args,)
|
args = (args,)
|
||||||
|
|
||||||
return func, tuple(args)
|
return func, tuple(args)
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user