Pergunta principal: como obter o delta for declare -F
, entre aquele no shell atual e aquele como se o shell tivesse acabado de ser iniciado (os dois primeiros comandos abaixo). $(declare -F)
não resolve o problema porque o subshell é uma cópia do processo shell . Subsidiária: por que o terceiro comando abaixo não produz nada?
$ exec env -i bash
$ declare -F
declare -f ShowInstallerIsoInfo
declare -f __expand_tilde_by_ref
declare -f __get_cword_at_cursor_by_ref
declare -f __load_completion
declare -f __ltrim_colon_completions
declare -f __parse_options
declare -f __reassemble_comp_words_by_ref
declare -f _allowed_groups
declare -f _allowed_users
declare -f _available_interfaces
declare -f _bashcomp_try_faketty
declare -f _bq_completer
declare -f _cd
declare -f _cd_devices
declare -f _command
declare -f _command_offset
declare -f _complete_as_root
declare -f _completer
declare -f _completion_loader
declare -f _configured_interfaces
declare -f _count_args
declare -f _dvd_devices
declare -f _expand
declare -f _filedir
declare -f _filedir_xspec
declare -f _fstypes
declare -f _get_comp_words_by_ref
declare -f _get_cword
declare -f _get_first_arg
declare -f _get_pword
declare -f _gids
declare -f _have
declare -f _included_ssh_config_files
declare -f _init_completion
declare -f _installed_modules
declare -f _ip_addresses
declare -f _kernel_versions
declare -f _known_hosts
declare -f _known_hosts_real
declare -f _longopt
declare -f _mac_addresses
declare -f _minimal
declare -f _modules
declare -f _ncpus
declare -f _open_files_for_editing
declare -f _parse_help
declare -f _parse_usage
declare -f _pci_ids
declare -f _pgids
declare -f _pids
declare -f _pnames
declare -f _python_argcomplete
declare -f _quote_readline_by_ref
declare -f _realcommand
declare -f _rl_enabled
declare -f _root_command
declare -f _service
declare -f _services
declare -f _shells
declare -f _signals
declare -f _split_longopt
declare -f _sysvdirs
declare -f _terms
declare -f _tilde
declare -f _uids
declare -f _upvar
declare -f _upvars
declare -f _usb_ids
declare -f _user_at_host
declare -f _usergroup
declare -f _userland
declare -f _variables
declare -f _xfunc
declare -f _xinetd_services
declare -f dequote
declare -f quote
declare -f quote_readline
$ "$SHELL" -c 'declare -F'
Outro:
$ uname -a
Linux elitebook 6.7.3-arch1-2 #1 SMP PREEMPT_DYNAMIC Fri, 02 Feb 2024 17:03:55 +0000 x86_64 GNU/Linux
$ bash --version
GNU bash, version 5.2.26(1)-release (x86_64-pc-linux-gnu)
$ echo $SHELL
/bin/bash
Atualizar:
O estado limpo é uma lista vazia de funções, como visto na saída de
bash -c 'declare -F'
Com base no primeiro comando, esperava que o segundo produzisse duas funções em vez de zero.
$ grep -F -f <(declare -F | cut --delimiter=' ' --fields=3) ~/.bashrc | grep -v -E '^#' | wc -l
2
$ bash -c 'source ~/.bashrc; declare -F'
Atualização2
Eu esperava que o segundo produzisse duas funções em vez de zero.
Este pode ser o motivo para o sourcing não entrar em vigor:
$ cat ~/.bashrc
#
# ~/.bashrc
#
# If not running interactively, don't do anything
[[ $- != *i* ]] && return
A solução alternativa gera duas funções.
$ bash -c 'source <(grep -v '\''!= *i*'\'' ~/.bashrc); compgen -A function' 2>/dev/null
Se você quiser saber o que mudou na lista de funções desde que o shell foi iniciado e originou os arquivos de inicialização, já que, no bash, os nomes das funções não podem conter caracteres de nova linha, você pode usar para
compgen -A function
despejar a lista de funções uma por linha, ecomm
para comparar esse dump (que precisa ser classificado no mesmo local) em diferentes momentos.Adicionar:
no final do seu
~/.bashrc
e execute:Para ver quais foram adicionados desde então.
Para aqueles que foram removidos.
O equivalente zsh seria:
De qualquer forma, observe que bash como zsh¹ não define nenhuma função por si só, então o estado limpo é uma lista vazia de funções, como visto na saída de
bash -c 'declare -F'
.Todas as funções que você pode ver foram importadas do ambiente (pois
bash
suporta a exportação de funções por meio deBASH_FUNC_funcname%%=
variáveis de ambiente comexport -f
) ou definidas no código bash que foi interpretadobash
desde que foi iniciado, possivelmente por meio do$BASHENV
arquivo ou de qualquer um dos arquivos de inicialização do bash , alguns dos quais possivelmente fornecidos pelo seu sistema operacional, ou arquivos provenientes dele, como os dobash-completion
projeto de terceiros que você parece estar usando.¹ No entanto, o zsh fornece um grande número de funções que você pode carregar ou carregar automaticamente como funções de exemplo ou para suportar vários de seus subsistemas, como conclusão (que não é um projeto separado no zsh), FTP, editor de linha, calendário, configuração de prompt, documentação , bem como algumas ferramentas úteis, como
zargs
,zmv
,zcalc
...