⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bashrc

📁 BASH Shell 编程 经典教程 《高级SHELL脚本编程》中文版
💻
📖 第 1 页 / 共 2 页
字号:
        */*) dirname==${file%/*} ;;        *) dirname=.;;        esac        nf=$(echo $filename | tr A-Z a-z)        newname="${dirname}/${nf}"        if [ "$nf" != "$filename" ]; then            mv "$file" "$newname"            echo "lowercase: $file --> $newname"        else            echo "lowercase: $file not changed."        fi    done}function swap()         # 交换两个文件名{    local TMPFILE=tmp.$$    mv "$1" $TMPFILE    mv "$2" "$1"    mv $TMPFILE "$2"}#----------------------# 进程/系统相关的函数:#----------------------function my_ps() { ps $@ -u $USER -o pid,%cpu,%mem,bsdtime,command ; }function pp() { my_ps f | awk '!/awk/ && $0~var' var=${1:-".*"} ; }# 这个函数与linux上的'killall'基本一致# 但是与Solaris上的却不相同function killps()   # 按进程名进行kill{    local pid pname sig="-TERM"   # 默认signal    if [ "$#" -lt 1 ] || [ "$#" -gt 2 ]; then        echo "Usage: killps [-SIGNAL] pattern"        return;    fi    if [ $# = 2 ]; then sig=$1 ; fi    for pid in $(my_ps| awk '!/awk/ && $0~pat { print $1 }' pat=${!#} ) ; do        pname=$(my_ps | awk '$1~var { print $5 }' var=$pid )        if ask "Kill process $pid <$pname> with signal $sig?"            then kill $sig $pid        fi    done}function my_ip() # 获得IP地址{    MY_IP=$(/sbin/ifconfig ppp0 | awk '/inet/ { print $2 } ' | sed -e s/addr://)    MY_ISP=$(/sbin/ifconfig ppp0 | awk '/P-t-P/ { print $3 } ' | sed -e s/P-t-P://)}function ii()   # 获得当前主机相关的信息{    echo -e "\nYou are logged on ${RED}$HOST"    echo -e "\nAdditionnal information:$NC " ; uname -a    echo -e "\n${RED}Users logged on:$NC " ; w -h    echo -e "\n${RED}Current date :$NC " ; date    echo -e "\n${RED}Machine stats :$NC " ; uptime    echo -e "\n${RED}Memory stats :$NC " ; free    my_ip 2>&- ;    echo -e "\n${RED}Local IP Address :$NC" ; echo ${MY_IP:-"Not connected"}    echo -e "\n${RED}ISP Address :$NC" ; echo ${MY_ISP:-"Not connected"}    echo}# 杂项工具:function repeat()       # 重复n次的命令{    local i max    max=$1; shift;    for ((i=1; i <= max ; i++)); do  # --> C风格的语法        eval "$@";    done}function ask(){    echo -n "$@" '[y/n] ' ; read ans    case "$ans" in        y*|Y*) return 0 ;;        *) return 1 ;;    esac}#=========================================================================## 按情况补全, complete命令 - BASH-2.04及其后续版本# 大部分摘自bash 2.05文档# 和Ian McDonalds的'Bash completion'软件包(http://www.caliban.org/bash/index.shtml#completion)# 某些特征可能需要使用bash-2.05a##=========================================================================if [ "${BASH_VERSION%.*}" \< "2.05" ]; then    echo "You will need to upgrade to version 2.05 for programmable completion"    returnfishopt -s extglob        # 必须的set +o nounset          # 否则某些自动补全将会失败complete -A hostname   rsh rcp telnet rlogin r ftp ping diskcomplete -A export     printenvcomplete -A variable   export local readonly unsetcomplete -A enabled    builtincomplete -A alias      alias unaliascomplete -A function   functioncomplete -A user       su mail fingercomplete -A helptopic  help     # 通常与内建命令一样complete -A shopt      shoptcomplete -A stopped -P '%' bgcomplete -A job -P '%'     fg jobs disowncomplete -A directory  mkdir rmdircomplete -A directory   -o default cd# 压缩complete -f -o default -X '*.+(zip|ZIP)'  zipcomplete -f -o default -X '!*.+(zip|ZIP)' unzipcomplete -f -o default -X '*.+(z|Z)'      compresscomplete -f -o default -X '!*.+(z|Z)'     uncompresscomplete -f -o default -X '*.+(gz|GZ)'    gzipcomplete -f -o default -X '!*.+(gz|GZ)'   gunzipcomplete -f -o default -X '*.+(bz2|BZ2)'  bzip2complete -f -o default -X '!*.+(bz2|BZ2)' bunzip2# Postscript,pdf,dvi.....(译者: 打印格式相关)complete -f -o default -X '!*.ps'  gs ghostview ps2pdf ps2asciicomplete -f -o default -X '!*.dvi' dvips dvipdf xdvi dviselect dvitypecomplete -f -o default -X '!*.pdf' acroread pdf2pscomplete -f -o default -X '!*.+(pdf|ps)' gvcomplete -f -o default -X '!*.texi*' makeinfo texi2dvi texi2html texi2pdfcomplete -f -o default -X '!*.tex' tex latex slitexcomplete -f -o default -X '!*.lyx' lyxcomplete -f -o default -X '!*.+(htm*|HTM*)' lynx html2ps# 多媒体complete -f -o default -X '!*.+(jp*g|gif|xpm|png|bmp)' xv gimpcomplete -f -o default -X '!*.+(mp3|MP3)' mpg123 mpg321complete -f -o default -X '!*.+(ogg|OGG)' ogg123complete -f -o default -X '!*.pl'  perl perl5# 这是一个'通用的'补全函数 - 当命令具有一个所谓的"长选项"模式it works when commands have# 的时候, 它就会工作, 比如: 'ls --all' 代替 'ls -a'_get_longopts () {     $1 --help | sed  -e '/--/!d' -e 's/.*--\([^[:space:].,]*\).*/--\1/'| \grep ^"$2" |sort -u ;}_longopts_func (){    case "${2:-*}" in	-*)	;;	*)	return ;;    esac    case "$1" in	\~*)	eval cmd="$1" ;;	*)	cmd="$1" ;;    esac    COMPREPLY=( $(_get_longopts ${1} ${2} ) )}complete  -o default -F _longopts_func configure bashcomplete  -o default -F _longopts_func wget id info a2ps ls recode_make_targets (){    local mdef makef gcmd cur prev i    COMPREPLY=()    cur=${COMP_WORDS[COMP_CWORD]}    prev=${COMP_WORDS[COMP_CWORD-1]}    # 如果之前的参数为-f, 那就返回可能的补全文件名.     # 我们可以让它更智能一些, 并且返回匹配的    # `makefile Makefile *.mk', 不管存在与否    case "$prev" in        -*f)    COMPREPLY=( $(compgen -f $cur ) ); return 0;;    esac    # 如果我们需要一个选项, 那就返回可能的posix选项    case "$cur" in        -)      COMPREPLY=(-e -f -i -k -n -p -q -r -S -s -t); return 0;;    esac    # 前尝试`makefile'再尝试`Makefile'    if [ -f makefile ]; then        mdef=makefile    elif [ -f Makefile ]; then        mdef=Makefile    else        mdef=*.mk               # 局部约定    fi    # 在我们扫描目标文件之前, 察看makefile文件名是否    # 使用-f指定    for (( i=0; i < ${#COMP_WORDS[@]}; i++ )); do        if [[ ${COMP_WORDS[i]} == -*f ]]; then            eval makef=${COMP_WORDS[i+1]}       # eval for tilde expansion(波浪号扩展)            break        fi    done        [ -z "$makef" ] && makef=$mdef    # 如果我们有特别偏爱的补全单词,     # 那么可以限制的补全这个单词    if [ -n "$2" ]; then gcmd='grep "^$2"' ; else gcmd=cat ; fi    # 如果我们不想使用*.mk, 我们可以使用    # 或者使用test -f $makef或者使用输入重定向    COMPREPLY=( $(cat $makef 2>/dev/null | awk 'BEGIN {FS=":"} /^[^.#   ][^=]*:/ {print $1}' | tr -s ' ' '\012' | sort -u | eval $gcmd ) )}complete -F _make_targets -X '+($*|*.[cho])' make gmake pmake# cvs(1) 补全_cvs (){    local cur prev    COMPREPLY=()    cur=${COMP_WORDS[COMP_CWORD]}    prev=${COMP_WORDS[COMP_CWORD-1]}    if [ $COMP_CWORD -eq 1 ] || [ "${prev:0:1}" = "-" ]; then        COMPREPLY=( $( compgen -W 'add admin checkout commit diff \        export history import log rdiff release remove rtag status \        tag update' $cur ))    else        COMPREPLY=( $( compgen -f $cur ))    fi    return 0}complete -F _cvs cvs_killall (){    local cur prev    COMPREPLY=()    cur=${COMP_WORDS[COMP_CWORD]}    # 获得进程列表(第一个sed表达式处理    # swap out出去的进程, 第二个    # 获得进程的basename)    COMPREPLY=( $( /usr/bin/ps -u $USER -o comm  | \        sed -e '1,1d' -e 's#[]\[]##g' -e 's#^.*/##'| \        awk '{if ($0 ~ /^'$cur'/) print $0}' ))    return 0}complete -F _killall killall killps# 一个元命令补全函数, 用于sudo(8)这种命令, # 需要先对这个命令进行补全, 然后需要按照这个命令自己的补全定义进行补全#  - 当前并不是非常可靠(比如 mount和umount命令# 就不能很好的工作), 但还是很有用的 - 作者, Ian McDonald, 我修改了一下. _my_command(){    local cur func cline cspec        COMPREPLY=()    cur=${COMP_WORDS[COMP_CWORD]}    if [ $COMP_CWORD = 1 ]; then	COMPREPLY=( $( compgen -c $cur ) )    elif complete -p ${COMP_WORDS[1]} &>/dev/null; then	cspec=$( complete -p ${COMP_WORDS[1]} )	if [ "${cspec%%-F *}" != "${cspec}" ]; then	    # complete -F &lt;function&gt;	    #	    # COMP_CWORD和COMP_WORDS()不是只读的,	    # 所以我们可以在传递到补全例程之前, 	    # 设置它们		    # 设置当前的标志号减1	    COMP_CWORD=$(( $COMP_CWORD - 1 ))	    # 获得函数名	    func=${cspec#*-F }	    func=${func%% *}	    # 获得去掉第一个命令后的命令行	    cline="${COMP_LINE#$1 }"	    # 分离当前命令, 传递给数组		COMP_WORDS=( $cline )	    $func $cline	elif [ "${cspec#*-[abcdefgjkvu]}" != "" ]; then	    # complete -[abcdefgjkvu]	    #func=$( echo $cspec | sed -e 's/^.*\(-[abcdefgjkvu]\).*$/\1/' )	    func=$( echo $cspec | sed -e 's/^complete//' -e 's/[^ ]*$//' )	    COMPREPLY=( $( eval compgen $func $cur ) )	elif [ "${cspec#*-A}" != "$cspec" ]; then	    # complete -A &lt;type&gt;	    func=${cspec#*-A }	func=${func%% *}	COMPREPLY=( $( compgen -A $func $cur ) )	fi    else	COMPREPLY=( $( compgen -f $cur ) )    fi}complete -o default -F _my_command nohup exec eval trace truss strace sotruss gdbcomplete -o default -F _my_command command type which man nice# 本地变量:# mode:shell-script# sh-shell:bash# End:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -