Compartilhar via


PSReadLine

about_PSReadLine

Descrição breve

O PSReadLine fornece uma experiência aprimorada de edição de linha de comando no console do PowerShell.

Descrição longa

O PSReadLine 2.0 fornece uma experiência avançada de edição de linha de comando para o console do PowerShell. Ele fornece:

  • Coloração de sintaxe da linha de comando
  • Uma indicação visual de erros de sintaxe
  • Uma melhor experiência de várias linhas (edição e histórico)
  • Associações de chave personalizáveis
  • Modos Cmd e Emacs
  • Muitas opções de configuração
  • Preenchimento de estilo bash (opcional no modo Cmd, padrão no modo Emacs)
  • Emacs ianque/kill-ring
  • Movimentação de "palavra" baseada em token do PowerShell e encerramento

O PSReadLine requer o PowerShell 3.0 ou mais recente e o host do console. Ele não funciona no ISE do PowerShell. Ele funciona no console do Visual Studio Code.

Observação

A partir do PowerShell 7.0, o PowerShell ignorará o carregamento automático do PSReadLine no Windows se um programa de leitor de tela for detectado. Atualmente, o PSReadLine não funciona bem com os leitores de tela. A renderização e a formatação padrão do PowerShell 7.0 no Windows funcionam corretamente. Você pode carregar manualmente o módulo, se necessário.

As funções a seguir estão disponíveis na classe [Microsoft.PowerShell.PSConsoleReadLine].

Funções básicas de edição

Anular

Anular a ação atual, por exemplo, pesquisa de histórico incremental.

  • Emacs: <Ctrl+g>

AcceptAndGetNext

Tente executar a entrada atual. Se ele puder ser executado (como AcceptLine), lembre-se do próximo item do histórico na próxima vez que ReadLine for chamado.

  • Emacs: <Ctrl+o>

AcceptLine

Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento, colchete ou aspas ausentes, o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves editarem a entrada atual.

  • Cmd: <Enter>
  • Emacs: <Enter>
  • Modo de inserção vi: <Enter>

Addline

O prompt de continuação é exibido na próxima linha e PSReadLine aguarda as chaves editarem a entrada atual. Isso é útil para inserir a entrada de várias linhas como um único comando, mesmo quando uma única linha é a entrada completa por si só.

  • Cmd: <Shift+Enter>
  • Emacs: <Shift+Enter>
  • Modo de inserção vi: <Shift+Enter>
  • Modo de comando Vi: <Shift+Enter>

BackwardDeleteChar

Exclua o caractere antes do cursor.

  • Cmd: <Backspace>, <Ctrl+h>
  • Emacs: <Backspace>, <Ctrl+Backspace>, <Ctrl+h>
  • Modo de inserção vi: <Backspace>
  • Modo de comando Vi: <X>, <d,h>

BackwardDeleteLine

Como BackwardKillLine – exclui o texto do ponto até o início da linha, mas não coloca o texto excluído no kill-ring.

  • Cmd: <Ctrl+Home>
  • Modo de inserção vi: <Ctrl+u>, <Ctrl+Home>
  • Modo de comando Vi: <Ctrl+u>, <Ctrl+Home>, <d,0>

BackwardDeleteWord

Exclui a palavra anterior.

  • Modo de comando Vi: <Ctrl+w>, <d,b>

BackwardKillLine

Limpe a entrada do início da entrada para o cursor. O texto limpo é colocado no kill-ring.

  • Emacs: <Ctrl+u>, <Ctrl+x,Backspace>

BackwardKillWord

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto limpo é colocado no kill-ring.

  • Cmd: <Ctrl+Backspace>
  • Emacs: <Alt+Backspace>, <Escape,Backspace>
  • Modo de inserção vi: <Ctrl+Backspace>
  • Modo de comando Vi: <Ctrl+Backspace>

CancelLine

Cancele a entrada atual, deixando a entrada na tela, mas retorna para o host para que o prompt seja avaliado novamente.

  • Modo de inserção vi: <Ctrl+c>
  • Modo de comando Vi: <Ctrl+c>

Copiar

Copie a região selecionada para a área de transferência do sistema. Se nenhuma região estiver selecionada, copie a linha inteira.

  • Cmd: <Ctrl+C>

CopyOrCancelLine

Se o texto estiver selecionado, copie para a área de transferência, caso contrário, cancele a linha.

  • Cmd: <Ctrl+c>
  • Emacs: <Ctrl+c>

Recortar

Exclua a região selecionada colocando o texto excluído na área de transferência do sistema.

  • Cmd: <Ctrl+x>

DeleteChar

Exclua o caractere sob o cursor.

  • Cmd: <Delete>
  • Emacs: <Delete>
  • Modo de inserção vi: <Delete>
  • Modo de comando Vi: <Delete>, <x>, <d,l>, <d,Space>

DeleteCharOrExit

Exclua o caractere sob o cursor ou, se a linha estiver vazia, saia do processo.

  • Emacs: <Ctrl+d>

DeleteEndOfWord

Exclua até o final da palavra.

  • Modo de comando Vi: <d,e>

DeleteLine

Exclui a linha atual, permitindo desfazer.

  • Modo de comando Vi: <d,d>

DeleteLineToFirstChar

Exclui o texto do cursor para o primeiro caractere não em branco da linha.

  • Modo de comando Vi: <d,^>

DeleteToEnd

Exclua até o final da linha.

  • Modo de comando Vi: <D>, <d,$>

DeleteWord

Exclua a próxima palavra.

  • Modo de comando Vi: <d,w>

ForwardDeleteLine

Como ForwardKillLine – exclui o texto do ponto até o final da linha, mas não coloca o texto excluído no kill-ring.

  • Cmd: <Ctrl+End>
  • Modo de inserção vi: <Ctrl+End>
  • Modo de comando Vi: <Ctrl+End>

InsertLineAbove

Uma nova linha vazia é criada acima da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor se move para o início da nova linha.

  • Cmd: <Ctrl+Enter>

InsertLineBelow

Uma nova linha vazia é criada abaixo da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor se move para o início da nova linha.

  • Cmd: <Shift+Ctrl+Enter>

InvertCase

Inverta o caso do caractere atual e vá para o próximo.

  • Modo de comando Vi: <~>

KillLine

Limpe a entrada do cursor até o final da entrada. O texto limpo é colocado no kill-ring.

  • Emacs: <Ctrl+k>

KillRegion

Encerre o texto entre o cursor e a marca.

  • A função não está relacionada.

KillWord

Limpe a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será limpa do cursor até o final da próxima palavra. O texto limpo é colocado no kill-ring.

  • Cmd: <Ctrl+Delete>
  • Emacs: <Alt+d>, <Escape,d>
  • Modo de inserção vi: <Ctrl+Delete>
  • Modo de comando Vi: <Ctrl+Delete>

Colar

Cole o texto da área de transferência do sistema.

  • Cmd: <Ctrl+v>, <Shift+Insert>
  • Modo de inserção vi: <Ctrl+v>
  • Modo de comando Vi: <Ctrl+v>

Importante

Ao usar a função Colar , todo o conteúdo do buffer da área de transferência é colado no buffer de entrada do PSReadLine. Em seguida, o buffer de entrada é passado para o analisador do PowerShell. A entrada colada usando o método de colagem de clique com o botão direito do mouse do aplicativo de console é copiada para o buffer de entrada um caractere por vez. O buffer de entrada é passado para o analisador quando um caractere de nova linha é copiado. Portanto, a entrada é analisada uma linha por vez. A diferença entre os métodos de colagem resulta em um comportamento de execução diferente.

PasteAfter

Cole a área de transferência após o cursor, movendo o cursor para o final do texto colado.

  • Modo de comando Vi: <p>

PasteBefore

Cole a área de transferência antes do cursor, movendo o cursor para o final do texto colado.

  • Modo de comando Vi: <P>

PrependAndAccept

Acrescente um '#' e aceite a linha.

  • Modo de comando Vi: <#>

Refazer

Desfazer uma desfaça.

  • Cmd: <Ctrl+y>
  • Modo de inserção vi: <Ctrl+y>
  • Modo de comando Vi: <Ctrl+y>

RepeatLastCommand

Repita a última modificação de texto.

  • Modo de comando Vi: <.>

RevertLine

Reverte toda a entrada para a entrada atual.

  • Cmd: <Escape>
  • Emacs: <Alt+r>, <Escape,r>

ShellBackwardKillWord

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto limpo é colocado no kill-ring.

A função não está relacionada.

ShellKillWord

Limpe a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será limpa do cursor até o final da próxima palavra. O texto limpo é colocado no kill-ring.

A função não está relacionada.

SwapCharacters

Troque o caractere atual e o antes dele.

  • Emacs: <Ctrl+t>
  • Modo de inserção vi: <Ctrl+t>
  • Modo de comando Vi: <Ctrl+t>

Desfazer

Desfazer uma edição anterior.

  • Cmd: <Ctrl+z>
  • Emacs: <Ctrl+_>, <Ctrl+x,Ctrl+u>
  • Modo de inserção vi: <Ctrl+z>
  • Modo de comando Vi: <Ctrl+z>, <u>

UndoAll

Desfazer todas as edições anteriores da linha.

  • Modo de comando Vi: <U>

UnixWordRubout

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto limpo é colocado no kill-ring.

  • Emacs: <Ctrl+w>

ValidateAndAcceptLine

Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento, colchete ou aspas ausentes, o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves editarem a entrada atual.

  • Emacs: <Ctrl+m>

ViAcceptLine

Aceite a linha e alterne para o modo Inserir.

  • Modo de comando Vi: <Enter>

ViAcceptLineOrExit

Como DeleteCharOrExit no modo Emacs, mas aceita a linha em vez de excluir um caractere.

  • Modo de inserção vi: <Ctrl+d>
  • Modo de comando Vi: <Ctrl+d>

ViAppendLine

Uma nova linha é inserida abaixo da linha atual.

  • Modo de comando Vi: <o>

ViBackwardDeleteGlob

Exclui a palavra anterior, usando apenas espaço em branco como delimitador de palavra.

  • Modo de comando Vi: <d,B>

ViBackwardGlob

Move o cursor de volta para o início da palavra anterior, usando apenas espaço em branco como delimitadores.

  • Modo de comando Vi: <B>

ViDeleteBrace

Localize a chave, parênteses ou colchetes correspondentes e exclua todo o conteúdo dentro, incluindo a chave.

  • Modo de comando Vi: <d,%>

ViDeleteEndOfGlob

Exclua até o final da palavra.

  • Modo de comando Vi: <d,E>

ViDeleteGlob

Exclua o próximo glob (palavra delimitada por espaço em branco).

  • Modo de comando Vi: <d,W>

ViDeleteToBeforeChar

Exclui até o caractere especificado.

  • Modo de comando Vi: <d,t>

ViDeleteToBeforeCharBackward

Exclui até o caractere especificado.

  • Modo de comando Vi: <d,T>

ViDeleteToChar

Exclui até o caractere especificado.

  • Modo de comando Vi: <d,f>

ViDeleteToCharBackward

Exclui para trás até o caractere especificado.

  • Modo de comando Vi: <d,F>

ViInsertAtBegining

Alterne para o modo Inserir e posicione o cursor no início da linha.

  • Modo de comando Vi: <I>

ViInsertAtEnd

Alterne para o modo Inserir e posicione o cursor no final da linha.

  • Modo de comando Vi: <A>

ViInsertLine

Uma nova linha é inserida acima da linha atual.

  • Modo de comando Vi: <O>

ViInsertWithAppend

Acrescente da posição da linha atual.

  • Modo de comando Vi: <a>

ViInsertWithDelete

Exclua o caractere atual e alterne para o modo Inserir.

  • Modo de comando Vi: <s>

ViJoinLines

Une a linha atual e a próxima linha.

  • Modo de comando Vi: <J>

ViReplaceLine

Apagar toda a linha de comando.

  • Modo de comando Vi: <S>, <c,c>

ViReplaceToBeforeChar

Substitui até o caractere especificado.

  • Modo de comando Vi: <c,t>

ViReplaceToBeforeCharBackward

Substitui até o caractere especificado.

  • Modo de comando Vi: <c,T>

ViReplaceToChar

Exclui até o caractere especificado.

  • Modo de comando Vi: <c,f>

ViReplaceToCharBackward

Substitui até o caractere especificado.

  • Modo de comando Vi: <c,F>

ViYankBeginningOfLine

Puxe do início do buffer para o cursor.

  • Modo de comando Vi: <y,0>

ViYankEndOfGlob

Puxe do cursor até o final do(s) WORD(s).

  • Modo de comando Vi: <y,E>

ViYankEndOfWord

Puxe do cursor até o final da(s) palavra(s).

  • Modo de comando Vi: <y,e>

ViYankLeft

Puxe caracteres à esquerda do cursor.

  • Modo de comando Vi: <y,h>

ViYankLine

Puxe todo o buffer.

  • Modo de comando Vi: <y,y>

ViYankNextGlob

Puxe do cursor para o início das próximas PALAVRAS.

  • Modo de comando Vi: <y,W>

ViYankNextWord

Puxe a(s) palavra(s) após o cursor.

  • Modo de comando vi: <y,w>

ViYankPercent

Puxe de/para a chave correspondente.

  • Modo de comando vi: <y,%>

ViYankPreviousGlob

Puxe do início do WORD(s) para o cursor.

  • Modo de comando vi: <y,B>

ViYankPreviousWord

Puxe a(s) palavra(s) antes do cursor.

  • Modo de comando vi: <y,b>

ViYankRight

Puxe caracteres sob e à direita do cursor.

  • Modo de comando Vi: <y,l>, <y,Space>

ViYankToEndOfLine

Puxe do cursor até o final do buffer.

  • Modo de comando vi: <y,$>

ViYankToFirstChar

Puxe do primeiro caractere não whitespace para o cursor.

  • Modo de comando vi: <y,^>

