Skip to content
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

Column select does not behave intuitively or consistently with other common editors #91647

Closed
zjturner opened this issue Feb 27, 2020 · 1 comment
Assignees
Labels
*duplicate Issue identified as a duplicate of another issue(s)

Comments

@zjturner
Copy link

zjturner commented Feb 27, 2020

This reproduces on all platforms and all versions of VSCode.

  1. Enter three lines of text:
ABC
BCD
CDE
  1. Use column-select to select BCD from the middle and press Ctrl+X to cut it.
  2. place the cursor after the C on the first line and make sure to you're out of multi-cursor edit mode.
  3. Press Ctrl+V

The end result is this:

ACB
C
D
BD
CE

The result should be this:

ACB
BDC
CED

Now, if you re-enter multi-cursor mode and select a 0x3 region on the right and then paste, it works. But this is both impractical and inconsistent with other editors.

It is impractical because for a large region of text, one can't realistically remember how many columns were selected as part of the Cut/Copy operation, and re-selecting a region of exactly the same size on the Paste is basically impossible. If you plan to paste within the same file, you might get lucky and have this work (as long as you don't click the mouse anywhere else at all before you go to the area you want to paste into), but if you want to paste into a separate editor window there's no solution here, because the editor forgets how many columns were selected as part of the original multi-cursor copy/cut operation. It also means that if I cut from VSCode and paste into another editor (or vice versa), it won't work correctly.

It is inconsistent with other editors because Visual Studio proper, Notepad++, and many other editors behave the way I've described as "expected" up above. If you do a box select and then copy or cut, then move the cursor anywhere else in the file (or another file) and paste, it behaves as expected.

It appears that VSCode is buggy on both the copy as well as the paste operations.

I determined that copy is buggy in VSCode by first selecting a rectangular area in Notepad++ and pasting it into Visual Studio (not VSCode). It behaves as expected, suggesting that this information is retained even cross-process, and that as long as clipboard data is constructed properly, Visual Studio can correctly paste data that was copied from another program. But when pasting data into VS that was originally copied from VSCode, it inserts new lines for each subsequent line of data that was copied, rather than pasting them into existing lines. So VSCode copy is not constructing the correct clipboard block

I determined that paste is buggy in VSCode by doing the converse. This time I copied from Visual Studio and pasted into VSCode, and lines were inserted. So even if the clipboard data is constructed correctly, VSCode still doesn't respect it.

@alexdima
Copy link
Member

alexdima commented Mar 9, 2020

Duplicate of #5940

@alexdima alexdima marked this as a duplicate of #5940 Mar 9, 2020
@alexdima alexdima closed this as completed Mar 9, 2020
@alexdima alexdima added the *duplicate Issue identified as a duplicate of another issue(s) label Mar 9, 2020
@github-actions github-actions bot locked and limited conversation to collaborators Apr 23, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
*duplicate Issue identified as a duplicate of another issue(s)
Projects
None yet
Development

No branches or pull requests

2 participants