prompts personalizados PowerShell

votos
13

Estou à procura de diferentes exemplos de costume PowerShell promptimplementações de função. Se você tem uma implementação personalizada do seu próprio favor postar o script. Links para recursos existentes são bons também.

Os pontos de bónus para postar um screenshot do que seu prompt realmente se parece com (a pré-visualização).

Publicado 27/08/2009 em 02:43
fonte usuário
Em outras línguas...                            


6 respostas

votos
10

Este é modificado versão do prompt de de jaykul. A vantagem é que

-há uma corrente ID de história, para que possa invocar itens anteriores da história com muita facilidade (você sabe o id) -é um pequeno lembrete - acrescento as minhas tarefas para o prompt para que eu não esquecê-los (ver a sshot)

function prompt {
  $err = !$?
  $origOfs = $ofs;
  $ofs = "|"
  $toPrompt = "$($global:__PromptVars)"
  $ofs = $origOfs;
  if ($toPrompt.Length -gt 0) { 
    Write-Host "$($toPrompt) >" -ForegroundColor Green -NoNewline }

  $host.UI.RawUI.WindowTitle = "PS1 > " + $(get-location)

  # store the current color, and change the color of the prompt text
  $script:fg = $Host.UI.RawUI.ForegroundColor
  # If there's an error, set the prompt foreground to "Red"
  if($err) { $Host.UI.RawUI.ForegroundColor = 'Red' }
  else { $Host.UI.RawUI.ForegroundColor = 'Yellow' }

  # Make sure that Windows and .Net know where we are at all times
  [Environment]::CurrentDirectory = (Get-Location -PSProvider FileSystem).ProviderPath

  # Determine what nesting level we are at (if any)
  $Nesting = "$([char]0xB7)" * $NestedPromptLevel

  # Generate PUSHD(push-location) Stack level string
  $Stack = "+" * (Get-Location -Stack).count

  # Put the ID of the command in, so we can get/invoke-history easier
  # eg: "r 4" will re-run the command that has [4]: in the prompt
  $nextCommandId = (Get-History -count 1).Id + 1
  # Output prompt string
  # Notice: no angle brackets, makes it easy to paste my buffer to the web
  Write-Host "[${Nesting}${nextCommandId}${Stack}]:" -NoNewLine

  # Set back the color
  $Host.UI.RawUI.ForegroundColor = $script:fg

  if ($toPrompt.Length -gt 0) { 
      $host.UI.RawUI.WindowTitle = "$($toPrompt) -- " + $host.UI.RawUI.WindowTitle
  }
  " "
}
function AddTo-Prompt($str) {
  if (!$global:__PromptVars) { $global:__PromptVars = @() }
  $global:__PromptVars += $str
}
function RemoveFrom-Prompt($str) {
  if ($global:__PromptVars) {
    $global:__PromptVars = @($global:__PromptVars | ? { $_ -notlike $str })
  }
}

sshot

Respondeu 27/08/2009 em 07:36
fonte usuário

votos
10

Aqui é a minha função alerta

function prompt() {
    if ( Test-Wow64 ) {
        write-host -NoNewLine "Wow64 "
    }
    if ( Test-Admin ) { 
        write-host -NoNewLine -f red "Admin "
    }
    write-host -NoNewLine -ForegroundColor Green $(get-location)
    foreach ( $entry in (get-location -stack)) {
        write-host -NoNewLine -ForegroundColor Red '+';
    }
    write-host -NoNewLine -ForegroundColor Green '>'
    ' '
}
Respondeu 27/08/2009 em 02:46
fonte usuário

votos
8

Aqui está o meu :

function prompt {
   # our theme
   $cdelim = [ConsoleColor]::DarkCyan
   $chost = [ConsoleColor]::Green
   $cloc = [ConsoleColor]::Cyan

   write-host "$([char]0x0A7) " -n -f $cloc
   write-host ([net.dns]::GetHostName()) -n -f $chost
   write-host ' {' -n -f $cdelim
   write-host (shorten-path (pwd).Path) -n -f $cloc
   write-host '}' -n -f $cdelim
   return ' '
}

Ele usa essa função auxiliar:

function shorten-path([string] $path) {
   $loc = $path.Replace($HOME, '~')
   # remove prefix for UNC paths
   $loc = $loc -replace '^[^:]+::', ''
   # make path shorter like tabs in Vim,
   # handle paths starting with \\ and . correctly
   return ($loc -replace '\\(\.?)([^\\])[^\\]*(?=\\)','\$1$2')
}
Respondeu 27/08/2009 em 14:31
fonte usuário

votos
4

Costumo usar nobre como um calc, então eu definir $ variável ans. https://connect.microsoft.com/PowerShell/feedback/ViewFeedback.aspx?FeedbackID=386493

PS> 100
100
PS> $ ans * 9
900
PS> $ ans * $ ans
810000

Respondeu 29/08/2009 em 17:54
fonte usuário

votos
1

Aqui é meu. Apenas tem o ID história em cada comando para que eu possa facilmente identificar o ID do comando. Eu também uso o WindowTitle para me dar o diretório de trabalho atual, em vez de tê-lo exibido no próprio alerta.

106 >  cat function:\prompt

    $history = @(get-history)
    if($history.Count -gt 0)
{
        $lastItem = $history[$history.Count - 1]
        $lastId = $lastItem.Id
    }

    $nextCommand = $lastId + 1
    $Host.ui.rawui.windowtitle = "PS " + $(get-location)
    $myPrompt = "$nextCommand > "
    if ($NestedPromptLevel -gt 0) {$arrows = ">"*$NestedPromptLevel; $myPrompt = "PS-nested $arrows"}
    Write-Host ($myPrompt) -nonewline
    return " "

Uma coisa que muitas pessoas esquecem é de lidar com a prompts personalizados é o prompt aninhado. Note que eu verifique $ NestedPromptLevel e adicionar uma seta para cada nível aninhado.

Andy

Respondeu 15/09/2009 em 14:48
fonte usuário

votos
0

I tendem a re-tipo

function prompt { "PS> " }

cada vez que eu estou preparando exemplos posso copiar / colar para alguém, especialmente quando estou em longos caminhos complicados que só iria distrair.

E eu ainda pretendo escrever uma função alerta decente que me mostra a unidade e uma aproximação útil no local ou usando o diretório atual (sem o caminho que levou até lá) ou (se é numérico) o próximo nível mais alto também. Mas isso é provavelmente muito específico para o meu próprio sistema de arquivos aqui. E eu nunca fui incomodado o suficiente pelo prompt padrão para realmente fazê-lo :-)

Respondeu 27/08/2009 em 06:36
fonte usuário

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more