Ianque

Adicione o texto morto mais recentemente à entrada.

  • Emacs: <Ctrl+y>

YankLastArg

Puxe o último argumento da linha de histórico anterior. Com um argumento, a primeira vez que ele é invocado, comporta-se exatamente como YankeeNthArg. Se invocado várias vezes, em vez disso, itera através do histórico e arg define a direção (negativo inverte a direção.)

  • Cmd: <Alt+.>
  • Emacs: <Alt+.>, <Alt+_>, , <Escape,.><Escape,_>

YankeeNthArg

Puxe o primeiro argumento (após o comando) da linha de histórico anterior. Com um argumento , puxe o nº argumento (começando a partir de 0), se o argumento for negativo, comece a partir do último argumento.

  • Emacs: <Ctrl+Alt+y>, <Escape,Ctrl+y>

YankPop

Se a operação anterior for Ianque ou IanquePop, substitua o texto anteriormente arrancado pelo próximo texto morto do anel de morte.

  • Emacs: <Alt+y>, <Escape,y>

Funções de movimento do cursor

BackwardChar

Mova o cursor um caractere para a esquerda. Isso pode mover o cursor para a linha anterior de entrada de várias linhas.

  • Cmd: <LeftArrow>
  • Emacs: <LeftArrow>, <Ctrl+b>
  • Modo de inserção vi: <LeftArrow>
  • Modo de comando vi: <LeftArrow>, <Backspace>, <h>

BackwardWord

Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Word limites são definidos por um conjunto configurável de caracteres.

  • Cmd: <Ctrl+LeftArrow>
  • Emacs: <Alt+b>, <Escape,b>
  • Modo de inserção vi: <Ctrl+LeftArrow>
  • Modo de comando vi: <Ctrl+LeftArrow>

BeginningOfLine

Se a entrada tiver várias linhas, vá para o início da linha atual ou, se já estiver no início da linha, vá para o início da entrada. Se a entrada tiver uma única linha, vá para o início da entrada.

  • Cmd: <Home>
  • Emacs: <Home>, <Ctrl+a>
  • Modo de inserção vi: <Home>
  • Modo de comando vi: <Home>

EndOfLine

Se a entrada tiver várias linhas, mova para o final da linha atual ou, se já estiver no final da linha, vá para o final da entrada. Se a entrada tiver uma única linha, vá para o final da entrada.

  • Cmd: <End>
  • Emacs: <End>, <Ctrl+e>
  • Modo de inserção vi: <End>

ForwardChar

Mova o cursor um caractere para a direita. Isso pode mover o cursor para a próxima linha de entrada de várias linhas.

  • Cmd: <RightArrow>
  • Emacs: <RightArrow>, <Ctrl+f>
  • Modo de inserção vi: <RightArrow>
  • Modo de comando vi: <RightArrow>, <Space>, <l>

ForwardWord

Mova o cursor para o final da palavra atual ou, se houver palavras, para o final da próxima palavra. Word limites são definidos por um conjunto configurável de caracteres.

  • Emacs: <Alt+f>, <Escape,f>

GotoBrace

Vá para a chave correspondente, parêntese ou colchete.

  • Cmd: <Ctrl+]>
  • Modo de inserção vi: <Ctrl+]>
  • Modo de comando vi: <Ctrl+]>

GotoColumn

Mova para a coluna indicada por arg.

  • Modo de comando vi: <|>

GotoFirstNonBlankOfLine

Mova o cursor para o primeiro caractere não em branco na linha.

  • Modo de comando vi: <^>

MoveToEndOfLine

Mova o cursor para o final da entrada.

  • Modo de comando Vi: <End>, <$>

NextLine

Mova o cursor para a próxima linha.

  • A função é desvinculada.

NextWord

Mova o cursor para o início da próxima palavra. Word limites são definidos por um conjunto configurável de caracteres.

  • Cmd: <Ctrl+RightArrow>
  • Modo de inserção vi: <Ctrl+RightArrow>
  • Modo de comando vi: <Ctrl+RightArrow>

NextWordEnd

Mova o cursor para o final da palavra atual ou, se houver palavras, para o final da próxima palavra. Word limites são definidos por um conjunto configurável de caracteres.

  • Modo de comando vi: <e>

PreviousLine

Mova o cursor para a linha anterior.

  • A função é desvinculada.

ShellBackwardWord

Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Word limites são definidos por tokens do PowerShell.

  • A função é desvinculada.

ShellForwardWord

Mova o cursor para o início da próxima palavra. Word limites são definidos por tokens do PowerShell.

  • A função é desvinculada.

ShellNextWord

Mova o cursor para o final da palavra atual ou, se houver palavras, para o final da próxima palavra. Word limites são definidos por tokens do PowerShell.

  • A função é desvinculada.

ViBackwardWord

Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Word limites são definidos por um conjunto configurável de caracteres.

  • Modo de comando vi: <b>

ViEndOfGlob

Move o cursor para o final da palavra, usando apenas espaço em branco como delimitadores.

  • Modo de comando vi: <E>

ViEndOfPreviousGlob

Move-se para o final da palavra anterior, usando apenas espaço em branco como um delimitador de palavras.

  • A função é desvinculada.

ViGotoBrace

Semelhante a GotoBrace, mas é baseado em caractere em vez de baseado em token.

  • Modo de comando vi: <%>

ViNextGlob

Passa para a próxima palavra, usando apenas espaço em branco como delimitador de palavras.

  • Modo de comando vi: <W>

ViNextWord

Mova o cursor para o início da próxima palavra. Word limites são definidos por um conjunto configurável de caracteres.

  • Modo de comando vi: <w>

Funções de histórico

BeginningOfHistory

Mova para o primeiro item do histórico.

  • Emacs: <Alt+<>'

ClearHistory

Limpa o histórico no PSReadLine. Isso não afeta o histórico do PowerShell.

  • Cmd: <Alt+F7>

EndOfHistory

Mova para o último item (a entrada atual) no histórico.

  • Emacs: <Alt+>>

ForwardSearchHistory

Execute uma pesquisa de encaminhamento incremental por meio do histórico.

  • Cmd: <Ctrl+s>
  • Emacs: <Ctrl+s>

HistorySearchBackward

Substitua a entrada atual pelo item 'anterior' do histórico PSReadLine que corresponde aos caracteres entre o início e a entrada e o cursor.

  • Cmd: <F8>

HistorySearchForward

Substitua a entrada atual pelo item 'next' do histórico PSReadLine que corresponde aos caracteres entre o início e a entrada e o cursor.

  • Cmd: <Shift+F8>

NextHistory

Substitua a entrada atual pelo item 'next' do histórico PSReadLine.

  • Cmd: <DownArrow>
  • Emacs: <DownArrow>, <Ctrl+n>
  • Modo de inserção vi: <DownArrow>
  • Modo de comando vi: <DownArrow>, <j>, <+>

PreviousHistory

Substitua a entrada atual pelo item 'anterior' do histórico PSReadLine.

  • Cmd: <UpArrow>
  • Emacs: <UpArrow>, <Ctrl+p>
  • Modo de inserção vi: <UpArrow>
  • Modo de comando vi: <UpArrow>, <k>, <->

ReverseSearchHistory

Execute uma pesquisa incremental com versões anteriores por meio do histórico.

  • Cmd: <Ctrl+r>
  • Emacs: <Ctrl+r>

ViSearchHistoryBackward

Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.

  • Modo de inserção vi: <Ctrl+r>
  • Modo de comando Vi: </>, <Ctrl+r>

Funções de conclusão

Concluir

Tente executar a conclusão no texto ao redor do cursor. Se houver várias conclusões possíveis, o prefixo inequívoco mais longo será usado para conclusão. Se estiver tentando concluir a conclusão inequívoca mais longa, uma lista de conclusões possíveis será exibida.

  • Emacs: <Tab>

Tente executar a conclusão no texto ao redor do cursor. Se houver várias conclusões possíveis, o prefixo inequívoco mais longo será usado para conclusão. Se estiver tentando concluir a conclusão inequívoca mais longa, uma lista de conclusões possíveis será exibida.

  • Cmd: <Ctrl+Space>
  • Emacs: <Ctrl+Space>

PossibleCompletions

Exiba a lista de conclusões possíveis.

  • Emacs: <Alt+=>
  • Modo de inserção vi: <Ctrl+Space>
  • Modo de comando vi: <Ctrl+Space>

TabCompleteNext

Tente concluir o texto em torno do cursor com a próxima conclusão disponível.

  • Cmd: <Tab>
  • Modo de comando vi: <Tab>

TabCompletePrevious

Tente concluir o texto ao redor do cursor com a conclusão disponível anterior.

  • Cmd: <Shift+Tab>
  • Modo de comando Vi: <Shift+Tab>

ViTabCompleteNext

Encerra o grupo de edição atual, se necessário, e invoca TabCompleteNext.

  • Modo de inserção vi: <Tab>

ViTabCompletePrevious

Encerra o grupo de edição atual, se necessário, e invoca TabCompletePrevious.

  • Modo de inserção vi: <Shift+Tab>

Funções diversas

CaptureScreen

Inicie a captura de tela interativa – setas para cima/para baixo selecionem linhas, insira o texto selecionado para a área de transferência como texto e html.

  • A função não está relacionada.

ClearScreen

Limpe a tela e desenhe a linha atual na parte superior da tela.

  • Cmd: <Ctrl+l>
  • Emacs: <Ctrl+l>
  • Modo de inserção vi: <Ctrl+l>
  • Modo de comando Vi: <Ctrl+l>

DigitArgument

Inicie um novo argumento de dígito para passar para outras funções.

  • Cmd: <Alt+0>, <Alt+1>, <Alt+2>, , <Alt+4><Alt+3>, <Alt+5>, <Alt+6>, <Alt+7>, <Alt+8>, , <Alt+9>,<Alt+->
  • Emacs: <Alt+0>, <Alt+1>, , <Alt+2>, <Alt+4><Alt+3>, <Alt+5>, <Alt+6>, <Alt+7>, <Alt+8>, , <Alt+9>,<Alt+->
  • Modo de comando Vi: <0>, <1>, , <3><2>, <4>, <5>, <6>, <7>, , <8><9>

InvokePrompt

Apaga o prompt atual e chama a função prompt para exibir novamente o prompt. Útil para manipuladores de chave personalizados que alteram o estado, por exemplo, altere o diretório atual.

  • A função não está relacionada.

ScrollDisplayDown

Role a tela para baixo em uma tela.

  • Cmd: <PageDown>
  • Emacs: <PageDown>

ScrollDisplayDownLine

Role a tela uma linha para baixo.

  • Cmd: <Ctrl+PageDown>
  • Emacs: <Ctrl+PageDown>

ScrollDisplayToCursor

Role a tela até o cursor.

  • Emacs: <Ctrl+End>

ScrollDisplayTop

Role a tela até a parte superior.

  • Emacs: <Ctrl+Home>

ScrollDisplayUp

Role a tela para cima em uma tela.

  • Cmd: <PageUp>
  • Emacs: <PageUp>

ScrollDisplayUpLine

Role a tela para cima em uma linha.

  • Cmd: <Ctrl+PageUp>
  • Emacs: <Ctrl+PageUp>

SelfInsert

Insira a chave.

  • A função não está relacionada.

ShowKeyBindings

Mostrar todas as teclas associadas.

  • Cmd: <Ctrl+Alt+?>
  • Emacs: <Ctrl+Alt+?>
  • Modo de inserção vi: <Ctrl+Alt+?>

ViCommandMode

Alterne o modo de operação atual de Vi-Insert para Vi-Command.

  • Modo de inserção vi: <Escape>

ViDigitArgumentInChord

Inicie um novo argumento de dígito para passar para outras funções enquanto estiver em um dos acordes de vi.

  • A função não está relacionada.

ViEditVisually

Edite a linha de comando em um editor de texto especificado por $env:EDITOR ou $env:VISUAL.

  • Emacs: <Ctrl+x,Ctrl+e>
  • Modo de comando Vi: <v>

ViExit

Sai do shell.

  • A função não está relacionada.

ViInsertMode

Alterne para o modo Inserir.

  • Modo de comando Vi: <i>

WhatIsKey

Leia uma chave e me diga a qual chave está associada.

  • Cmd: <Alt+?>
  • Emacs: <Alt+?>

Funções de seleção

ExchangePointAndMark

O cursor é colocado no local da marca e a marca é movida para o local do cursor.

  • Emacs: <Ctrl+x,Ctrl+x>

SelectAll

Selecione a linha inteira.

  • Cmd: <Ctrl+a>

SelectBackwardChar

Ajuste a seleção atual para incluir o caractere anterior.

  • Cmd: <Shift+LeftArrow>
  • Emacs: <Shift+LeftArrow>

SelectBackwardsLine

Ajuste a seleção atual para incluir do cursor até o início da linha.

  • Cmd: <Shift+Home>
  • Emacs: <Shift+Home>

SelectBackwardWord

Ajuste a seleção atual para incluir a palavra anterior.

  • Cmd: <Shift+Ctrl+LeftArrow>
  • Emacs: <Alt+B>

SelectForwardChar

Ajuste a seleção atual para incluir o próximo caractere.

  • Cmd: <Shift+RightArrow>
  • Emacs: <Shift+RightArrow>

SelectForwardWord

Ajuste a seleção atual para incluir a próxima palavra usando ForwardWord.

  • Emacs: <Alt+F>

Selecionar Linha

Ajuste a seleção atual para incluir do cursor até o final da linha.

  • Cmd: <Shift+End>
  • Emacs: <Shift+End>

SelectNextWord

Ajuste a seleção atual para incluir a próxima palavra.

  • Cmd: <Shift+Ctrl+RightArrow>

SelectShellBackwardWord

Ajuste a seleção atual para incluir a palavra anterior usando ShellBackwardWord.

  • A função não está relacionada.

SelectShellForwardWord

