declare -F
주요 질문: 현재 셸의 값과 셸이 방금 시작되었을 때의 값 사이의 델타를 얻는 방법 (아래 처음 두 명령) $(declare -F)
때문에 문제를 해결하지 못했습니다.서브쉘은 쉘 프로세스의 복사본입니다.. 자회사: 아래 세 번째 명령이 아무것도 출력하지 않는 이유는 무엇입니까?
$ 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'
다른:
$ 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
고쳐 쓰다:
정리 상태는 출력에 표시된 대로 빈 함수 목록입니다.
bash -c 'declare -F'
첫 번째 명령을 기반으로 두 번째 명령이 0 대신 두 개의 함수를 출력할 것으로 예상했습니다.
$ grep -F -f <(declare -F | cut --delimiter=' ' --fields=3) ~/.bashrc | grep -v -E '^#' | wc -l
2
$ bash -c 'source ~/.bashrc; declare -F'
업데이트 2
나는 두 번째 함수가 0 대신 두 개의 함수를 출력할 것으로 예상했습니다.
구매가 적용되지 않는 이유는 다음과 같습니다.
$ cat ~/.bashrc
#
# ~/.bashrc
#
# If not running interactively, don't do anything
[[ $- != *i* ]] && return
해결 방법은 두 기능을 모두 출력합니다.
$ bash -c 'source <(grep -v '\''!= *i*'\'' ~/.bashrc); compgen -A function' 2>/dev/null
답변1
쉘이 시작된 이후 함수 목록에서 무엇이 변경되었는지 알고 시작 파일을 얻으려면 bash 함수 이름에는 개행 문자가 포함될 수 없으므로 compgen -A function
함수 목록을 한 줄에 하나씩 덤프하고 comm
서로 다른 시간을 비교할 수 있습니다. 포인트 덤프( 동일한 로케일로 정렬해야 합니다.)
다음에 추가:
initial_functions=$(compgen -A function | LC_ALL=C sort)
실행이 끝나면 ~/.bashrc
다음을 실행하십시오.
LC_ALL=C comm -13 <(printf '%s\n' "$initial_functions") \
<(compgen -A function | LC_ALL=C sort)
이후 추가된 내용을 확인하세요.
LC_ALL=C comm -23 <(printf '%s\n' "$initial_functions") \
<(compgen -A function | LC_ALL=C sort)
삭제된 분들을 위해.
zsh에 해당하는 내용은 다음과 같습니다.
initial_functions=( ${(k)functions} )
() { print -rC1 -- ${argv:|initial_functions}; } ${(k)functions}
() { print -rC1 -- ${initial_functions:|argv}; } ${(k)functions}
어쨌든 zsh와 같은 bash는 자체적으로 어떤 기능도 정의하지 않으므로 주의하세요.깨끗한 상태의 출력에 표시된 것처럼 은 빈 함수 목록입니다 bash -c 'declare -F'
.
볼 수 있는 모든 함수는 환경에서 가져오거나( bash
환경 변수를 통한 함수 내보내기가 지원되기 때문에) 시작 이후 해석된 bash 코드로 정의됩니다. 파일 등을 통해 가능합니다.BASH_FUNC_funcname%%=
export -f
bash
$BASHENV
배시 시작 파일, 그 중 일부는 운영 체제에서 제공되거나 다음과 같은 파일에서 제공될 수 있습니다.bash-completion
타사 프로젝트사용하고 계시는 것 같습니다.
그러나 zsh는 예제 함수 또는 자동 로드로 로드할 수 있거나 완료(zsh의 별도 프로젝트 아님), FTP, 라인 편집기, 달력, 프롬프트 구성, 문서화 등 여러 하위 시스템을 지원할 수 있는 많은 기능을 제공합니다. 그리고 다음과 같은 유용한 도구도 있습니다 zargs
.zmv
zcalc