aboutsummaryrefslogtreecommitdiff
path: root/xanguage/valgrind.h
diff options
context:
space:
mode:
authorxolatile2025-04-20 15:13:58 +0200
committerxolatile2025-04-20 15:13:58 +0200
commitb2bbfd7be69c1de91a06d922a9f7e09b45e59c1e (patch)
treed0b0e5bb6e3eec2e6a8538d4394f1af09edaf2cf /xanguage/valgrind.h
downloadxolatile-xarbon-master.tar.xz
xolatile-xarbon-master.tar.zst
Hopefully finished Xarbon...HEADmaster
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);
+}