-
Notifications
You must be signed in to change notification settings - Fork 29.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Upcoming when clause context parser #175540
Comments
Will |
AFAIU, "never" is not a keyword or a pre-defined constant. Currently it's equivalent because context key "never" is undefined. Technically I can run |
Hi @bwateratmsft, @Eskibear is right, |
Hello everyone,
I also updated the EBNF grammar in this issue's description above. Please, let me know if you have any feedback! :-) |
In preparation for any future breakages related to extensions or user-local keybindings, I have created a Q&A on Stack Overflow, which you can (where appropriate) use as a duplicate-target. A fair number of people often go to Stack Overflow with problems like this. Feel free also to suggest edits to the question and answer posts to improve them. |
The new parser now runs by default in VS Code 1.77 (stable). Thanks everyone! I will keep this issue around in case there are any future changes to the parser. |
Is there any plan to port this to the user settings Should I file a separate issue for that, or is this issue the right place to report that? |
@ian-h-chamberlain made a request #188427. Thanks for the heads up 😊 |
One thing I really feel is missing is the ability to inject a regex context string, e.g. extension.js
package.json:
|
Has something changed in a more recent version w.r.t. to regex parsing? In particular as it relates to this, my regex matching seems to require quotes now instead of slashes:
Keybindings that used to work for me e.g. Edit: system details
|
@ian-h-chamberlain There's hasn't been any changes for a while. Could you please file a bug with a repro? |
What's a when clause?
When clauses allow to selectively enable and disable various extension contributions such as commands and UI elements (e.g., menus or views). When clauses are simple expressions that are put in an extension’s manifest (i.e.,
package.json
).New parser
The next VS Code release is planned to include a new parser of when clauses. The new parser will come with new features, more precise but stricter parsing rules, and a linter to see incorrect when clauses right away in
package.json
files.Below we outline new features, breakages, and a way to make sure your extension works as intended. Please, subscribe to this issue to stay up-to-date with other changes that may happen before the next VS Code release 1.77.
New features
Support for parentheses
(requested in Add support for parenthesis in "when" conditions #91473)
Note: Negation of expressions such as!(editorTextFocus && debugState == 'running')
is still work-in-progress. A comment will be posted to this issue, when it’s ready. Currently, one can only negate a context key, e.g.,!editorTextFocus
.Negation of expressions (e.g.,
!(editorTextFocus && debugState == 'running')
) is also now supported.Support for more regular expression flags
Key-value when clause operator
=~
currently supports thei
flag for case-insensitive regular expression search, but the new parser will support the following flags are supported:i
,s
,m
,u
. VS Code will not throw an error ifg
andy
flags are put in the regular expression but will not use them.Support operators
===
and!==
The new parser allows
===
and!==
operators, but they behave the same as==
and!=
. We noticed that there are already extensions that use these operators, assuming that they are supported, so we designed the new parser to be more flexible and support such operators.Breakages
We tried our best to keep old parser’s behavior on most when clauses so that existing when clauses work as they did before. There are three cases to keep in mind, however, for a when clause to work as intended:
When used with key-value when clause operator, a regular expression needs to be put between slash characters
/
just as in JavaScript, e.g.,view =~ /[a-z]+/
.Also important to note that a slash character within a regular expression needs to be escaped with two backslash characters, e.g.,
"when": "workspacePath =~ /my\\/path\//"
. The first backslash is to escape the second backslash in the JSON string withinpackage.json
and the second backslash is to escape the slash character.A string value containing whitespace must be quoted, e.g.,
"when": "myContextKey == 'two words'"
Note: only single quotes are currently supported.
Comparison operators need to be separated by whitespace from its operands, i.e.,
correct:
count < 2
incorrect:
count<2
Migration
VS Code Insiders comes with a linter for when clauses when an extension manifest file
package.json
is open. See no errors are reported for your extension’spackage.json
.VS Code Insiders will also run the new parser by default to see how extensions work with the new parser -- a comment will be posted when this happens as a notification to check out how your extension works with it.
Latest parsing grammar
In EBNF.
Please, let me know if you have any feedback! :-)
The text was updated successfully, but these errors were encountered: