Skip to content

Commit

Permalink
c++ fixes
Browse files Browse the repository at this point in the history
incorporates:

atom/language-c#252
Note that this particular change was modified. `class public virtual : public virtual Example` is invalid I think, but I don't see a good way to prevent that because the detection must be moved into `patterns > include` because textmate is not multiline regex.
See also jeff-hykin/better-cpp-syntax#14
(In fact that whole repostory probably has some improvements)
I changed it to include the angle brackets because types can have those

atom/language-c#263
atom/language-c#311
atom/language-c#368

For tree-sitter, kinda fix the Discord reported issue
(In #support M1 Mac C++ Syntax highlighting)

Note that I syntax color only the last function name and not the namespace or colon. But that could easily be changed.

For future me, the relevant tree-sitter namespace identifier scopes are:
`call_expression > qualified_identifier > identifier` and
`function_declarator > qualified_identifier > identifier`

I don't know anything about template functions so I left that untouched. So this is probably an incomplete fix.

Finally, add the `static_assert` operator. It's technically a directive so it'll appear purple, not blue. Again this could easily be changed so don't hesitate about feedback, idk anything about c++
  • Loading branch information
icecream17 authored Feb 2, 2023
1 parent 1da0dab commit c2963a3
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 20 deletions.
47 changes: 29 additions & 18 deletions packages/language-c/grammars/c++.cson
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,17 @@
'name': 'punctuation.separator.namespace.access.cpp'
}
{
'match': '\\b(and|and_eq|bitand|bitor|compl|not|not_eq|or|or_eq|typeid|xor|xor_eq|alignof|alignas)\\b'
'match': '\\b(typeid|alignof|alignas)\\b'
'name': 'keyword.operator.cpp'
}
{
'match': '\\b(and|and_eq|bitand|bitor|compl|not|not_eq|or|or_eq|xor|xor_eq)\\b'
'name': 'keyword.operator.alias.cpp'
}
{
'match': '\\bstatic_assert\\b'
'name': 'keyword.static-assert.cpp'
}
{
'match': '\\b(class|decltype|wchar_t|char16_t|char32_t)\\b'
'name': 'storage.type.cpp'
Expand Down Expand Up @@ -242,7 +250,7 @@
"name": "meta.using-namespace-declaration.cpp"
},
{
'begin': '\\b(namespace)\\b\\s*([_A-Za-z][_A-Za-z0-9]*\\b)?+'
'begin': '\\b(namespace)\\b\\s*((?:[_A-Za-z][_A-Za-z0-9]*\\b(::)?)*)?+'
'beginCaptures':
'1':
'name': 'storage.type.cpp'
Expand Down Expand Up @@ -281,33 +289,36 @@
]
}
{
'begin': '\\b(class|struct)\\b\\s*([_A-Za-z][_A-Za-z0-9]*\\b)?+(\\s*:\\s*(public|protected|private)\\s*([_A-Za-z][_A-Za-z0-9]*\\b)((\\s*,\\s*(public|protected|private)\\s*[_A-Za-z][_A-Za-z0-9]*\\b)*))?'
'begin': '\\b(class|struct)\\b\\s*([_A-Za-z][_A-Za-z0-9]*\\b)?+(\\s*:\\s)?'
'beginCaptures':
'1':
'name': 'storage.type.cpp'
'2':
'name': 'entity.name.type.cpp'
'4':
'name': 'storage.type.modifier.cpp'
'5':
'name': 'entity.name.type.inherited.cpp'
'6':
'patterns': [
{
'match': '(public|protected|private)'
'name': 'storage.type.modifier.cpp'
}
{
'match': '[_A-Za-z][_A-Za-z0-9]*'
'name': 'entity.name.type.inherited.cpp'
}
]
'end': '(?<=\\})|(?=(;|\\(|\\)|>|\\[|\\]|=))'
'name': 'meta.class-struct-block.cpp'
'patterns': [
{
'include': '#angle_brackets'
}
{
'begin': '(virtual\\s*)?(public|protected|private)\\s*(virtual\\s*)?([_A-Za-z][_A-Za-z0-9]*)\\b'
'beginCaptures':
'1':
'name': 'storage.type.modifier.cpp'
'2':
'name': 'storage.type.modifier.cpp'
'3':
'name': 'storage.type.modifier.cpp'
'4':
'name': 'entity.name.type.inherited.cpp'
'end': '(\\{)|(\\s*\\n)|(,)?'
'patterns': [
{
'include': '#angle_brackets'
}
]
}
{
'begin': '\\{'
'beginCaptures':
Expand Down
7 changes: 5 additions & 2 deletions packages/language-c/grammars/tree-sitter-cpp.cson
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,7 @@ scopes:
'"#define"': 'keyword.control.directive'
'"#include"': 'keyword.control.directive'
'preproc_directive': 'keyword.control.directive'
'"static_assert"': 'keyword.control.directive'

'"if"': 'keyword.control'
'"else"': 'keyword.control'
Expand Down Expand Up @@ -133,12 +134,14 @@ scopes:
call_expression > identifier,
call_expression > field_expression > field_identifier,
call_expression > scoped_identifier > identifier,
call_expression > qualified_identifier > identifier,
template_function > identifier,
template_function > scoped_identifier > identifier,
template_method > field_identifier,
function_declarator > identifier,
function_declarator > field_identifier,
function_declarator > scoped_identifier > identifier,
function_declarator > qualified_identifier > identifier,
destructor_name > identifier
''': 'entity.name.function'

Expand Down Expand Up @@ -224,8 +227,8 @@ scopes:
'"=="': 'keyword.operator'
'"!"': 'keyword.operator'
'"!="': 'keyword.operator'
'relational_expression > "<"': 'keyword.operator'
'relational_expression > ">"': 'keyword.operator'
'binary_expression > "<"': 'keyword.operator'
'binary_expression > ">"': 'keyword.operator'
'">="': 'keyword.operator'
'"<="': 'keyword.operator'
'"&&"': 'keyword.operator'
Expand Down

0 comments on commit c2963a3

Please sign in to comment.