aboutsummaryrefslogtreecommitdiff
path: root/xanguage/valgrind.h
diff options
context:
space:
mode:
authorxolatile2025-04-20 12:12:07 +0200
committerxolatile2025-04-20 12:12:07 +0200
commite767bea2c871e30c32305ad4035527188c844f29 (patch)
tree29b556efa5fea262ad96901082b1c17f1dfa628a /xanguage/valgrind.h
parentc53055c9b71af24644d7a984e2309ebbc042449f (diff)
downloadxolatile-xighlight-e767bea2c871e30c32305ad4035527188c844f29.tar.xz
xolatile-xighlight-e767bea2c871e30c32305ad4035527188c844f29.tar.zst
Trying...
Diffstat (limited to 'xanguage/valgrind.h')
-rwxr-xr-xxanguage/valgrind.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/xanguage/valgrind.h b/xanguage/valgrind.h
new file mode 100755
index 0000000..f187721
--- /dev/null
+++ b/xanguage/valgrind.h
@@ -0,0 +1,24 @@
+static procedure language_highlight_valgrind (language_structure * language, syntax_structure * syntax) {
+ character * separators = ".,:;<=>+-*/%!&~^?|@#$()[]{}'\" \t\r\n";
+
+ character * titles [] = {
+ "HEAP", "LEAK", "ERROR", "SUMMARY"
+ };
+
+ syntax_define (syntax, false, false, "==", "==", '\0', language->comment_colour, language->comment_effect);
+ syntax_define (syntax, false, false, "\"", "\"", '\0', language->string_colour, language->string_effect);
+ syntax_define (syntax, false, false, "(", ")", '\0', language->lowercase_colour, language->lowercase_effect);
+ syntax_define (syntax, false, false, "0x", ":", '\0', language->string_colour, language->string_effect);
+
+ for (natural_64 word = 0; word < array_length (titles); ++word) {
+ syntax_define (syntax, false, true, titles [word], separators, '\0', language->fatal_colour, language->fatal_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, ": ()\t\r\n", '\0', language->number_colour, language->number_effect);
+ syntax_define (syntax, true, true, language_lowercase, separators, '\0', language->uppercase_colour, language->uppercase_effect);
+ syntax_define (syntax, true, true, language_uppercase, separators, '\0', language->uppercase_colour, language->uppercase_effect);
+ syntax_define (syntax, true, true, "_", separators, '\0', language->uppercase_colour, language->uppercase_effect);
+}