Ajuste a seleção atual para incluir a próxima palavra usando ShellForwardWord.

  • A função não está relacionada.

SelectShellNextWord

Ajuste a seleção atual para incluir a próxima palavra usando ShellNextWord.

  • A função não está relacionada.

SetMark

Marque o local atual do cursor para uso em um comando de edição subsequente.

  • Emacs: <Ctrl+>'

Pesquisa funções

CharacterSearch

Leia um caractere e pesquise a próxima ocorrência desse caractere. Se um argumento for especificado, pesquise para frente (ou para trás se negativo) para a nª ocorrência.

  • Cmd: <F3>
  • Emacs: <Ctrl+]>
  • Modo de inserção vi: <F3>
  • Modo de comando Vi: <F3>

CharacterSearchBackward

Leia um caractere e pesquise para trás a próxima ocorrência desse caractere. Se um argumento for especificado, pesquise para trás (ou para frente, se negativo) para a nª ocorrência.

  • Cmd: <Shift+F3>
  • Emacs: <Ctrl+Alt+]>
  • Modo de inserção vi: <Shift+F3>
  • Modo de comando Vi: <Shift+F3>

RepeatLastCharSearch

Repita a última pesquisa de caracteres gravada.

  • Modo de comando Vi: <;>

RepeatLastCharSearchBackwards

Repita a última pesquisa de caracteres gravada, mas na direção oposta.

  • Modo de comando Vi: <,>

RepeatSearch

Repita a última pesquisa na mesma direção de antes.

  • Modo de comando Vi: <n>

RepeatSearchBackward

Repita a última pesquisa na mesma direção de antes.

  • Modo de comando Vi: <N>

SearchChar

Leia o próximo caractere e, em seguida, encontre-o, daqui para frente e, em seguida, desative um caractere. Isso é para a funcionalidade 't'.

  • Modo de comando Vi: <f>

SearchCharBackward

Leia o próximo caractere e, em seguida, encontre-o, indo para trás e, em seguida, desative um caractere. Isso é para a funcionalidade 'T'.

  • Modo de comando Vi: <F>

SearchCharBackwardWithBackoff

Leia o próximo caractere e, em seguida, encontre-o, indo para trás e, em seguida, desative um caractere. Isso é para a funcionalidade 'T'.

  • Modo de comando Vi: <T>

SearchCharWithBackoff

Leia o próximo caractere e, em seguida, encontre-o, daqui para frente e, em seguida, desative um caractere. Isso é para a funcionalidade 't'.

  • Modo de comando Vi: <t>

Searchforward

Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.

  • Modo de inserção vi: <Ctrl+s>
  • Modo de comando Vi: <?>, <Ctrl+s>

Associações de chave personalizadas

O PSReadLine dá suporte a associações de chave personalizadas usando o cmdlet Set-PSReadLineKeyHandler. A maioria das associações de chave personalizadas chama uma das funções acima, por exemplo

Set-PSReadLineKeyHandler -Key UpArrow -Function HistorySearchBackward

Você pode associar um ScriptBlock a uma chave. O ScriptBlock pode fazer praticamente tudo o que você quiser. Alguns exemplos úteis incluem

  • editar a linha de comando
  • abrindo uma nova janela (por exemplo, ajuda)
  • alterar diretórios sem alterar a linha de comando

O ScriptBlock recebe dois argumentos:

  • $key - Um objeto [ConsoleKeyInfo] que é a chave que disparou a associação personalizada. Se você associar o mesmo ScriptBlock a várias chaves e precisar executar ações diferentes dependendo da chave, poderá marcar $key. Muitas associações personalizadas ignoram esse argumento.

  • $arg - Um argumento arbitrário. Na maioria das vezes, esse seria um argumento inteiro que o usuário passa das associações de chave DigitArgument. Se a associação não aceitar argumentos, será razoável ignorar esse argumento.

Vamos dar uma olhada em um exemplo que adiciona uma linha de comando ao histórico sem executá-la. Isso é útil quando você percebe que esqueceu de fazer algo, mas não deseja inserir novamente a linha de comando que você já inseriu.

$parameters = @{
    Key = 'Alt+w'
    BriefDescription = 'SaveInHistory'
    LongDescription = 'Save current line in history but do not execute'
    ScriptBlock = {
      param($key, $arg)   # The arguments are ignored in this example

      # GetBufferState gives us the command line (with the cursor position)
      $line = $null
      $cursor = $null
      [Microsoft.PowerShell.PSConsoleReadLine]::GetBufferState([ref]$line,
        [ref]$cursor)

      # AddToHistory saves the line in history, but does not execute it.
      [Microsoft.PowerShell.PSConsoleReadLine]::AddToHistory($line)

      # RevertLine is like pressing Escape.
      [Microsoft.PowerShell.PSConsoleReadLine]::RevertLine()
  }
}
Set-PSReadLineKeyHandler @parameters

