From b54bc4df4b4ea7f84e945cd50e1b197993213f71 Mon Sep 17 00:00:00 2001 From: James Buren Date: Thu, 7 Nov 2024 12:36:05 -0600 Subject: [PATCH] [C] Add support for C23 _BitInt type This is implemented like typeof() because it can only be used with ()s to indicate how many bits the resulting integer type will have. While I was at it, I also added support for the new suffixes for _BitInt integer constants and the new wN and wfN length modifiers for printf and scanf. --- C++/C.sublime-syntax | 18 +++++++++--------- C++/syntax_test_c.c | 8 ++++++++ 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/C++/C.sublime-syntax b/C++/C.sublime-syntax index 20239f5e07..db87d8850f 100644 --- a/C++/C.sublime-syntax +++ b/C++/C.sublime-syntax @@ -33,7 +33,7 @@ variables: hex_suffix: '[g-zG-Z_][[:alnum:]_]*' double_suffix: '[fFlL]' float_suffix: '[fF]' - integer_suffix: '[lL]{1,2}[uU]?|[uU][lL]{0,2}' + integer_suffix: 'u?wb|[lL]{1,2}[uU]?|[uU][lL]{0,2}' identifier: \b[[:alpha:]_][[:alnum:]_]*\b # upper and lowercase macro_identifier: \b[[:upper:]_][[:upper:][:digit:]_]{2,}\b # only uppercase, at least 3 chars @@ -51,7 +51,7 @@ variables: type_qualifier: 'const|volatile|_Atomic' compiler_directive: 'inline|restrict|__restrict__|__restrict|_Noreturn|noreturn' modifiers: '{{storage_classes}}|{{type_qualifier}}|{{compiler_directive}}' - non_func_keywords: 'if|for|switch|while|decltype|typeof|typeof_unqual|_Atomic|sizeof|alignof|_Alignof|static_assert|_Static_assert|__declspec|__attribute__' + non_func_keywords: 'if|for|switch|while|decltype|typeof|typeof_unqual|_Atomic|_BitInt|sizeof|alignof|_Alignof|static_assert|_Static_assert|__declspec|__attribute__' contexts: main: @@ -180,12 +180,12 @@ contexts: string_placeholder: - match: |- (?x)% - (\d+\$)? # field (argument #) - [#0\- +']* # flags - [,;:_]? # separator character (AltiVec) - ((-?\d+)|\*(-?\d+\$)?)? # minimum field width - (\.((-?\d+)|\*(-?\d+\$)?)?)? # precision - (hh|h|ll|l|j|t|z|q|L|vh|vl|v|hv|hl)? # length modifier + (\d+\$)? # field (argument #) + [#0\- +']* # flags + [,;:_]? # separator character (AltiVec) + ((-?\d+)|\*(-?\d+\$)?)? # minimum field width + (\.((-?\d+)|\*(-?\d+\$)?)?)? # precision + (hh|h|ll|l|j|t|z|q|L|vh|vl|v|hv|hl|wf?[0-9]+)? # length modifier (\[[^\]]+\]|[am]s|[diouxXbDOUeEfFgGaACcSspn%]) # conversion type scope: constant.other.placeholder.c @@ -260,7 +260,7 @@ contexts: - include: types-parens types-parens: - - match: '\b(typeof|__typeof|__typeof__|typeof_unqual|_Atomic)\b\s*(\()' + - match: '\b(typeof|__typeof|__typeof__|typeof_unqual|_Atomic|_BitInt)\b\s*(\()' captures: 1: keyword.declaration.type.c 2: meta.group.c punctuation.section.group.begin.c diff --git a/C++/syntax_test_c.c b/C++/syntax_test_c.c index 37b352f14e..86966f8b5a 100644 --- a/C++/syntax_test_c.c +++ b/C++/syntax_test_c.c @@ -201,6 +201,14 @@ struct foo { int i; /* <- storage.type */ +signed _BitInt(4) bi1 = 1wb; +/* ^ keyword.declaration.type */ +/* ^ constant.numeric.suffix */ + +unsigned _BitInt(4) bi2 = 1uwb; +/* ^ keyword.declaration.type */ +/* ^ constant.numeric.suffix */ + _Atomic int ai1; /* <- storage.modifier */