Set-PSReadLineOption
Personaliza o comportamento de edição de linha de comando em PSReadLine.
Sintaxe
Set-PSReadLineOption
[-EditMode <EditMode>]
[-ContinuationPrompt <String>]
[-HistoryNoDuplicates]
[-AddToHistoryHandler <System.Func[System.String,System.Object]>]
[-CommandValidationHandler <System.Action[System.Management.Automation.Language.CommandAst]>]
[-HistorySearchCursorMovesToEnd]
[-MaximumHistoryCount <Int32>]
[-MaximumKillRingCount <Int32>]
[-ShowToolTips]
[-ExtraPromptLineCount <Int32>]
[-DingTone <Int32>]
[-DingDuration <Int32>]
[-BellStyle <BellStyle>]
[-CompletionQueryItems <Int32>]
[-WordDelimiters <String>]
[-HistorySearchCaseSensitive]
[-HistorySaveStyle <HistorySaveStyle>]
[-HistorySavePath <String>]
[-AnsiEscapeTimeout <Int32>]
[-PromptText <String[]>]
[-ViModeIndicator <ViModeStyle>]
[-ViModeChangeHandler <ScriptBlock>]
[-Colors <Hashtable>]
[<CommonParameters>]
Description
O Set-PSReadLineOption
cmdlet personaliza o comportamento do módulo PSReadLine quando você edita a linha de comando. Para visualizar as configurações do PSReadLine , use Get-PSReadLineOption
.
As opções definidas por este comando aplicam-se apenas à sessão atual. Para persistir quaisquer opções, adicione-as a um script de perfil. Para obter mais informações, consulte about_Profiles e personalizando seu ambiente de shell.
Exemplos
Exemplo 1: Definir cores de primeiro plano e plano de fundo
Este exemplo define PSReadLine para exibir o token Comment com texto de primeiro plano verde em um plano de fundo cinza. Na sequência de escape usada no exemplo, 32 representa a cor de primeiro plano e 47 representa a cor de plano de fundo.
Set-PSReadLineOption -Colors @{ "Comment"="$([char]0x1b)[32;47m" }
Você pode optar por definir apenas uma cor de texto em primeiro plano. Por exemplo, uma cor de texto de primeiro plano verde brilhante para o token Comment : "Comment"="$([char]0x1b)[92m"
.
Exemplo 2: Definir estilo de sino
Neste exemplo, PSReadLine responderá a erros ou condições que exigem atenção do usuário. O BellStyle está configurado para emitir um sinal sonoro a 1221 Hz durante 60 ms.
Set-PSReadLineOption -BellStyle Audible -DingTone 1221 -DingDuration 60
Nota
Esse recurso pode não funcionar em todos os hosts em plataformas.
Exemplo 3: Definir várias opções
Set-PSReadLineOption
pode definir várias opções com uma tabela hash.
$PSReadLineOptions = @{
EditMode = "Emacs"
HistoryNoDuplicates = $true
HistorySearchCursorMovesToEnd = $true
Colors = @{
"Command" = "#8181f7"
}
}
Set-PSReadLineOption @PSReadLineOptions
A tabela hash $PSReadLineOptions
define as chaves e os valores. Set-PSReadLineOption
usa as chaves e os valores com @PSReadLineOptions
para atualizar as opções PSReadLine .
Pode ver as chaves e os valores que introduzem o nome da tabela hash, $PSReadLineOptions
na linha de comandos do PowerShell.
Exemplo 4: Definir várias opções de cor
Este exemplo mostra como definir mais de um valor de cor em um único comando.
Set-PSReadLineOption -Colors @{
Command = 'Magenta'
Number = 'DarkGray'
Member = 'DarkGray'
Operator = 'DarkGray'
Type = 'DarkGray'
Variable = 'DarkGreen'
Parameter = 'DarkGreen'
ContinuationPrompt = 'DarkGray'
Default = 'DarkGray'
}
Exemplo 5: Definir valores de cor para vários tipos
Este exemplo mostra três métodos diferentes para definir a cor dos tokens exibidos em PSReadLine.
Set-PSReadLineOption -Colors @{
# Use a ConsoleColor enum
"Error" = [ConsoleColor]::DarkRed
# 24 bit color escape sequence
"String" = "$([char]0x1b)[38;5;100m"
# RGB value
"Command" = "#8181f7"
}
Exemplo 6: Use ViModeChangeHandler para exibir alterações no modo Vi
Este exemplo emite um escape VT de alteração de cursor em resposta a uma alteração no modo Vi .
function OnViModeChange {
if ($args[0] -eq 'Command') {
# Set the cursor to a blinking block.
Write-Host -NoNewLine "$([char]0x1b)[1 q"
} else {
# Set the cursor to a blinking line.
Write-Host -NoNewLine "$([char]0x1b)[5 q"
}
}
Set-PSReadLineOption -ViModeIndicator Script -ViModeChangeHandler $Function:OnViModeChange
A função OnViModeChange define as opções do cursor para os modos Vi : inserir e comando.
ViModeChangeHandler usa o provedor para fazer referência a Function:
OnViModeChange como um objeto de bloco de script.
Para obter mais informações, consulte about_Providers.
Exemplo 7: Usar HistoryHandler para filtrar comandos adicionados ao histórico
O exemplo a seguir mostra como usar o AddToHistoryHandler
para evitar salvar quaisquer comandos git no histórico.
$ScriptBlock = {
Param([string]$line)
if ($line -match "^git") {
return $false
} else {
return $true
}
}
Set-PSReadLineOption -AddToHistoryHandler $ScriptBlock
O scriptblock retornará $false
se o comando tiver começado com git
. Isso tem o mesmo efeito que retornar o SkipAdding
enum AddToHistory . Se o comando não começar com git
, o manipulador retornará $true
e PSReadLine salvará o comando no histórico.
Exemplo 8: Use CommandValidationHandler para validar um comando antes de ser executado
Este exemplo mostra como usar o parâmetro CommandValidationHandler para executar um comando de validação antes que ele seja executado. O exemplo verifica especificamente o comando git
com o subcomando cmt
e o substitui pelo nome commit
completo. Dessa forma, você pode criar aliases abreviados para subcomandos.
# Load the namespace so you can use the [CommandAst] object type
using namespace System.Management.Automation.Language
Set-PSReadLineOption -CommandValidationHandler {
param([CommandAst]$CommandAst)
switch ($CommandAst.GetCommandName()) {
'git' {
$gitCmd = $CommandAst.CommandElements[1].Extent
switch ($gitCmd.Text) {
'cmt' {
[Microsoft.PowerShell.PSConsoleReadLine]::Replace(
$gitCmd.StartOffset, $gitCmd.EndOffset - $gitCmd.StartOffset, 'commit')
}
}
}
}
}
# This checks the validation script when you hit enter
Set-PSReadLineKeyHandler -Chord Enter -Function ValidateAndAcceptLine
Exemplo 9: Usando o parâmetro PromptText
Quando há um erro de análise, PSReadLine altera uma parte do prompt vermelho. O parâmetro PromptText informa ao PSReadLine a parte da cadeia de caracteres do prompt para ficar vermelha.
Por exemplo, o exemplo a seguir cria um prompt que contém o caminho atual seguido pelo caractere maior que (>
) e um espaço.
function prompt { "PS $pwd> " }`
Set-PSReadLineOption -PromptText '> ' # change the '>' character red
Set-PSReadLineOption -PromptText '> ', 'X ' # replace the '>' character with a red 'X'
A primeira cadeia de caracteres é a parte da cadeia de caracteres de prompt que você deseja tornar vermelha quando há um erro de análise. A segunda cadeia de caracteres é uma cadeia de caracteres alternativa a ser usada quando há um erro de análise.
Parâmetros
-AddToHistoryHandler
Especifica um ScriptBlock que controla como os comandos são adicionados ao histórico PSReadLine.
O ScriptBlock recebe a linha de comando como entrada.
O ScripBlock deve retornar um membro do enum AddToHistoryOption , o nome da cadeia de caracteres de um desses membros ou um valor booleano. A lista abaixo descreve os valores possíveis e seus efeitos.
MemoryAndFile
- Adicione o comando ao arquivo de histórico e à sessão atual.MemoryOnly
- Adicione o comando ao histórico apenas para a sessão atual.SkipAdding
- Não adicione o comando ao arquivo de histórico da sessão atual.$false
- O mesmo que se o valor fosseSkipAdding
.$true
- O mesmo que se o valor fosseMemoryAndFile
.
Tipo: | Func<T,TResult>[System.String,System.Object] |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-AnsiEscapeTimeout
Esta opção é específica para o Windows quando a entrada é redirecionada, por exemplo, quando executada em tmux
ou screen
.
Com a entrada redirecionada no Windows, muitas teclas são enviadas como uma sequência de caracteres começando com o caractere de escape. É impossível distinguir entre um único personagem de fuga seguido por mais personagens e uma sequência de fuga válida.
A suposição é que o terminal pode enviar os caracteres mais rápido do que um usuário digita. PSReadLine aguarda este tempo limite antes de concluir que recebeu uma sequência de fuga completa.
Se vir carateres aleatórios ou inesperados quando escreve, pode ajustar este tempo limite.
Tipo: | Int32 |
Position: | Named |
Default value: | 100 |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-BellStyle
Especifica como PSReadLine responde a vários erros e condições ambíguas.
Os valores válidos são os seguintes:
- Audível: Um sinal sonoro curto.
- Visual: O texto pisca brevemente.
- Nenhum: Sem comentários.
Tipo: | BellStyle |
Position: | Named |
Default value: | Audible |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Colors
O parâmetro Colors especifica várias cores usadas pelo PSReadLine.
O argumento é uma tabela de hash onde as chaves especificam os elementos e os valores especificam a cor. Para obter mais informações, consulte about_Hash_Tables.
As cores podem ser um valor de ConsoleColor, por exemplo[ConsoleColor]::Red
, ou uma sequência de escape ANSI válida. Sequências de fuga válidas dependem do seu terminal. No PowerShell 5.0, um exemplo de sequência de escape para texto vermelho é $([char]0x1b)[91m
. No PowerShell 6 e mais recente, a mesma sequência de escape é `e[91m
. Você pode especificar outras sequências de escape, incluindo os seguintes tipos:
- 256 cores
- Cor de 24 bits
- Primeiro plano, plano de fundo ou ambos
- Inverso, negrito
Para obter mais informações sobre códigos de cores ANSI, consulte o artigo da Wikipedia ANSI escape code.
As chaves válidas incluem:
- ContinuationPrompt: A cor do prompt de continuação.
- Ênfase: A cor da ênfase. Por exemplo, o texto correspondente ao pesquisar o histórico.
- Erro: A cor do erro. Por exemplo, no prompt.
- Seleção: a cor para realçar a seleção do menu ou o texto selecionado.
- Padrão: A cor padrão do token.
- Comentário: A cor do token de comentário.
- Palavra-chave: A cor do token de palavra-chave.
- String: A cor do token de cadeia de caracteres.
- Operador: A cor do token do operador.
- Variável: A variável cor do token.
- Comando: A cor do token de comando.
- Parâmetro: A cor do token do parâmetro.
- Tipo: A cor do token de tipo.
- Número: A cor do token numérico.
- Membro: A cor do token do nome do membro.
Tipo: | Hashtable |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-CommandValidationHandler
Especifica um ScriptBlock que é chamado de ValidateAndAcceptLine. Se uma exceção for lançada, a validação falhará e o erro será relatado.
Antes de lançar uma exceção, o manipulador de validação pode colocar o cursor no ponto do erro para facilitar a correção. Um manipulador de validação também pode alterar a linha de comando para corrigir erros tipográficos comuns.
ValidateAndAcceptLine é usado para evitar sobrecarregar seu histórico com comandos que não podem funcionar.
Tipo: | Action<T>[CommandAst] |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-CompletionQueryItems
Especifica o número máximo de itens de conclusão que são mostrados sem avisar.
Se o número de itens a serem exibidos for maior que esse valor, PSReadLine solicitará sim/não antes de exibir os itens de conclusão.
Tipo: | Int32 |
Position: | Named |
Default value: | 100 |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ContinuationPrompt
Especifica a cadeia de caracteres exibida no início das linhas subsequentes quando a entrada de várias linhas é inserida. O padrão é o dobro maior que os sinais (>>
). Uma cadeia de caracteres vazia é válida.
Tipo: | String |
Position: | Named |
Default value: | >> |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-DingDuration
Especifica a duração do bipe quando BellStyle está definido como Audível.
Tipo: | Int32 |
Position: | Named |
Default value: | 50ms |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-DingTone
Especifica o tom em Hertz (Hz) do sinal sonoro quando BellStyle está definido como Audível.
Tipo: | Int32 |
Position: | Named |
Default value: | 1221 |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-EditMode
Especifica o modo de edição da linha de comando. O uso desse parâmetro redefine todas as ligações de chave definidas pelo Set-PSReadLineKeyHandler
.
Os valores válidos são os seguintes:
- Windows: As associações de chave emulam PowerShell, cmd e Visual Studio.
- Emacs: As ligações de teclas emulam Bash ou Emacs.
- Vi: As ligações de chave emulam Vi.
Use Get-PSReadLineKeyHandler
para ver as ligações de chave para o EditMode configurado no momento.
Tipo: | EditMode |
Position: | Named |
Default value: | Windows |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ExtraPromptLineCount
Especifica o número de linhas extras.
Se o prompt se estender por mais de uma linha, especifique um valor para esse parâmetro. Use esta opção quando quiser que linhas extras estejam disponíveis quando PSReadLine exibir o prompt depois de mostrar alguma saída. Por exemplo, PSReadLine retorna uma lista de conclusão.
Esta opção é menos necessária do que em versões anteriores do PSReadLine, mas é útil quando a InvokePrompt
função é usada.
Tipo: | Int32 |
Position: | Named |
Default value: | 0 |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-HistoryNoDuplicates
Esta opção controla o comportamento de recuperação. Comandos duplicados ainda são adicionados ao arquivo de histórico. Quando essa opção é definida, somente a invocação mais recente aparece ao chamar comandos. Comandos repetidos são adicionados ao histórico para preservar a ordem durante a recuperação. No entanto, normalmente você não quer ver o comando várias vezes ao lembrar ou pesquisar o histórico.
Por padrão, a propriedade HistoryNoDuplicates do objeto global PSConsoleReadLineOptions é definida como True
. Para alterar o valor da propriedade, você deve especificar o valor do SwitchParameter da seguinte maneira: -HistoryNoDuplicates:$False
. Você pode redefinir para True
usando apenas o SwitchParameter, -HistoryNoDuplicates
.
Usando o seguinte comando, você pode definir o valor da propriedade diretamente:
(Get-PSReadLineOption).HistoryNoDuplicates = $False
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-HistorySavePath
Especifica o caminho para o arquivo onde o histórico é salvo. Os computadores que executam plataformas Windows ou não Windows armazenam o arquivo em locais diferentes. O nome do arquivo é armazenado em uma variável $($Host.Name)_history.txt
, por exemplo ConsoleHost_history.txt
.
Se você não usar esse parâmetro, o caminho padrão será:
$env:APPDATA\Microsoft\Windows\PowerShell\PSReadLine\$($Host.Name)_history.txt
Tipo: | String |
Position: | Named |
Default value: | A file named $($Host.Name)_history.txt in $env:APPDATA\Microsoft\Windows\PowerShell\PSReadLine on Windows and $env:XDG_DATA_HOME/powershell/PSReadLine or $HOME/.local/share/powershell/PSReadLine on non-Windows platforms |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-HistorySaveStyle
Especifica como PSReadLine salva o histórico.
Os valores válidos são os seguintes:
SaveIncrementally
: salve o histórico depois que cada comando for executado e compartilhe em várias instâncias do PowerShell.SaveAtExit
: Anexe o arquivo de histórico quando o PowerShell for encerrado.SaveNothing
: Não use um arquivo de histórico.
Nota
Se você definir HistorySaveStyle como SaveNothing
e, em seguida, defini-lo para SaveIncrementally
mais tarde na mesma sessão, PSReadLine salvará todos os comandos executados anteriormente na sessão.
Tipo: | HistorySaveStyle |
Position: | Named |
Default value: | SaveIncrementally |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-HistorySearchCaseSensitive
Especifica que a pesquisa de histórico diferencia maiúsculas de minúsculas em funções como ReverseSearchHistory ou HistorySearchBackward.
Por padrão, a propriedade HistorySearchCaseSensitive do objeto global PSConsoleReadLineOptions é definida como False
. O uso desse SwitchParameter define o valor da propriedade como True
. Para alterar o valor da propriedade de volta, você deve especificar o valor do SwitchParameter da seguinte maneira: -HistorySearchCaseSensitive:$False
.
Usando o seguinte comando, você pode definir o valor da propriedade diretamente:
(Get-PSReadLineOption).HistorySearchCaseSensitive = $False
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-HistorySearchCursorMovesToEnd
Indica que o cursor se move para o final dos comandos que você carrega do histórico usando uma pesquisa.
Quando esse parâmetro é definido como $False
, o cursor permanece na posição em que estava quando você pressionou as setas para cima ou para baixo.
Por padrão, a propriedade HistorySearchCursorMovesToEnd do objeto global PSConsoleReadLineOptions é definida como False
. Usando este SwitchParameter, defina o valor da propriedade como True
. Para alterar o valor da propriedade de volta, você deve especificar o valor do SwitchParameter da seguinte maneira: -HistorySearchCursorMovesToEnd:$False
.
Usando o seguinte comando, você pode definir o valor da propriedade diretamente:
(Get-PSReadLineOption).HistorySearchCursorMovesToEnd = $False
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-MaximumHistoryCount
Especifica o número máximo de comandos a serem salvos no histórico do PSReadLine .
O histórico do PSReadLine é separado do histórico do PowerShell.
Tipo: | Int32 |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-MaximumKillRingCount
Especifica o número máximo de itens armazenados no anel de eliminação.
Tipo: | Int32 |
Position: | Named |
Default value: | 10 |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-PromptText
Este parâmetro define o valor da propriedade PromptText . O valor predefinido é "> "
.
PSReadLine analisa sua função de prompt para determinar como alterar apenas a cor de parte do prompt. Esta análise não é 100% fiável. Use esta opção se PSReadLine estiver alterando seu prompt de maneiras inesperadas. Inclua qualquer espaço em branco à direita.
O valor desse parâmetro pode ser uma única cadeia de caracteres ou uma matriz de duas cadeias de caracteres. A primeira cadeia de caracteres é a parte da cadeia de caracteres de prompt que você deseja que seja alterada para vermelho quando houver um erro de análise. A segunda cadeia de caracteres é uma cadeia de caracteres alternativa a ser usada quando há um erro de análise.
Tipo: | String[] |
Position: | Named |
Default value: | > |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ShowToolTips
Ao exibir possíveis conclusão, as dicas de ferramentas são mostradas na lista de conclusão.
Por predefinição, esta opção encontra-se ativada. Esta opção não estava habilitada por padrão em versões anteriores do PSReadLine. Para desativar, defina esta opção como $False
.
Por padrão, a propriedade ShowToolTips do objeto global PSConsoleReadLineOptions é definida como True
. O uso desse SwitchParameter define o valor da propriedade como True
. Para alterar o valor da propriedade, você deve especificar o valor do SwitchParameter da seguinte maneira: -ShowToolTips:$False
.
Usando o seguinte comando, você pode definir o valor da propriedade diretamente:
(Get-PSReadLineOption).ShowToolTips = $False
Tipo: | SwitchParameter |
Position: | Named |
Default value: | True |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ViModeChangeHandler
Quando o ViModeIndicator estiver definido como Script
, o bloco de script fornecido será invocado sempre que o modo for alterado. O bloco de script é fornecido um argumento do tipo ViMode
.
Esse parâmetro foi introduzido no PowerShell 7.
Tipo: | ScriptBlock |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ViModeIndicator
Esta opção define o indicador visual para o modo Vi atual. Modo de inserção ou modo de comando.
Os valores válidos são os seguintes:
- Nenhum: Não há indicador.
- Prompt: O prompt muda de cor.
- Cursor: O cursor muda de tamanho.
- Script: O texto especificado pelo usuário é impresso.
Tipo: | ViModeStyle |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-WordDelimiters
Especifica os caracteres que delimitam palavras para funções como ForwardWord ou KillWord.
Tipo: | String |
Position: | Named |
Default value: | ;:,.[]{}()/\|^&*-=+'"--- |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
Entradas
None
Não é possível canalizar objetos para este cmdlet.
Saídas
None
Este cmdlet não retorna nenhuma saída.