Você pode ver muitos outros exemplos no arquivo SamplePSReadLineProfile.ps1 que está instalado na pasta do módulo PSReadLine.

A maioria das associações de teclas usa algumas funções auxiliares para editar a linha de comando. Essas APIs estão documentadas na próxima seção.

APIs de suporte à associação de chave personalizada

As funções a seguir são públicas em Microsoft.PowerShell.PSConsoleReadLine, mas não podem ser associadas diretamente a uma chave. A maioria é útil em associações de chave personalizadas.

void AddToHistory(string command)

Adicione uma linha de comando ao histórico sem executá-la.

void ClearKillRing()

Limpe o kill-ring. Isso é usado principalmente para teste.

void Delete(int start, int length)

Exclua caracteres de comprimento desde o início. Esta operação dá suporte a desfazer/refazer.

void Ding()

Execute a ação Ding com base na preferência dos usuários.

void GetBufferState([ref] string input, [ref] int cursor)
void GetBufferState([ref] Ast ast, [ref] Token[] tokens,
  [ref] ParseError[] parseErrors, [ref] int cursor)

Essas duas funções recuperam informações úteis sobre o estado atual do buffer de entrada. O primeiro é mais comumente usado para casos simples. O segundo será usado se a associação estiver fazendo algo mais avançado com o Ast.

IEnumerable[Microsoft.PowerShell.KeyHandler]
  GetKeyHandlers(bool includeBound, bool includeUnbound)

Essa função é usada por Get-PSReadLineKeyHandler e provavelmente não é útil em uma associação de chave personalizada.

Microsoft.PowerShell.PSConsoleReadLineOptions GetOptions()

Essa função é usada por Get-PSReadLineOption e provavelmente não é muito útil em uma associação de chave personalizada.

void GetSelectionState([ref] int start, [ref] int length)

Se não houver seleção na linha de comando, -1 será retornado no início e no comprimento. Se houver uma seleção na linha de comando, o início e o comprimento da seleção serão retornados.

void Insert(char c)
void Insert(string s)

Insira um caractere ou cadeia de caracteres no cursor. Esta operação dá suporte a desfazer/refazer.

string ReadLine(runspace remoteRunspace,
  System.Management.Automation.EngineIntrinsics engineIntrinsics)

Esse é o ponto de entrada main para PSReadLine. Ele não dá suporte à recursão, portanto, não é útil em uma associação de chave personalizada.

void RemoveKeyHandler(string[] key)

Essa função é usada por Remove-PSReadLineKeyHandler e provavelmente não é muito útil em uma associação de chave personalizada.

void Replace(int start, int length, string replacement)

Substitua parte da entrada. Esta operação dá suporte a desfazer/refazer. Isso é preferencial em vez de Excluir seguido por Inserir porque ele é tratado como uma única ação para desfazer.

void SetCursorPosition(int cursor)

Mova o cursor para o deslocamento fornecido. O movimento do cursor não é rastreado para desfazer.

void SetOptions(Microsoft.PowerShell.SetPSReadLineOption options)

Essa função é um método auxiliar usado pelo cmdlet Set-PSReadLineOption, mas pode ser útil para uma associação de chave personalizada que deseja alterar temporariamente uma configuração.

bool TryGetArgAsInt(System.Object arg, [ref] int numericArg,
  int defaultNumericArg)

Esse método auxiliar é usado para associações personalizadas que respeitam DigitArgument. Uma chamada típica se parece com

[int]$numericArg = 0
[Microsoft.PowerShell.PSConsoleReadLine]::TryGetArgAsInt($arg,
  [ref]$numericArg, 1)

Observação

Histórico de Comandos

O PSReadLine mantém um arquivo de histórico que contém todos os comandos e dados inseridos na linha de comando. Isso pode conter dados confidenciais, incluindo senhas. Por exemplo, se você usar o ConvertTo-SecureString cmdlet, a senha será registrada no arquivo de histórico como texto sem formatação. Os arquivos de histórico são um arquivo chamado $($host.Name)_history.txt. Em sistemas Windows, o arquivo de histórico é armazenado em $env:APPDATA\Microsoft\Windows\PowerShell\PSReadLine. Em sistemas não Windows, os arquivos de histórico são armazenados em $env:XDG_DATA_HOME/powershell/PSReadLine ou $env:HOME/.local/share/powershell/PSReadLine.

Comentários & contribuindo para o PSReadLine

PSReadLine no GitHub

Fique à vontade para enviar uma solicitação de pull ou enviar comentários na página do GitHub.

Consulte Também

O PSReadLine é fortemente influenciado pela biblioteca de linha de leitura do GNU.