from talon import Context, Module, actions, settings from ..tags.operators import Operators mod = Module() ctx = Context() ctx.matches = r""" code.language: c """ ctx.lists["self.c_pointers"] = { "pointer": "*", "pointer to pointer": "**", } ctx.lists["self.stdint_signed"] = { "signed": "", "unsigned": "u", "you": "u", } ctx.lists["self.c_signed"] = { "signed": "signed", "unsigned": "unsigned", } ctx.lists["self.c_keywords"] = { "static": "static", "volatile": "volatile", "register": "register", } ctx.lists["self.stdint_types"] = { "character": "int8_t", "char": "int8_t", "short": "int16_t", "long": "int32_t", "long long": "int64_t", "int": "int32_t", "integer": "int32_t", "void": "void", "double": "double", "struct": "struct", "struck": "struct", "num": "enum", "union": "union", "float": "float", } ctx.lists["self.c_types"] = { "character": "char", "char": "char", "short": "short", "long": "long", "int": "int", "integer": "int", "void": "void", "double": "double", "struct": "struct", "struck": "struct", "num": "enum", "union": "union", "float": "float", } ctx.lists["user.code_libraries"] = { "assert": "assert.h", "type": "ctype.h", "error": "errno.h", "float": "float.h", "limits": "limits.h", "locale": "locale.h", "math": "math.h", "set jump": "setjmp.h", "signal": "signal.h", "arguments": "stdarg.h", "definition": "stddef.h", "input": "stdio.h", "output": "stdio.h", "library": "stdlib.h", "string": "string.h", "time": "time.h", "standard int": "stdint.h", } mod.list("c_pointers", desc="Common C pointers") mod.list("c_signed", desc="Common C datatype signed modifiers") mod.list("c_keywords", desc="C keywords") mod.list("c_types", desc="Common C types") mod.list("stdint_types", desc="Common stdint C types") mod.list("stdint_signed", desc="Common stdint C datatype signed modifiers") @mod.capture(rule="{self.c_pointers}") def c_pointers(m) -> str: "Returns a string" return m.c_pointers @mod.capture(rule="{self.c_signed}") def c_signed(m) -> str: "Returns a string" return m.c_signed @mod.capture(rule="{self.c_keywords}") def c_keywords(m) -> str: "Returns a string" return m.c_keywords @mod.capture(rule="{self.c_types}") def c_types(m) -> str: "Returns a string" return m.c_types @mod.capture(rule="{self.stdint_types}") def stdint_types(m) -> str: "Returns a string" return m.stdint_types @mod.capture(rule="{self.stdint_signed}") def stdint_signed(m) -> str: "Returns a string" return m.stdint_signed @mod.capture(rule="[] [+]") def c_cast(m) -> str: "Returns a string" return "(" + " ".join(list(m)) + ")" @mod.capture(rule="[] [+]") def stdint_cast(m) -> str: "Returns a string" return "(" + "".join(list(m)) + ")" @mod.capture(rule="[] []") def c_variable(m) -> str: "Returns a string" return " ".join(list(m)) operators = Operators( SUBSCRIPT=lambda: actions.user.insert_between("[", "]"), ASSIGNMENT=" = ", ASSIGNMENT_ADDITION=" += ", ASSIGNMENT_SUBTRACTION=" -= ", ASSIGNMENT_MULTIPLICATION=" *= ", ASSIGNMENT_DIVISION=" /= ", ASSIGNMENT_MODULO=" %= ", ASSIGNMENT_INCREMENT="++", ASSIGNMENT_BITWISE_AND=" &= ", ASSIGNMENT_BITWISE_OR=" |= ", ASSIGNMENT_BITWISE_EXCLUSIVE_OR=" ^= ", ASSIGNMENT_BITWISE_LEFT_SHIFT=" <<= ", ASSIGNMENT_BITWISE_RIGHT_SHIFT=" >>= ", BITWISE_AND=" & ", BITWISE_OR=" | ", BITWISE_NOT="~", BITWISE_EXCLUSIVE_OR=" ^ ", BITWISE_LEFT_SHIFT=" << ", BITWISE_RIGHT_SHIFT=" >> ", MATH_SUBTRACT=" - ", MATH_ADD=" + ", MATH_MULTIPLY=" * ", MATH_DIVIDE=" / ", MATH_MODULO=" % ", MATH_EQUAL=" == ", MATH_NOT_EQUAL=" != ", MATH_GREATER_THAN=" > ", MATH_GREATER_THAN_OR_EQUAL=" >= ", MATH_LESS_THAN=" < ", MATH_LESS_THAN_OR_EQUAL=" <= ", MATH_AND=" && ", MATH_OR=" || ", MATH_NOT="!", POINTER_INDIRECTION="*", POINTER_ADDRESS_OF="&", POINTER_STRUCTURE_DEREFERENCE="->", ) @ctx.action_class("user") class UserActions: def code_get_operators() -> Operators: return operators def code_insert_null(): actions.auto_insert("NULL") def code_insert_is_null(): actions.auto_insert(" == NULL ") def code_insert_is_not_null(): actions.auto_insert(" != NULL") def code_insert_true(): actions.auto_insert("true") def code_insert_false(): actions.auto_insert("false") def code_insert_function(text: str, selection: str): if selection: text = text + f"({selection})" else: text = text + "()" actions.user.paste(text) actions.edit.left() # TODO - it would be nice that you integrate that types from c_cast # instead of defaulting to void def code_private_function(text: str): """Inserts private function declaration""" result = "void {}".format( actions.user.formatted_text( text, settings.get("user.code_private_function_formatter") ) ) actions.user.code_insert_function(result, None) def code_private_static_function(text: str): """Inserts private static function""" result = "static void {}".format( actions.user.formatted_text( text, settings.get("user.code_private_function_formatter") ) ) actions.user.code_insert_function(result, None) def code_insert_library(text: str, selection: str): actions.user.paste(f"#include <{text}>")