253 lines
6.4 KiB
Python
253 lines
6.4 KiB
Python
from typing import Set
|
|
from user.pokey_talon.code.terms import DELETE
|
|
|
|
from talon import Module, Context, actions, app
|
|
import sys
|
|
|
|
default_alphabet = "air bat cap drum each fine gust harp sit jane crunch look made near odd pit quench red sun trap urge vest whale plex yank zip".split(
|
|
" "
|
|
)
|
|
letters_string = "abcdefghijklmnopqrstuvwxyz"
|
|
|
|
default_digits = "zero one two three four five six seven eight nine".split(" ")
|
|
numbers = [str(i) for i in range(10)]
|
|
default_f_digits = (
|
|
"one two three four five six seven eight nine ten eleven twelve".split(" ")
|
|
)
|
|
|
|
mod = Module()
|
|
mod.list("letter", desc="The spoken phonetic alphabet")
|
|
mod.list("symbol_key", desc="All symbols from the keyboard")
|
|
mod.list("immune_symbol_key", desc="Symbols that can appear in a formatter")
|
|
mod.list("arrow_key", desc="All arrow keys")
|
|
mod.list("number_key", desc="All number keys")
|
|
mod.list("modifier_key", desc="All modifier keys")
|
|
mod.list("function_key", desc="All function keys")
|
|
mod.list("special_key", desc="All special keys")
|
|
mod.list("punctuation", desc="words for inserting punctuation into text")
|
|
|
|
|
|
@mod.capture(rule="{self.modifier_key}+")
|
|
def modifiers(m) -> str:
|
|
"One or more modifier keys"
|
|
return "-".join(m.modifier_key_list)
|
|
|
|
|
|
@mod.capture(rule="{self.arrow_key}")
|
|
def arrow_key(m) -> str:
|
|
"One directional arrow key"
|
|
return m.arrow_key
|
|
|
|
|
|
@mod.capture(rule="<self.arrow_key>+")
|
|
def arrow_keys(m) -> str:
|
|
"One or more arrow keys separated by a space"
|
|
return str(m)
|
|
|
|
|
|
@mod.capture(rule="{self.number_key}")
|
|
def number_key(m) -> str:
|
|
"One number key"
|
|
return m.number_key
|
|
|
|
|
|
@mod.capture(rule="{self.letter}")
|
|
def letter(m) -> str:
|
|
"One letter key"
|
|
return m.letter
|
|
|
|
|
|
@mod.capture(rule="{self.special_key}")
|
|
def special_key(m) -> str:
|
|
"One special key"
|
|
return m.special_key
|
|
|
|
|
|
@mod.capture(rule="{self.symbol_key}")
|
|
def symbol_key(m) -> str:
|
|
"One symbol key"
|
|
return m.symbol_key
|
|
|
|
|
|
@mod.capture(rule="{self.immune_symbol_key}")
|
|
def immune_symbol_key(m) -> str:
|
|
"A symbol key that is allowed to appear within a format string"
|
|
return m.immune_symbol_key
|
|
|
|
|
|
@mod.capture(rule="{self.function_key}")
|
|
def function_key(m) -> str:
|
|
"One function key"
|
|
return m.function_key
|
|
|
|
|
|
@mod.capture(rule="( <self.letter> | <self.number_key> | <self.symbol_key> )")
|
|
def any_alphanumeric_key(m) -> str:
|
|
"any alphanumeric key"
|
|
return str(m)
|
|
|
|
|
|
@mod.capture(
|
|
rule="( <self.letter> | <self.number_key> | <self.symbol_key> "
|
|
"| <self.arrow_key> | <self.function_key> | <self.special_key> )"
|
|
)
|
|
def unmodified_key(m) -> str:
|
|
"A single key with no modifiers"
|
|
return str(m)
|
|
|
|
|
|
@mod.capture(rule="{self.modifier_key}* <self.unmodified_key>")
|
|
def key(m) -> str:
|
|
"A single key with optional modifiers"
|
|
try:
|
|
mods = m.modifier_key_list
|
|
except AttributeError:
|
|
mods = []
|
|
return "-".join(mods + [m.unmodified_key])
|
|
|
|
|
|
@mod.capture(rule="<self.key>+")
|
|
def keys(m) -> str:
|
|
"A sequence of one or more keys with optional modifiers"
|
|
return " ".join(m.key_list)
|
|
|
|
|
|
@mod.capture(rule="{self.letter}+")
|
|
def letters(m) -> str:
|
|
"Multiple letter keys"
|
|
return "".join(m.letter_list)
|
|
|
|
|
|
ctx = Context()
|
|
modifier_keys = {
|
|
# If you find 'alt' is often misrecognized, try using 'alter'.
|
|
"alt": "alt", #'alter': 'alt',
|
|
"many": "cmd",
|
|
"troll": "ctrl", #'troll': 'ctrl',
|
|
"option": "alt",
|
|
"ship": "shift", #'sky': 'shift',
|
|
"super": "super",
|
|
}
|
|
if app.platform == "mac":
|
|
modifier_keys["command"] = "cmd"
|
|
modifier_keys["option"] = "alt"
|
|
ctx.lists["self.modifier_key"] = modifier_keys
|
|
alphabet = dict(zip(default_alphabet, letters_string))
|
|
ctx.lists["self.letter"] = alphabet
|
|
|
|
# `punctuation_words` is for words you want available BOTH in dictation and as
|
|
# key names in command mode. `symbol_key_words` is for key names that should be
|
|
# available in command mode, but NOT during dictation.
|
|
punctuation_words = {
|
|
# TODO: I'm not sure why we need these, I think it has something to do with
|
|
# Dragon. Possibly it has been fixed by later improvements to talon? -rntz
|
|
"`": "`",
|
|
",": ",", # <== these things
|
|
"back tick": "`",
|
|
"comma": ",",
|
|
"period": ".",
|
|
"semi": ";",
|
|
"colon": ":",
|
|
"forward slash": "/",
|
|
"question mark": "?",
|
|
"exclamation mark": "!",
|
|
"exclamation point": "!",
|
|
"dollar sign": "$",
|
|
"asterisk": "*",
|
|
"hash sign": "#",
|
|
"number sign": "#",
|
|
"percent sign": "%",
|
|
"at sign": "@",
|
|
"and sign": "&",
|
|
"ampersand": "&",
|
|
}
|
|
|
|
immune_symbol_key_words = {
|
|
"dot": ".",
|
|
"dash": "-",
|
|
}
|
|
|
|
symbol_key_words = {
|
|
"brick": "`",
|
|
"stroke": "/",
|
|
"backstroke": "\\",
|
|
"minus": "-",
|
|
"equal": "=",
|
|
"plus": "+",
|
|
"tilde": "~",
|
|
"bang": "!",
|
|
"dollar": "$",
|
|
"down score": "_",
|
|
"question": "?",
|
|
"single": "'",
|
|
"double": '"',
|
|
"leper": "(",
|
|
"repper": ")",
|
|
"lack": "[",
|
|
"rack": "]",
|
|
"lace": "{",
|
|
"race": "}",
|
|
"angle": "<",
|
|
"less than": "<",
|
|
"wrangle": ">",
|
|
"greater than": ">",
|
|
"snow": "*",
|
|
"pound": "#",
|
|
"percy": "%",
|
|
"tangle": "^",
|
|
"amper": "&",
|
|
"pipe": "|",
|
|
}
|
|
|
|
# make punctuation words also included in {user.symbol_keys}
|
|
symbol_key_words.update(punctuation_words)
|
|
symbol_key_words.update(immune_symbol_key_words)
|
|
ctx.lists["self.punctuation"] = punctuation_words
|
|
ctx.lists["self.symbol_key"] = symbol_key_words
|
|
ctx.lists["self.immune_symbol_key"] = immune_symbol_key_words
|
|
ctx.lists["self.number_key"] = dict(zip(default_digits, numbers))
|
|
ctx.lists["self.arrow_key"] = {
|
|
"down": "down",
|
|
"left": "left",
|
|
"right": "right",
|
|
"up": "up",
|
|
}
|
|
|
|
simple_keys = [
|
|
# "end",
|
|
# "home",
|
|
# "insert",
|
|
"pagedown",
|
|
"pageup",
|
|
"tab",
|
|
]
|
|
|
|
alternate_keys = {
|
|
"clap": "enter",
|
|
"deli": "delete",
|
|
"drill": "delete",
|
|
"chuck that": "backspace",
|
|
"wipe": "backspace",
|
|
"scrape": "escape",
|
|
"void": "space",
|
|
"page up": "pageup",
|
|
"page down": "pagedown",
|
|
}
|
|
# mac apparently doesn't have the menu key.
|
|
if app.platform in ("windows", "linux"):
|
|
alternate_keys["menu key"] = "menu"
|
|
alternate_keys["print screen"] = "printscr"
|
|
|
|
keys = {k: k for k in simple_keys}
|
|
keys.update(alternate_keys)
|
|
ctx.lists["self.special_key"] = keys
|
|
ctx.lists["self.function_key"] = {
|
|
f"fun {default_f_digits[i]}": f"f{i + 1}" for i in range(12)
|
|
}
|
|
|
|
|
|
@mod.action_class
|
|
class Actions:
|
|
def get_alphabet() -> dict:
|
|
"""Provides the alphabet dictionary"""
|
|
return alphabet
|