Skip to content

Latest commit

 

History

History
152 lines (89 loc) · 7.19 KB

README.md

File metadata and controls

152 lines (89 loc) · 7.19 KB

The Fishshell Framework

MIT License Fish Shell Version Travis Build Status Slack Status

O Oh My Fish fornece infra-estrutura básica para permitir que você instale pacotes que estendam ou modifiquem a aparência do seu shell. É rápido, extensível e fácil de usar.

Also in  🇺🇸 🇷🇺 🇨🇳 🇺🇦 🇪🇸


Instalação

curl -L https://github.com/oh-my-fish/oh-my-fish/raw/master/bin/install | fish
omf help

Ou baixar e executar:

curl -L https://github.com/oh-my-fish/oh-my-fish/raw/master/bin/install > install
fish install

Tutorial

O Oh My Fish inclui um pequeno utilitário omf para buscar e instalar novos pacotes e temas.

omf update [omf] [<package>...]

Atualiza o Oh My Fish, todos os pacotes do repositório, e todos os pacotes instalados.

  • Quando chamado sem argumentos, atualiza o framework e todos os pacotes instalados.
  • Voce pode escolher atualizar somente o framework, executando omf update omf.
  • Para uma atualização seletiva de pacotes, liste apenas os nomes dos pacotes que pretende atualizar. Você ainda pode incluir "omf" na lista para atualizar o framework também.

omf install [<name>|<url>]

Instala um ou mais pacotes.

  • Voce pode instalar pacotes diretamente pela URL via omf install URL
  • Quando chamado sem argumentos, instala os pacotes ausentes do bundle.

omf repositories [list|add|remove]

Gerencie os repositórios de pacotes instalados pelo usuário. Repositórios de pacotes são onde os pacotes vêm a ser usados por comandos como omf install. Por padrão o repositorio oficial é sempre instalado e disponível.

omf list

Lista dos pacotes instalados.

omf theme <theme>

Aplica um tema. Para lista os temas disponíveis, digite omf theme. Você pode também visualizar os temas disponíveis antes da instalação.

omf remove <name>

Remove um tema ou pacote.

Os pacotes podem usar ganchos de desinstalação, portanto, a limpeza personalizada de recursos pode ser feita ao desinstalá-la. Ver Desinstalação para mais informações.

omf reload

Recarrega Oh My Fish e todos os plugins usando exec para substituir o processo shell atual com um novo.

Este comando tenta ser o mais seguro possivel, suavizando os efeitos colaterais causados pelo exec e impedindo o recarregamento no caso de processos em plano de fundo.

omf new pkg | theme <name>

Cria uma estrutura para um novo pacote ou tema.

Cria um novo diretorio $OMF_CONFIG/{pkg | themes}/ com um template.

omf search -t|--theme / -pkg|--package <name>

Procura no banco de dados de Oh My Fish para um determinado pacote, tema ou ambos. Ele também suporta pesquisa fuzzy, então se você não tem certeza do nome, você pode simplesmente buscar omf search simple.

omf channel

Obtém ou altera o canal de atualização.

Dois canais estão disponíveis por padrão: o canal stable que fornece atualizações estáveis com a última versão etiquetada de Oh My Fish e dev que fornece as últimas alterações em desenvolvimento. O canal de atualização atualmente definido determina para qual versão omf update atualizará.

omf doctor

Use para solucionar problemas antes de abrir um issue.

omf destroy

Desinstala o Oh My Fish.

Avançado

O instalador do Oh My Fish coloca seu código de inicialização no arquivo de configuração do fish (~/.config/fish/config.fish).

Inicialização

Toda vez que você abre um novo shell, o código de inicialização define o diretório de instalação do Oh My Fish e o caminho da configuração (~/.config/omf por padrão), chamando o script init.fish posteriormente, o qual carrega os pacotes, temas e seus arquivos de inicialização personalizados.

Para mais informações confira a FAQ.

Dotfiles (arquivos de configuração)

O diretório $ OMF_CONFIG representa o estado do usuário de Oh My Fish. É o candidato perfeito para ser adicionado aos seus dotfiles e / ou ao sistema de controle de versão. Existem quatro arquivos importantes:

  • theme - O tema atual
  • bundle - Lista atual dos pacotes/temas instalados
  • init.fish - Script personalizado que é executado depois de executar shell
  • before.init.fish - Script personalizado que é executado antes de executar shell
  • key_bindings.fish - Teclas de atalho customizadas onde você pode usar o comando bind livremente.

É altamente recomendado que customize os comandos de inicialização no arquivo init.fish invés do ~/.config/fish/config.fish, com isso permite a você manter todo $OMF_CONFIG diretamente sobre o controle de versão.

Se você precisar executar comandos de inicialização antes Oh My Fish iniciar os plugins, coloque eles em before.init.fish. Se está inseguro, é melhor coloca-los em init.fish.

Alterando variáveis em init.fish

Um dos mais comuns comandos de inicialização usados no init.fish é a definição de variáveis. Muito provavelmente, essas variáveis precisam estar disponíveis em qualquer sessão do shell. Para conseguir isso, defina-os globalmente. Por exemplo:

# Golang developers might need this one
set -xg GOPATH $HOME/gocode

# Python developers otherwise
set -xg PYTHONDONTWRITEBYTECODE 1

Sobre o bundle

A todo momento pacotes/temas são instalados ou removidos, o arquivo bundle é atualizado. Você também pode editar eles manualmente e executar omf install apos concluir as alterações. Por favor note que enquanto pacotes/temas adicionados ao bundle são automaticamente instalados, um pacote/tema removido do bundle não sera removido das instalações do usuário.

Criando Pacotes

O Oh My Fish usa uma arquitetura moderna e bem definida de plugins para facilitar o desenvolvimento de um plugin, incluindo eventos de inicialização/exclusão, funções de backup. consulte a documentação para mais detalhes.