Psreadline: Predictive IntelliSense

Created on 13 Apr 2020  Â·  9Comments  Â·  Source: PowerShell/PSReadLine

Reference issue: RFC#687

Predictive IntelliSense is an addition to the interactive experience to assist in command discovery
and accelerate full command execution. This enables new and experienced users of PowerShell to
discover, edit, and execute full commands based on matching predictions from the users history or
additional provider.

pi-static

Tab Completion has accelerated the success of both new and experienced PowerShell users. New users get the benefit of discovery; seeing available cmdlets and parameters as options while interactively typing. Experienced users receive the benefit of acceleration; typing less while using the key to quickly complete a command.

The increasing amount of technology translates to an increase in cmdlets and full command
complexity. Predictive IntelliSense is an addition to the concept of Tab Completion; helping the
user discover, build and edit full commands based on the users history or additional plugins.

The proposal is to add Predictive IntelliSense and enhancements for MenuComplete/Dynamic Help to the users interactive experience.

Predictive IntelliSense Protoype maybe found on PSGallery.

Proposed technical implementation details

  1. Predictive IntelliSense displays a best match command completion from command history. The
    prediction may change if a better match is found as the user types additional information. The
    predicted command may be accepted, edited, or ignored. It may be possible to support additional
    predictive providers.

pi-static

  1. Predictions are searchable and may be edited. Additional key bindings may be added to the users
    Profile as in the example below:
Set-PSReadLineKeyHandler -Key "Ctrl+d" -Function MenuComplete
Set-PSReadLineKeyHandler -Key "Ctrl+f" -Function ForwardWord
Set-PSReadLineKeyHandler -Key "Ctrl+b" -Function BackwardWord
Set-PSReadLineKeyHandler -Key "Ctrl+z" -Function Undo
Set-PSReadLineKeyHandler -Key UpArrow -Function HistorySearchBackward
Set-PSReadLineKeyHandler -Key DownArrow -Function HistorySearchForward
  1. Predictions are searchable based on the current cursor position.
  • Searching history from cmdlet verb.

pi-arrow-verb

  • Searching histroy from cmdlet noun.

pi-arrow-Noun

  • Searching history from parameter.

pi-arrow-param

  1. Predictions may be edited by stepping-through the parameters and arguments.
  • Moving forward and backward using additional key bindings.

pi-fb

  • Note: Changing the parameter/argument, changes the prediction.

pi-fb-arg

  1. MenuComplete/Dynamic Help is a current feature of PSReadLine. When combined with Predictive IntelliSense, MenuComplete provides additonal discovery and help information.
  • MenuComplete providing cmdlet discovery and help.

mc-noun2

  • MenuComplete providing parameter discovery and help.

mc-param

Open discussion items:

  • Should the number of lines displayed for MenuComplete be restricted and what should that
    restriction be?
  • Should an interactive cursor-based scroll bar for paging be included?
  • What should the content of Dynamic Help include?

mc-realestate

  1. Full cmdlet help is accessible using a key binding to access the help in a virtual terminal. An
    additional key binding will return the user from the virtual terminal to the previous screen.

dh-f1

  1. Predictive IntelliSense Accessibility is managed through the users profile.

pi-color

pi-color2

Set-PSReadLineOption -Colors @{ Prediction = '#8A0303'}
Set-PSReadLineOption -Colors @{ Prediction = '#2F7004'}

pi-color2-fb

Multiple color code values are supported currently in PSReadLine.

Examples of different color code values:

Set-PSReadLineOption -Colors @{ Prediction = 'DarkRed'}
 # Use a ConsoleColor enum
Set-PSReadLineOption -Colors @{ Prediction = [ConsoleColor]::DarkRed}
 # 24 bit color escape sequence
Set-PSReadLineOption -Colors @{ Prediction = "$([char]0x1b)[38;5;100m"}
 # RGB value
Set-PSReadLineOption -Colors @{ Prediction = "#8181f7"}
  1. Predictive IntelliSense Extensibility

It may be possible to support 1st party and 3rd party predictive plugins.

Issue-Enhancement

