Smart Indenting now Removes Whitespace

29 visualizzazioni (ultimi 30 giorni)
In recent versions of MATLAB (I believe this behavior started with R2021a), the smart indent feature changed its behavior. The way it behaves in R2020b and earlier is, if your cursor is on a line that has been indented:
  1. If you press return one or more times, the cursor will be indented on the same level as the previous line.
  2. If you then click to a line that was previously smart-indented to the correct level, the cursor will be on that correct indentation level.
The way it behaves in R2022a is:
  1. (Same as R2020b) If you press return one or more times, the cursor will be indented on the same level as the previous line.
  2. If you then click to a line that was previously smart-indented to the correct level, the cursor will not be on the correct indentation level. It will have zero indentation, implying that the smart-indent features doesn't leave whitespace behind.
I find the behavior of the R2022a smart indentor to be very difficult to use, because it means going back and adding to indented code often requires you to manually hit tab a few times until your code is properly indented. This seems to largely defeats the purpose of automatic indenting. I've poked through settings looking for a way to restore R2020b indenting behavior, but cannot find an option to make it return to "correct" indenting.
Does anyone know how to restore the smart-indenting behavior to the R2020b behavior? I'm also curious if you know why this change was made; rather than shaking my tiny fist at the MATLAB gods in frustration, I'd like to know why this change can be benefitial to some users.
  3 Commenti
Grant Giesbrecht
Grant Giesbrecht il 26 Ago 2022
I see what you mean about anticipating what the user wants. The reason I'm still surprised to see it is: 1.) I think the previous MATLAB editor's implementation of guessing what the user wanted was pretty reasonable, and I'd rarely need to adjust the indentation level it provided and 2.) Most other editors also perform this guesswork reasonably well (eg. Atom, XCode, Spyder, PyCharm, etc).
Andrew Robbins
Andrew Robbins il 1 Apr 2023
Spostato: Matt J il 2 Apr 2023
Hello, I want to echo how awful this feature is for some basic workflows. (I'm using R2022b)
One simple example is:
Say you want to start an if statement and you're already on the 3rd indent. I would do the following:
  1. Type "if <expr>"
  2. Press enter twice
  3. Type "end"
  4. Click up arrow once to start putting in the contents of the if statement
function myFunc()
for i = 1:5
if true
<no tabs>
end
end
end
And now you have to tab yourself or put some code there and smart indent manually. Earlier versions of MATLAB just worked. The indenting was correct to begin with, no tabbing or anything required.
Am I using this is some unique and niche way? I would LOVE to opt to the old system, not because fixing this costs a significant amount of time, but because it is so stupid and unnecessary.

Accedi per commentare.

Risposta accettata

goc3
goc3 il 22 Mar 2024
Release 2024a includes a setting for this!! The following code will stop smart indenting from removing white space:
s = settings;
s.matlab.editor.indent.PadEmptyLines.PersonalValue = 1;
See the documentation page for more details on this and other editor settings.
  1 Commento
Grant Giesbrecht
Grant Giesbrecht il 1 Apr 2024
Great find! Though for me at least, I also needed to set:
s.matlab.editor.indent.RemoveAutomaticWhitespace = 0;
in order for the new PadEmptyLines setting to take effect.

Accedi per commentare.

Più risposte (1)

Matt J
Matt J il 26 Ago 2022
Modificato: Matt J il 26 Ago 2022
This is just my suspicion but, in the Matlab editor, the tab key doesn't really seem to insert tab characters. It appears just to be a shortkey for inserting a certain number of space characters. As a result, it is not possible to backward tab in a single keystroke: when undoing indentation, you have to delete individual spaces.
Therefore, if you are inserting code into a blank line where you want indentation level 2 when the previous line has an indentation level of 3, it will cost you a lot more keystrokes to go backward from 3 than to start at an indentation level of 0 and hit the tab key twice.
The above argument ignores the possibility of doing Ctrl+[ to undo indentation, but I think control and escape sequences are considered more laborious and need to be weighted differently than single key sequences when evaluating the keystroke count.
  4 Commenti
Levi Blake
Levi Blake il 5 Gen 2024
"As a result, it is not possible to backward tab in a single keystroke: when undoing indentation, you have to delete individual spaces."
You do not need to delete individual spaces when undoing indentation. On windows you can remove however many spaces you use for indents by pressing shift + tab. Effectively, it's the reverse of using tab, and matches the behavior of many other programs such as Microsoft Word and OneNote.
Steven Lord
Steven Lord il 5 Gen 2024
This is just my suspicion but, in the Matlab editor, the tab key doesn't really seem to insert tab characters.
That depends on your preferences. See the Editor/Debugger Tab Preferences section on this documentation page.

Accedi per commentare.

Categorie

Scopri di più su Environment and Settings in Help Center e File Exchange

Prodotti


Release

R2022a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by