diff options
| author | xolatile | 2025-04-20 12:12:07 +0200 |
|---|---|---|
| committer | xolatile | 2025-04-20 12:12:07 +0200 |
| commit | e767bea2c871e30c32305ad4035527188c844f29 (patch) | |
| tree | 29b556efa5fea262ad96901082b1c17f1dfa628a /xanguage/holy_c.h | |
| parent | c53055c9b71af24644d7a984e2309ebbc042449f (diff) | |
| download | xolatile-xighlight-e767bea2c871e30c32305ad4035527188c844f29.tar.xz xolatile-xighlight-e767bea2c871e30c32305ad4035527188c844f29.tar.zst | |
Trying...
Diffstat (limited to 'xanguage/holy_c.h')
| -rwxr-xr-x | xanguage/holy_c.h | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/xanguage/holy_c.h b/xanguage/holy_c.h new file mode 100755 index 0000000..b9cdb1d --- /dev/null +++ b/xanguage/holy_c.h @@ -0,0 +1,46 @@ +static procedure language_highlight_holy_c (language_structure * language, syntax_structure * syntax) { + character * separators = ".,:;<=>+-*/%!&~^|()[]{}'\" \t\r\n"; + + character * keywords [] = { + "static", "extern", "import", "auto", "public", "sizeof", "asm", "no_warn", + "do", "while", "for", "switch", "case", "default", "start", "end", + "if", "else", "goto", "return", "break", "try", "catch", "throw", + "enum", "union", "class" + }; + + character * types [] = { + "U8", "U16", "U32", "U64", "I8", "I16", "I32", "I64", + "U0", "I0", "F64", "Bool" + }; + + character * commons [] = { + "_extern", "_intern", "_import", "lastclass", "offset", "defined", "lock", "interrupt", + "reg", "noreg", "argpop", "noargpop", "haserrcode", "NULL", "TRUE", "FALSE" + }; + + syntax_define (syntax, false, false, "/*", "*/", '\0', language->comment_colour, language->comment_effect); + syntax_define (syntax, false, false, "//", "\n", '\0', language->comment_colour, language->comment_effect); + syntax_define (syntax, false, false, "#", "\n", '\\', language->processor_colour, language->processor_effect); + syntax_define (syntax, false, false, "'", "'", '\\', language->character_colour, language->character_effect); + syntax_define (syntax, false, false, "\"", "\"", '\\', language->string_colour, language->string_effect); + + for (natural_64 word = 0; word < array_length (keywords); ++word) { + syntax_define (syntax, false, true, keywords [word], separators, '\0', language->keyword_colour, language->keyword_effect); + } + + for (natural_64 word = 0; word < array_length (types); ++word) { + syntax_define (syntax, false, true, types [word], separators, '\0', language->type_colour, language->type_effect); + } + + for (natural_64 word = 0; word < array_length (commons); ++word) { + syntax_define (syntax, false, true, commons [word], separators, '\0', language->extension_colour, language->extension_effect); + } + + syntax_define (syntax, true, false, "()[]{}", "", '\0', language->bracket_colour, language->bracket_effect); + syntax_define (syntax, true, false, ".,:;<=>+*-/%!&~^|", "", '\0', language->operator_colour, language->operator_effect); + + syntax_define (syntax, true, true, language_digits, separators, '\0', language->number_colour, language->number_effect); + syntax_define (syntax, true, true, language_lowercase, separators, '\0', language->lowercase_colour, language->lowercase_effect); + syntax_define (syntax, true, true, language_uppercase, separators, '\0', language->uppercase_colour, language->uppercase_effect); + syntax_define (syntax, true, true, "_", separators, '\0', language->underscore_colour, language->underscore_effect); +} |