Most helpful comment

One other thing about the Dynamic Help feature... the PowerShell extension has been providing this experience for a while (see the box on the right):

image

It's called the completionItem/resolve request as a part of the language server protocol.

The idea here is... for a completion, give me _more details_ about it... but only send the request for more details when it is highlighted.

However, the PowerShell extension goes a step further to provide syntax as you're typing parameters too:

image

VS Code decided it was a good idea to separate this into it's own request called the Signature Help Request.

There are a lot of learning from the PowerShell extension and LSP that can be leveraged in the design of the features outlined here. Please consider them in the design.

All 9 comments

I'd also love to see proposed PowerShell API additions so that this isn't a shell-only feature. Something like this would be really nice in editors as well, for example.

What should the content of Dynamic Help include?

For cmdlets/functions it should show the synopsis. Syntax sounds helpful, but on bigger commands with lots of parameters and parameter sets it's... unwieldy.

For parameters it should should show the helpmessage, that normally only surfaces at the mandatory prompt when you type !?

Predictive IntelliSense Extensibility

I want to have this available in VS Code.

As a module author, I want to be able to inject common use cases for my modules' functions.

Predictions should also be based on the current working directory. Example: In some local repos I might do a git pull origin master but in others I do a git pull origin develop

This is amazing. Subscribed. I posted in the slack channel for vscode asking what magical vodoo was happening, as I had never seen this and it felt like such a natural thing to have. Didn't realize it got rolled out with the insiders powershell extension. Looking forward to the improvements. #win

it's work on non VT ?

One other thing about the Dynamic Help feature... the PowerShell extension has been providing this experience for a while (see the box on the right):

image

It's called the completionItem/resolve request as a part of the language server protocol.

The idea here is... for a completion, give me _more details_ about it... but only send the request for more details when it is highlighted.

However, the PowerShell extension goes a step further to provide syntax as you're typing parameters too:

image

VS Code decided it was a good idea to separate this into it's own request called the Signature Help Request.

There are a lot of learning from the PowerShell extension and LSP that can be leveraged in the design of the features outlined here. Please consider them in the design.

This is pretty cool. The first thing I do in my $profile is

set-psreadlineoption -editmode emacs

so that pressing tab lists all the choices at once.

I just upgraded to the prerelease version of PSReadLine and I see real potential for this feature. As it is now, though, I find the history-biased suggestions a bit frustrating. Consider this scenario:

  • current working directory is c:\foo\bar\baz
  • at some point in the past, I have entered the command cd ..\qux
  • unfortunately, c:\foo\bar _has no subdirectory_ named qux
  • nevertheless, while sitting at c:\foo\bar\baz, as soon as I type cd .. a ghostly \qux is suggested to me — a completely invalid path

Overall this seems far less useful than it would be if it were suggesting valid completions of the partially-typed command line. I'm fairly new to PSReadLine, so I'm sorry if this is a naive question, but is it possible to configure this behavior? Or to validate potential completions before suggesting them (and then not suggest invalid completions at all)?

I just upgraded to the prerelease version of PSReadLine and I see real potential for this feature. As it is now, though, I find the history-biased suggestions a bit frustrating. Consider this scenario:

  • current working directory is c:\foo\bar\baz
  • at some point in the past, I have entered the command cd ..\qux
  • unfortunately, c:\foo\bar _has no subdirectory_ named qux
  • nevertheless, while sitting at c:\foo\bar\baz, as soon as I type cd .. a ghostly \qux is suggested to me — a completely invalid path

Overall this seems far less useful than it would be if it were suggesting valid completions of the partially-typed command line. I'm fairly new to PSReadLine, so I'm sorry if this is a naive question, but is it possible to configure this behavior? Or to validate potential completions before suggesting them (and then not suggest invalid completions at all)?

AFAIK this happens because, currently, the only prediction source available is the commands history. Since it's a WIP, there's room for improvement, and probably the first would be to get history entries and then only let through (to the user) the ones that really would apply to his current terminal state (directory, Git repo, etc).

Was this page helpful?
0 / 5 - 0 ratings