Skip to content

ViMode crashed during c-F ViReplaceToCharBackward operation, attempting to specify ^ beginning of line. #4423

Open
@AltitudeApps

Description

@AltitudeApps

Prerequisites

  • Write a descriptive title.
  • Make sure you are able to repro it on the latest released version
  • Search the existing issues, especially the pinned issues.

Exception report

PS C:\Users\Home> `
          (GEt-Item $_.Path) | % {
Oops, something went wrong.
Please report this bug with ALL the details below, including both the 'Environment' and 'Exception' sections.
Please report on GitHub: https://github.com/PowerShell/PSReadLine/issues/new?template=Bug_Report.yaml
Thank you!      $_.BaseName
                $_.DirectoryName
### Environment;
PSReadLine: 2.3.6+d2e770f93b7a53d8660a6402eb29d1ae1c35e767
PowerShell: 7.5.0-rc.1Object -Property Count -Descending `
OS: Microsoft Windows 10.0.19045
BufferWidth: 195 -f blue $_.Group[0].Hash;
BufferHeight: 48oreach{
          }
Last 200 Keys:
    }
 c t Backspace Backspace Backspace l e c t - f o r k * " Spacebar ` Enter Backspace LeftArrow } Shift+Spacebar Enter O v e o p g a v e r Enter UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow DownArrow DownArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow DownArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow Enter UpArrow UpArrow UpArrow UpArrow UpArrow Enter UpArrow LeftArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow DownArrow DownArrow DownArrow Ctrl+[ d d UpArrow p UpArrow UpArrow p DownArrow DownArrow d d Enter UpArrow LeftArrow LeftArrow LeftArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow UpArrow Ctrl+[ d 8 d k k k k k o p Backspace Ctrl+[ p x Ctrl+[ Backspace Backspace x UpArrow p x UpArrow Ctrl+c UpArrow DownArrow DownArrow UpArrow RightArrow DownArrow DownArrow DownArrow DownArrow DownArrow DownArrow UpArrow UpArrow DownArrow d 8 d k k k k k p < Backspace x Ctrl+[ Backspace x RightArrow LeftArrow i Ctrl+[ < Backspace x DownArrow DownArrow DownArrow UpArrow UpArrow UpArrow Shift+DownArrow Shift+DownArrow Shift+DownArrow Shift+RightArrow Shift+RightArrow w c F ^ l s

### Exception

System.InvalidOperationException: Operation is not valid due to the current state of the object.
   at Microsoft.PowerShell.PSConsoleReadLine.StartEditGroup()
   at Microsoft.PowerShell.PSConsoleReadLine.GroupUndoHelper.StartGroup(Action`2 instigator, Object instigatorArg)
   at Microsoft.PowerShell.PSConsoleReadLine.ViInsertWithDelete(Nullable`1 key, Object arg)
   at Microsoft.PowerShell.PSConsoleReadLine.InputLoop()
   at Microsoft.PowerShell.PSConsoleReadLine.ReadLine(Runspace runspace, EngineIntrinsics engineIntrinsics, CancellationToken cancellationToken, Nullable`1 lastRunStatus)


PS C:\Users\Home> `
          (GEt-Item $_.Path) | % {
            $x = $(
                $_.Mode
                $_.LastWriteTime
                $_.BaseName
                $_.DirectoryName
              );
            $x -join ", "
  $moreThanOne | Sort-Object -Property Count -Descending `
  | % {
      Write-host -f blue $_.Group[0].Hash;
      $_.Group.Foreach{
          }
        }
    }

Screenshot

just after the exception:

Image

what was in my buffer the moment before:

Image

Environment data

PS Version: 7.5.0-rc.1
PS HostName: ConsoleHost (Windows Terminal)
PSReadLine Version: 2.3.6
PSReadLine EditMode: Vi
OS: 10.0.19041.1 (WinBuild.160101.0800)
BufferWidth: 195
BufferHeight: 48

Steps to reproduce

repro:

  1. open a powershell terminal. (either 5.1 or or 7)
  2. invoke Set-PSReadlineOption -editMode vi
  3. enter some text at the prompt
  4. press Esc to switch to vi command mode
  5. press the following keys: c F ^ c F
  6. now press ^ a final time, and the exception will occur.

screenshot here: #4423 (comment)

unfortunately I am unable to reproduce the issue in a fresh pwsh tab.
PLEASE STAND BY... I have been able to reproduce this in a fresh environment, by attempting the operation twice. I keep getting interrupted, but I intend to provide a full repro later today.

Expected behavior

Not sure what I would expect, because I was just experimenting with Vi mode, trying to remove spaces from the beginning of a line. As far as I know, the key keystrokes that I was using are not a valid way of performing the operation that I was attempting; I was just experimenting to see what would happen.

Larger context: I was trying to unindent a block of code which I had cut from below with 'd 8 d', and then pasted at the top with a 'p' command.

Actual behavior

** BOOM **

Metadata

Metadata

Assignees

No one assigned

    Labels

    Needs-Triage 🔍It's a new issue that core contributor team needs to triage.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions