views:

1680

answers:

9

Edit: This question had been tagged "Tolstoy" in appreciation of the quality and length of my writing:) Just reading the first and the last paragraph should be enough:) If you tend to select and move code with the mouse, the stuff in middle could be interesting to you.

This question is about how you use text editors in general. I’m looking for the best way to delete a plurality of lines of code (no intent to patent it:) This extends to transposing lines, i.e. deleting and adding them somewhere else. Most importantly, I don’t want to be creating any blank lines that I have to delete separately. Sort of like Visual Studio's SHIFT+DELETE feature, but working for multiple lines at once.

Say you want to delete line 3 from following code (tabs and newlines visualized as well). The naïve way would be to select the text between angle brackets:

if (true) {\n
\t int i = 1;\n
\t <i *= 2;>\n
\t i += 3;\n
}\n

Then hit backspace. This creates a blank line. Hit backspace twice more to delete \t and \n.

You end up with:

if (true) {\n
\t int i = 1;\n
\t i += 3;\n
}\n

When you try to select a whole line, Visual Studio doesn't let you select the trailing newline character. For example, placing the cursor on a line and hitting SHIFT+END will not select the newline at the end. Neither will you select the newline if you use your mouse, i.e. clicking in the middle of a line and dragging the cursor all the way to the right. You only select the trailing newline characters if you make a selection that spans at least two lines. Most editors I use do it this way; Microsoft WordPad and Word are counter-examples (and I frequently get newlines wrong when deleting text there; at least Word has a way to display end-of-line and end-of-paragraph characters explicitly).

When using Visual Studio and other editors in general, here’s the solution that currently works best for me:

Using the mouse, I select the characters that I put between angle brackets:

if (true) {\n
\t int i = 1;<\n
\t i *= 2;>\n
\t i += 3;\n
}\n

Hitting backspace now, you delete the line in one go without having to delete any other characters. This works for several contiguous lines at once. Additionally, it can be used for transposing lines. You could drag the selection between the angle brackets to the point marked with a caret:

if (true) {\n
\t int i = 1;<\n
\t i *= 2;>\n
\t i += 3;^\n
}\n

This leaves you with:

if (true) {\n
\t int i = 1;\n
\t i += 3;<\n
\t i *= 2;>\n
}\n

where lines 3 and 4 have switched place.

There are variations on this theme. When you want to delete line 3, you could also select the following characters:

if (true) {\n
\t int i = 1;\n
<\t i *= 2;\n
>\t i += 3;\n
}\n

In fact, this is what Visual Studio does if you tell it to select a complete line. You do this by clicking in the margin between your code and the column where the red circles go which indicate breakpoints. The mouse pointer is mirrored in that area to distinguish it a little better, but I think it's too narrow and physically too far removed from the code I want to select.

Maybe this method is useful to other people as well, even if it only serves to make them aware of how newlines are handled when selecting/deleting text:) It works nicely for most non-specialized text editors. However, given the vast amount of features and plugins for Visual Studio (which I use most), I'm sure there is better way to use it to delete and move lines of code. Getting the indentation right automatically when moving code between different blocks would be nice (i.e. without hitting "Format Document/Selection"). I'm looking forward to suggestions; no rants on micro-optimization, please:)


Summary of Answers

With respect to Visual Studio: Navigating well with the cursor keys.

The solution that would best suit my style of going over and editing code is the Eclipse way:

You can select several consecutive lines of code, where the first and the last selected line may be selected only partially. Pressing ALT+{up,down} moves the complete lines (not just the selection) up and down, fixing indentation as you go. Hitting CTRL+D deletes the lines completely (not just the selection) without leaving any unwanted blank lines. I would love to see this in Visual Studio!

+4  A: 

In Emacs:

  • kill-line C-k
  • transpose-lines C-x C-t

C-a C-k C-k -- kill whole line including newline (or kill-whole-line by C-S-backspace).

C-u <number> C-k -- kill <number> of lines (including newlines).

C-y -- yank back the most recently killed text (aka paste)

J.F. Sebastian
+2  A: 

In Eclipse you can ALT-down or ALT-up to move a line. I find this incredibly useful, as well as ALT-SHIFT-{down, up} to copy a line. In addition, it doesn't wreck your clipboard. It even corrects indentation as the line is moving!

Pedro
Nice! I would love to have that in Visual Studio!
ephemer
+3  A: 

In VIM:

  • Delete the whole line including the newline: dd
  • Transpose lines: dd p

You can always prefix any command with a number to repeat it, so to delete 10 lines do:

10 dd

You can also specify a range of lines to delete. For instance, to delete lines 10-15:

:10,15d

Or you can move the lines, for instance move lines 10-15 below line 20:

:10,15m20

Or you can copy the lines:

:10,15t20
Nathan Fellman
+1  A: 

Learn to use your cursor keys.

For moving lines I do the following:

  1. Use Arrow Up/Down to move to the line you want to copy.
  2. Hit Home if not there already, and again if it places the cursor after whitespace.
  3. Then press Shift+Down to select the line (or lines) you want to move
  4. Ctrl+X to cut the line.
  5. Move Up/Down to the line you want to insert
  6. Ctrl+V

This should work in pretty much any text editor on Windows.

When deleting lines I still tend to use Ctrl+X (although I guess I also use backspace) as the above is so ingrained in how I edit, and it's also more forgiving.

(Although I find them disorienting on the occasions I use Macs, I think Apple might have been on to something with the way they've set up the Home/End, skip word shortcuts on Macs)

Sam Hasler
+3  A: 

What I do is, starting with the cursor at the start of the line (in some editors you have to press home twice to do this), hold shift and press down until all lines that I want to delete are selected. Then I press delete.

Turambar
A: 

Using the Brief keyboard mapping this is done using the Al+L to mark the line and the Minus key on the numeric keypad (or Alt+D) to cut the line to clipboard. The cut will remove the line entirely, including the newline character.

Hitting the Ins key on the numeric keypad would put the line back into the document including the newline character.

IMHO Brief is a really well designed keyboard mapping.

PS: I think MSVC has an option to emulate the Brief keyboard mapping.

jussij
A: 

in Eclipse i use CTRL + D to delete a single line (or a couple) for many lines i'll select them with the mouse or with SHIFT + ARROW then press the delete key.

Matt
A: 

In addition to the above, use Resharper for Visual Studio to do what you want. Best VS plugin you will find ever. It provides a bunch of different commands that help with moving/deleting/copying code here there and everywhere. Not to mention refactor/generate/etc code.

Ctrl-Shift-Alt Up or Down will move a method up or down, line up or down, etc. Shift-Del - deletes the current line, but puts it in the clipboard (unless you modify your settings to not do this - I'm trying to recall if this is a VS standard shortcut, not just Resharper - been too long). Ctrl-C, Ctrl-X without selecting copies/cuts the current line. And on and on...

See http://www.jetbrains.com/resharper/docs/ReSharper40DefaultKeymap2.pdf for a full list.

Ted
+1  A: 

Adding to the existing vim answer, you can use d along with any cursor movement command to delete from the cursor's current position to the new position. For example, to delete...

  • ...to end-of-paragraph (usually meaning "to the next blank line"): d}
  • ...the line containing the cursor and the next 5 lines: d5j
  • ...a set of parentheses, braces, etc. and its contents: d% (with the cursor on the opening or closing paren/brace/etc.)
  • ...to the third appearance of the word "foo": d3/foo

It's quite flexible.

Dave Sherohman