Monday, December 4, 2017

Is there any way for VS Code to indent to an open bracket?

Leave a Comment

I'm looking to modify VS Code's indentation behavior so that if I press enter after typing a line like this:

variable = function(param1, 

It'll indent to the level of the open parenthesis so that I can easily format code like this:

variable = function(param1,                     param2) 

I'd like it to work for open square brackets and curly brackets as well:

variable = function([1, 2, 3, 4                      5, 6, 7, 8],                     param2,                     {'a': 1, 'b': 2,                      'c': 3, 'd': 4},                     param4) 

I'd prefer it to have this behavior for pretty much every language I work with, though the curly braces behavior isn't necessary (and may even be undesirable) when working in C++ or C#.

This is very similar to Sublime Text's indent_to_bracket setting.

Is there any way to accomplish this? If there's no setting, I'm willing to tinker with whatever is necessary. I'm also open to an extension that can do this, or even writing an extension if it's necessary and makes sense to do so.

3 Answers

Answers 1

It looks like ESLint will do this for you.

Examples of correct code for this rule with the 2, { "FunctionExpression": {"parameters": "first"} } option:

/*eslint indent: ["error", 2, {"FunctionExpression": {"parameters": "first"}}]*/  var foo = function(bar, baz,                    qux, boop) {   qux(); } 

From indent rule : Function Expressions.

Install the extension vscode-eslint integration and then

If you haven't installed ESLint either locally or globally do so by running npm install eslint in the workspace folder for a local install or npm install -g eslint for a global install.

Then a rule like

"indent": ["error", 2, { "FunctionExpression": {"body": 1, "parameters": "first"} }], 

in your .eslintrc.json file will do what you want - at least on save if you have

"eslint.autoFixOnSave": true 

in your settings. false is the default. I don't believe you can make it "fix" the problem as you type - but only on save. You can also modify this setting

// An array of language ids which should be validated by ESLint

"eslint.validate": [ "javascript", "javascriptreact" ],

Answers 2

There is a closed issue on GitHub for this very feature. A recent comment from the development team reads as follows:

This feature request will not be considered in the next 6-12 months roadmap and as such will be closed to keep the number of issues we have to maintain actionable. Thanks for understanding and happy coding!

Therefore, it will not be included in the foreseeable future.

The only option right now would be to attempt to create an extension that does exactly this or even hack on the main editor source code. I suggest you start here: https://code.visualstudio.com/docs/extensions/overview

Answers 3

Have a look at then viusal studio extension "AStyle". I used AStyle often, when I have to work on bad formatted code files.

AStyle is also available as a stand alone program. Maybe it fits your needs

If You Enjoyed This, Take 5 Seconds To Share It

0 comments:

Post a Comment