<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      linux中的配置文件

      /etc/profile:此文件為系統的每個用戶設置環境信息,當用戶第一次登錄時,該文件被執行.并從/etc/profile.d目錄的配置文件中搜集shell的設置.

      /etc/bashrc:為每一個運行bash shell的用戶執行此文件.當bash shell被打開時,該文件被讀取.

      ~/.bash_profile:每個用戶都可使用該文件輸入專用于自己使用的shell信息,當用戶登錄時,該文件僅僅執行一次!默認情況下,他設置一些環境變量,執行用戶的.bashrc文件.

      ~/.bashrc:該文件包含專用于你的bash shell的bash信息,當登錄時以及每次打開新的shell時,該文件被讀取.(每個用戶都有一個.bashrc文件,在用戶目錄下)

      ~/.bash_logout:當每次退出系統(退出bash shell)時,執行該文件. 

      另外,/etc/profile中設定的變量(全局)的可以作用于任何用戶,而~/.bashrc等中設定的變量(局部)只能繼承/etc/profile中的變量,他們是"父子"關系.

      ~/.bash_profile 是交互式、login 方式進入 bash 運行的
      ~/.bashrc 是交互式 non-login 方式進入 bash 運行的
      通常二者設置大致相同,所以通常前者會調用后者。

      /etc/profile:此文件為系統的每個用戶設置環境信息,當用戶第一次登錄時,該文件被執行.并從/etc/profile.d目錄的配置文件中搜集shell的設置.

      /etc/bashrc:為每一個運行bash shell的用戶執行此文件.當bash shell被打開時,該文件被讀取.

      ~/.bash_profile:每個用戶都可使用該文件輸入專用于自己使用的shell信息,當用戶登錄時,該文件僅僅執行一次!默認情況下,他設置一些環境變量,執行用戶的.bashrc文件.

      ~/.bashrc:該文件包含專用于你的bash shell的bash信息,當登錄時以及每次打開新的shell時,該文件被讀取.(每個用戶都有一個.bashrc文件,在用戶目錄下)

      ~/.bash_logout:當每次退出系統(退出bash shell)時,執行該文件. 

      另外,/etc/profile中設定的變量(全局)的可以作用于任何用戶,而~/.bashrc等中設定的變量(局部)只能繼承/etc/profile中的變量,他們是"父子"關系.

      ~/.bash_profile 是交互式、login 方式進入 bash 運行的
      ~/.bashrc 是交互式 non-login 方式進入 bash 運行的
      通常二者設置大致相同,所以通常前者會調用后者。


      在登錄Linux時要執行文件的過程如下:

      在剛登錄Linux時,首先啟動 /etc/profile 文件,然后再啟動用戶目錄下的 ~/.bash_profile、 ~/.bash_login或 ~/.profile文件中的其中一個,
      執行的順序為:~/.bash_profile、 ~/.bash_login、 ~/.profile。
      如果 ~/.bash_profile文件存在的話,一般還會執行 ~/.bashrc文件。
      因為在 ~/.bash_profile文件中一般會有下面的代碼:
      if [ -f ~/.bashrc ] ; then

      . ./bashrc

      fi

      ~/.bashrc中,一般還會有以下代碼:
      if [ -f /etc/bashrc ] ; then

      . /bashrc

      fi

      所以,~/.bashrc會調用 /etc/bashrc文件。最后,在退出shell時,還會執行 ~/.bash_logout文件。

      執行順序為:/etc/profile -> (~/.bash_profile | ~/.bash_login | ~/.profile) -> ~/.bashrc -> /etc/bashrc -> ~/.bash_logout

      關于各個文件的作用域,在網上找到了以下說明:

      (1)/etc/profile: 此文件為系統的每個用戶設置環境信息,當用戶第一次登錄時,該文件被執行. 并從/etc/profile.d目錄的配置文件中搜集shell的設置。

      (2)/etc/bashrc: 為每一個運行bash shell的用戶執行此文件.當bash shell被打開時,該文件被讀取。

      (3)~/.bash_profile:每個用戶都可使用該文件輸入專用于自己使用的shell信息,當用戶登錄時,該文件僅僅執行一次!默認情況下,他設置一些環境變量,執行用戶的.bashrc文件。

      (4)~/.bashrc:該文件包含專用于你的bash shell的bash信息,當登錄時以及每次打開新的shell時,該該文件被讀取。

      (5)~/.bash_logout: 當每次退出系統(退出bash shell)時,執行該文件. 另外,/etc/profile中設定的變量(全局)的可以作用于任何用戶,而~/.bashrc等中設定的變量(局部)只能繼承 /etc/profile中的變量,他們是"父子"關系。

      (6)~/.bash_profile 是交互式、login 方式進入 bash 運行的~/.bashrc 是交互式 non-login 方式進入 bash 運行的通常二者設置大致相同,所以通常前者會調用后者。

       

       

       

       

      1 #===============================================================
      2 #
      3 # 個人的$HOME/.bashrc文件, 基于bash-2.05a(或更高版本)
      4 #
      5 # 最后更新日期: 星期2 4月15 20:32:34 CEST 2003
      6 #
      7 # 這個文件(一般情況下)被只會被交互式shell讀取. 
      8 # 這里可以定義你的別名, 函數, 
      9 # 和其他的一些交互式特征, 比如你的提示符. 
      10 #
      11 # 這個文件(開始時)是為Solaris設計的, 
      12 # 但是基于Redhat的默認.bashrc文件
      13 # --> 為Linux修改. 
      14 # 你在這里看到的大部分代碼都是從網上找來的
      15 # (即internet). 
      16 # 這個bashrc文件有點擠 - 
      17 # 記住, 它僅僅是個例子而已. 按照你自己的需求進行裁減. 
      18 #
      19 #
      20 #===============================================================
      21 
      22 # --> 注釋由HOWTO的作者添加. 
      23 # --> 然后又被ER編輯了一下 :-)
      24 
      25 #--------------------------------------
      26 # 如果有源代碼的全局定義, 請在此處定義.
      27 #--------------------------------------
      28 
      29 if [ -f /etc/bashrc ]; then
      30 . /etc/bashrc # --> 讀取/etc/bashrc, 如果存在的話. 
      31 fi
      32 
      33 #-------------------------------------------------------------
      34 # $DISPLAY的自動設置 (如果還沒設置的話)
      35 # 這用于linux - 可能運行的結果不同.... 
      36 # 問題是不同的終端種類對于'who am i'來說, 
      37 # 將會給出不同的答案......
      38 # 我還沒發現一種'通用'方法
      39 #-------------------------------------------------------------
      40 
      41 function get_xserver ()
      42 {
      43 case $TERM in
      44 xterm )
      45 XSERVER=$(who am i | awk '{print $NF}' | tr -d ')''(' ) 
      46 # Ane-Pieter Wieringa建議使用下面這種方式:
      47 # I_AM=$(who am i)
      48 # SERVER=${I_AM#*(}
      49 # SERVER=${SERVER%*)}
      50 
      51 XSERVER=${XSERVER%%:*}
      52 ;;
      53 aterm | rxvt)
      54 # 找出一些運行在這里的代碼.....
      55 ;;
      56 esac 
      57 }
      58 
      59 if [ -z ${DISPLAY:=""} ]; then
      60 get_xserver
      61 if [[ -z ${XSERVER} || ${XSERVER} == $(hostname) || ${XSERVER} == "unix" ]]; then
      62 DISPLAY=":0.0" # 在本地主機上顯示
      63 else 
      64 DISPLAY=${XSERVER}:0.0 # 在遠端主機上顯示
      65 fi
      66 fi
      67 
      68 export DISPLAY
      69 
      70 #----------
      71 # 一些設置
      72 #----------
      73 
      74 ulimit -S -c 0 # 不需要任何coredump
      75 set -o notify
      76 set -o noclobber
      77 set -o ignoreeof
      78 set -o nounset
      79 #set -o xtrace # 對于調試來說非常有用
      80 
      81 # 使能選項:
      82 shopt -s cdspell
      83 shopt -s cdable_vars
      84 shopt -s checkhash
      85 shopt -s checkwinsize
      86 shopt -s mailwarn
      87 shopt -s sourcepath
      88 shopt -s no_empty_cmd_completion # 僅限于bash>=2.04
      89 shopt -s cmdhist
      90 shopt -s histappend histreedit histverify
      91 shopt -s extglob # 對于complete命令(按情況補全)來說是必要的
      92 
      93 # 禁用選項:
      94 shopt -u mailwarn
      95 unset MAILCHECK # 當有郵件到達時, 我不希望我的shell提示我
      96 
      97 
      98 export TIMEFORMAT=$'\nreal %3R\tuser %3U\tsys %3S\tpcpu %P\n'
      99 export HISTIGNORE="&:bg:fg:ll:h"
      100 export HOSTFILE=$HOME/.hosts # 將遠端主機的列表放入~/.hosts
      101 
      102 
      103 
      104 #-----------------------
      105 # 問候, 問侯報文等等...
      106 #-----------------------
      107 
      108 # 先定義一些顏色:
      109 red='\e[0;31m'
      110 RED='\e[1;31m'
      111 blue='\e[0;34m'
      112 BLUE='\e[1;34m'
      113 cyan='\e[0;36m'
      114 CYAN='\e[1;36m'
      115 NC='\e[0m' # 沒有顏色
      116 # --> 很好. 與使用"ansi.sys"的DOS效果相同. 
      117 
      118 # 在黑色背景下看起來非常好.....
      119 echo -e "${CYAN}This is BASH ${RED}${BASH_VERSION%.*}${CYAN} - DISPLAY on ${RED}$DISPLAY${NC}\n"
      120 date
      121 if [ -x /usr/games/fortune ]; then
      122 /usr/games/fortune -s # 讓我們的每天充滿樂趣.... :-)
      123 fi
      124 
      125 function _exit() # 在退出shell時運行的函數
      126 {
      127 echo -e "${RED}Hasta la vista, baby${NC}"
      128 }
      129 trap _exit EXIT
      130 
      131 #---------------
      132 # Shell提示符
      133 #---------------
      134 
      135 if [[ "${DISPLAY#$HOST}" != ":0.0" && "${DISPLAY}" != ":0" ]]; then 
      136 HILIT=${red} # 遠端主機: 提示符為紅
      137 else
      138 HILIT=${cyan} # 本地主機: 提示符為青色
      139 fi
      140 
      141 # --> 下面提示符函數中\W和\w的替換實例, 
      142 #+ --> 用來獲得完整路徑名的顯示. 
      143 
      144 function fastprompt()
      145 {
      146 unset PROMPT_COMMAND
      147 case $TERM in
      148 *term | rxvt )
      149 PS1="${HILIT}[\h]$NC \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;
      150 linux )
      151 PS1="${HILIT}[\h]$NC \W > " ;;
      152 *)
      153 PS1="[\h] \W > " ;;
      154 esac
      155 }
      156 
      157 function powerprompt()
      158 {
      159 _powerprompt()
      160 {
      161 LOAD=$(uptime|sed -e "s/.*: \([^,]*\).*/\1/" -e "s/ //g")
      162 }
      163 
      164 PROMPT_COMMAND=_powerprompt
      165 case $TERM in
      166 *term | rxvt )
      167 PS1="${HILIT}[\A \$LOAD]$NC\n[\h \#] \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;
      168 linux )
      169 PS1="${HILIT}[\A - \$LOAD]$NC\n[\h \#] \w > " ;;
      170 * )
      171 PS1="[\A - \$LOAD]\n[\h \#] \w > " ;;
      172 esac
      173 }
      174 
      175 powerprompt # 這是默認提示符 - 可能比較慢
      176 # 如果很慢的話, 可以使用fastprompt來代替....
      177 
      178 #===============================================================
      179 #
      180 # 別名和函數
      181 #
      182 # 事實上, 這里定義的一些函數非常大
      183 # (比如'lowercase'), 但是我的機器是512M內存, 所以 .....
      184 # 如果你想讓這個文件小一點, 
      185 # 可以將這些函數放到腳本中. 
      186 #
      187 # 其中的許多函數來自于bash-2.04
      188 # 中的例子. 
      189 #
      190 #===============================================================
      191 
      192 #-------------------
      193 # 個人的別名
      194 #-------------------
      195 
      196 alias rm='rm -i'
      197 alias cp='cp -i'
      198 alias mv='mv -i'
      199 # -> 防止偶然的文件誤操作. 
      200 alias mkdir='mkdir -p'
      201 
      202 alias h='history'
      203 alias j='jobs -l'
      204 alias r='rlogin'
      205 alias which='type -all'
      206 alias ..='cd ..'
      207 alias path='echo -e ${PATH//:/\\n}'
      208 alias print='/usr/bin/lp -o nobanner -d $LPDEST' # 假設LPDEST被定義
      209 alias pjet='enscript -h -G -fCourier9 -d $LPDEST' # 使用enscript的漂亮的打印
      210 alias background='xv -root -quit -max -rmode 5' # 將一張圖片作為背景
      211 alias du='du -kh'
      212 alias df='df -kTh'
      213 
      214 # 'ls'家族 (假定使用GNU ls)
      215 alias la='ls -Al' # 顯示隱藏文件
      216 alias ls='ls -hF --color' # 為識別的文件類型添加顏色
      217 alias lx='ls -lXB' # 按擴展名排序
      218 alias lk='ls -lSr' # 按尺寸排序
      219 alias lc='ls -lcr' # 按修改時間排序
      220 alias lu='ls -lur' # 按訪問時間排序
      221 alias lr='ls -lR' # 遞歸ls
      222 alias lt='ls -ltr' # 按日期排序
      223 alias lm='ls -al |more' # 管道給'more'
      224 alias tree='tree -Csu' # 'ls'的另一種好方法
      225 
      226 # 裁減'less'
      227 alias more='less'
      228 export PAGER=less
      229 export LESSCHARSET='latin1'
      230 export LESSOPEN='|/usr/bin/lesspipe.sh %s 2>&-' # 如果lesspipe.sh存在, 就用這個
      231 export LESS='-i -N -w -z-4 -g -e -M -X -F -R -P%t?f%f \
      232 :stdin .?pb%pb\%:?lbLine %lb:?bbByte %bb:-...'
      233 
      234 # 拼寫錯誤 - 純粹個人喜好 :-)
      235 alias xs='cd'
      236 alias vf='cd'
      237 alias moer='more'
      238 alias moew='more'
      239 alias kk='ll'
      240 
      241 #----------------
      242 # 一些有趣東西
      243 #----------------
      244 
      245 function xtitle ()
      246 {
      247 case "$TERM" in
      248 *term | rxvt)
      249 echo -n -e "\033]0;$*\007" ;;
      250 *) 
      251 ;;
      252 esac
      253 }
      254 
      255 # 別名...
      256 alias top='xtitle Processes on $HOST && top'
      257 alias make='xtitle Making $(basename $PWD) ; make'
      258 alias ncftp="xtitle ncFTP ; ncftp"
      259 
      260 # .. 和函數
      261 function man ()
      262 {
      263 for i ; do
      264 xtitle The $(basename ?|tr -d .[:digit:]) manual
      265 command man -F -a "$i"
      266 done
      267 }
      268 
      269 function ll(){ ls -l "$@"| egrep "^d" ; ls -lXB "$@" 2>&-| egrep -v "^d|total "; }
      270 function te() # xemacs/gnuserv的包裝器
      271 {
      272 if [ "$(gnuclient -batch -eval t 2>&-)" == "t" ]; then
      273 gnuclient -q "$@";
      274 else
      275 ( xemacs "$@" &);
      276 fi
      277 }
      278 
      279 #---------------------------
      280 # 與文件和字符串相關的函數:
      281 #---------------------------
      282 
      283 # 使用名字模式來查找文件:
      284 function ff() { find . -type f -iname '*'$*'*' -ls ; }
      285 # 使用pattern ?和Execute ū來查找文件: 
      286 function fe() { find . -type f -iname '*'?'*' -exec "${2:-file}" {} \; ; }
      287 # 在一系列文件中找到模式, 并高亮
      288 function fstr()
      289 {
      290 OPTIND=1
      291 local case=""
      292 local usage="fstr: find string in files.
      293 Usage: fstr [-i] \"pattern\" [\"filename pattern\"] "
      294 while getopts :it opt
      295 do
      296 case "$opt" in
      297 i) case="-i " ;;
      298 *) echo "$usage"; return;;
      299 esac
      300 done
      301 shift $(( $OPTIND - 1 ))
      302 if [ "$#" -lt 1 ]; then
      303 echo "$usage"
      304 return;
      305 fi
      306 local SMSO=$(tput smso)
      307 local RMSO=$(tput rmso)
      308 find . -type f -name "${2:-*}" -print0 | xargs -0 grep -sn ${case} "?" 2>&- | \
      309 sed "s/?/${SMSO}\0${RMSO}/gI" | more
      310 }
      311 
      312 function cuttail() # 在文件中切掉n行, 默認為10行
      313 {
      314 nlines=${2:-10}
      315 sed -n -e :a -e "1,${nlines}!{P;N;D;};N;ba" ?
      316 }
      317 
      318 function lowercase() # 將文件名轉換為小寫
      319 {
      320 for file ; do
      321 filename=${file##*/}
      322 case "$filename" in
      323 */*) dirname==${file%/*} ;;
      324 *) dirname=.;;
      325 esac
      326 nf=$(echo $filename | tr A-Z a-z)
      327 newname="${dirname}/${nf}"
      328 if [ "$nf" != "$filename" ]; then
      329 mv "$file" "$newname"
      330 echo "lowercase: $file --> $newname"
      331 else
      332 echo "lowercase: $file not changed."
      333 fi
      334 done
      335 }
      336 
      337 function swap() # 交換兩個文件名
      338 {
      339 local TMPFILE=tmp.$$
      340 mv "?" $TMPFILE
      341 mv "ū" "?"
      342 mv $TMPFILE "ū"
      343 }
      344 
      345 
      346 #----------------------
      347 # 進程/系統相關的函數:
      348 #----------------------
      349 
      350 function my_ps() { ps $@ -u $USER -o pid,%cpu,%mem,bsdtime,command ; }
      351 function pp() { my_ps f | awk '!/awk/ && ?~var' var=${1:-".*"} ; }
      352 
      353 # 這個函數與linux上的'killall'基本一致
      354 # 但是與Solaris上的卻不相同
      355 function killps() # 按進程名進行kill
      356 {
      357 local pid pname sig="-TERM" # 默認signal
      358 if [ "$#" -lt 1 ] || [ "$#" -gt 2 ]; then
      359 echo "Usage: killps [-SIGNAL] pattern"
      360 return;
      361 fi
      362 if [ $# = 2 ]; then sig=? ; fi
      363 for pid in $(my_ps| awk '!/awk/ && ?~pat { print ? }' pat=${!#} ) ; do
      364 pname=$(my_ps | awk '?~var { print ? }' var=$pid )
      365 if ask "Kill process $pid <$pname> with signal $sig?"
      366 then kill $sig $pid
      367 fi
      368 done
      369 }
      370 
      371 function my_ip() # 獲得IP地址
      372 {
      373 MY_IP=$(/sbin/ifconfig ppp0 | awk '/inet/ { print ū } ' | sed -e s/addr://)
      374 MY_ISP=$(/sbin/ifconfig ppp0 | awk '/P-t-P/ { print ū } ' | sed -e s/P-t-P://)
      375 }
      376 
      377 function ii() # 獲得當前主機相關的信息
      378 {
      379 echo -e "\nYou are logged on ${RED}$HOST"
      380 echo -e "\nAdditionnal information:$NC " ; uname -a
      381 echo -e "\n${RED}Users logged on:$NC " ; w -h
      382 echo -e "\n${RED}Current date :$NC " ; date
      383 echo -e "\n${RED}Machine stats :$NC " ; uptime
      384 echo -e "\n${RED}Memory stats :$NC " ; free
      385 my_ip 2>&- ;
      386 echo -e "\n${RED}Local IP Address :$NC" ; echo ${MY_IP:-"Not connected"}
      387 echo -e "\n${RED}ISP Address :$NC" ; echo ${MY_ISP:-"Not connected"}
      388 echo
      389 }
      390 
      391 # 雜項工具:
      392 
      393 function repeat() # 重復n次的命令
      394 {
      395 local i max
      396 max=? shift;
      397 for ((i=1; i <= max ; i++)); do # --> C風格的語法
      398 eval "$@";
      399 done
      400 }
      401 
      402 function ask()
      403 {
      404 echo -n "$@" '[y/n] ' ; read ans
      405 case "$ans" in
      406 y*|Y*) return 0 ;;
      407 *) return 1 ;;
      408 esac
      409 }
      410 
      411 #=========================================================================
      412 #
      413 # 按情況補全, complete命令 - BASH-2.04及其后續版本
      414 # 大部分摘自bash 2.05文檔
      415 # 和Ian McDonalds的'Bash completion'軟件包(http://www.caliban.org/bash/index.shtml#completion)
      416 # 某些特征可能需要使用bash-2.05a
      417 #
      418 #=========================================================================
      419 
      420 if [ "${BASH_VERSION%.*}" \< "2.05" ]; then
      421 echo "You will need to upgrade to version 2.05 for programmable completion"
      422 return
      423 fi
      424 
      425 shopt -s extglob # 必須的
      426 set +o nounset # 否則某些自動補全將會失敗
      427 
      428 complete -A hostname rsh rcp telnet rlogin r ftp ping disk
      429 complete -A export printenv
      430 complete -A variable export local readonly unset
      431 complete -A enabled builtin
      432 complete -A alias alias unalias
      433 complete -A function function
      434 complete -A user su mail finger
      435 
      436 complete -A helptopic help # 通常與內建命令一樣
      437 complete -A shopt shopt
      438 complete -A stopped -P '%' bg
      439 complete -A job -P '%' fg jobs disown
      440 
      441 complete -A directory mkdir rmdir
      442 complete -A directory -o default cd
      443 
      444 # 壓縮
      445 complete -f -o default -X '*.+(zip|ZIP)' zip
      446 complete -f -o default -X '!*.+(zip|ZIP)' unzip
      447 complete -f -o default -X '*.+(z|Z)' compress
      448 complete -f -o default -X '!*.+(z|Z)' uncompress
      449 complete -f -o default -X '*.+(gz|GZ)' gzip
      450 complete -f -o default -X '!*.+(gz|GZ)' gunzip
      451 complete -f -o default -X '*.+(bz2|BZ2)' bzip2
      452 complete -f -o default -X '!*.+(bz2|BZ2)' bunzip2
      453 # Postscript,pdf,dvi.....(譯者: 打印格式相關)
      454 complete -f -o default -X '!*.ps' gs ghostview ps2pdf ps2ascii
      455 complete -f -o default -X '!*.dvi' dvips dvipdf xdvi dviselect dvitype
      456 complete -f -o default -X '!*.pdf' acroread pdf2ps
      457 complete -f -o default -X '!*.+(pdf|ps)' gv
      458 complete -f -o default -X '!*.texi*' makeinfo texi2dvi texi2html texi2pdf
      459 complete -f -o default -X '!*.tex' tex latex slitex
      460 complete -f -o default -X '!*.lyx' lyx
      461 complete -f -o default -X '!*.+(htm*|HTM*)' lynx html2ps
      462 # 多媒體
      463 complete -f -o default -X '!*.+(jp*g|gif|xpm|png|bmp)' xv gimp
      464 complete -f -o default -X '!*.+(mp3|MP3)' mpg123 mpg321
      465 complete -f -o default -X '!*.+(ogg|OGG)' ogg123
      466 
      467 
      468 
      469 complete -f -o default -X '!*.pl' perl perl5
      470 
      471 # 這是一個'通用的'補全函數 - 當命令具有一個所謂的"長選項"模式it works when commands have
      472 # 的時候, 它就會工作, 比如: 'ls --all' 代替 'ls -a'
      473 
      474 _get_longopts () 
      475 { 
      476 ? --help | sed -e '/--/!d' -e 's/.*--\([^[:space:].,]*\).*/--\1/'| \
      477 grep ^"ū" |sort -u ;
      478 }
      479 
      480 _longopts_func ()
      481 {
      482 case "${2:-*}" in
      483 -*) ;;
      484 *) return ;;
      485 esac
      486 
      487 case "?" in
      488 \~*) eval cmd="?" ;;
      489 *) cmd="?" ;;
      490 esac
      491 COMPREPLY=( $(_get_longopts ${1} ${2} ) )
      492 }
      493 complete -o default -F _longopts_func configure bash
      494 complete -o default -F _longopts_func wget id info a2ps ls recode
      495 
      496 
      497 _make_targets ()
      498 {
      499 local mdef makef gcmd cur prev i
      500 
      501 COMPREPLY=()
      502 cur=${COMP_WORDS[COMP_CWORD]}
      503 prev=${COMP_WORDS[COMP_CWORD-1]}
      504 
      505 # 如果之前的參數為-f, 那就返回可能的補全文件名. 
      506 # 我們可以讓它更智能一些, 并且返回匹配的
      507 # `makefile Makefile *.mk', 不管存在與否
      508 case "$prev" in
      509 -*f) COMPREPLY=( $(compgen -f $cur ) ); return 0;;
      510 esac
      511 
      512 # 如果我們需要一個選項, 那就返回可能的posix選項
      513 case "$cur" in
      514 -) COMPREPLY=(-e -f -i -k -n -p -q -r -S -s -t); return 0;;
      515 esac
      516 
      517 # 前嘗試`makefile'再嘗試`Makefile'
      518 if [ -f makefile ]; then
      519 mdef=makefile
      520 elif [ -f Makefile ]; then
      521 mdef=Makefile
      522 else
      523 mdef=*.mk # 局部約定
      524 fi
      525 
      526 # 在我們掃描目標文件之前, 察看makefile文件名是否
      527 # 使用-f指定
      528 for (( i=0; i < ${#COMP_WORDS[@]}; i++ )); do
      529 if [[ ${COMP_WORDS} == -*f ]]; then
      530 eval makef=${COMP_WORDS[i+1]} # eval for tilde expansion(波浪號擴展)
      531 break
      532 fi
      533 done
      534 
      535 [ -z "$makef" ] && makef=$mdef
      536 
      537 # 如果我們有特別偏愛的補全單詞, 
      538 # 那么可以限制的補全這個單詞
      539 if [ -n "ū" ]; then gcmd='grep "^ū"' ; else gcmd=cat ; fi
      540 
      541 # 如果我們不想使用*.mk, 我們可以使用
      542 # 或者使用test -f $makef或者使用輸入重定向
      543 COMPREPLY=( $(cat $makef 2>/dev/null | awk 'BEGIN {FS=":"} /^[^.# ][^=]*:/ {print ?}' | tr -s ' ' '\012' | sort -u | eval $gcmd ) )
      544 }
      545 
      546 complete -F _make_targets -X '+($*|*.[cho])' make gmake pmake
      547 
      548 
      549 # cvs(1) 補全
      550 _cvs ()
      551 {
      552 local cur prev
      553 COMPREPLY=()
      554 cur=${COMP_WORDS[COMP_CWORD]}
      555 prev=${COMP_WORDS[COMP_CWORD-1]}
      556 
      557 if [ $COMP_CWORD -eq 1 ] || [ "${prev:0:1}" = "-" ]; then
      558 COMPREPLY=( $( compgen -W 'add admin checkout commit diff \
      559 export history import log rdiff release remove rtag status \
      560 tag update' $cur ))
      561 else
      562 COMPREPLY=( $( compgen -f $cur ))
      563 fi
      564 return 0
      565 }
      566 complete -F _cvs cvs
      567 
      568 _killall ()
      569 {
      570 local cur prev
      571 COMPREPLY=()
      572 cur=${COMP_WORDS[COMP_CWORD]}
      573 
      574 # 獲得進程列表(第一個sed表達式處理
      575 # swap out出去的進程, 第二個
      576 # 獲得進程的basename)
      577 COMPREPLY=( $( /usr/bin/ps -u $USER -o comm | \
      578 sed -e '1,1d' -e 's#[]\[]##g' -e 's#^.*/##'| \
      579 awk '{if (? ~ /^'$cur'/) print ?}' ))
      580 
      581 return 0
      582 }
      583 
      584 complete -F _killall killall killps
      585 
      586 
      587 # 一個元命令補全函數, 用于sudo(8)這種命令, 
      588 # 需要先對這個命令進行補全, 然后需要按照這個命令自己的補全定義進行補全
      589 # - 當前并不是非常可靠(比如 mount和umount命令
      590 # 就不能很好的工作), 但還是很有用的 - 作者, Ian McDonald, 我修改了一下. 
      591 
      592 _my_command()
      593 {
      594 local cur func cline cspec
      595 
      596 COMPREPLY=()
      597 cur=${COMP_WORDS[COMP_CWORD]}
      598 
      599 if [ $COMP_CWORD = 1 ]; then
      600 COMPREPLY=( $( compgen -c $cur ) )
      601 elif complete -p ${COMP_WORDS[1]} &>/dev/null; then
      602 cspec=$( complete -p ${COMP_WORDS[1]} )
      603 if [ "${cspec%%-F *}" != "${cspec}" ]; then
      604 # complete -F <function>
      605 #
      606 # COMP_CWORD和COMP_WORDS()不是只讀的,
      607 # 所以我們可以在傳遞到補全例程之前, 
      608 # 設置它們
      609 
      610 # 設置當前的標志號減1
      611 COMP_CWORD=$(( $COMP_CWORD - 1 ))
      612 # 獲得函數名
      613 func=${cspec#*-F }
      614 func=${func%% *}
      615 # 獲得去掉第一個命令后的命令行
      616 cline="${COMP_LINE#? }"
      617 # 分離當前命令, 傳遞給數組
      618 COMP_WORDS=( $cline )
      619 $func $cline
      620 elif [ "${cspec#*-[abcdefgjkvu]}" != "" ]; then
      621 # complete -[abcdefgjkvu]
      622 #func=$( echo $cspec | sed -e 's/^.*\(-[abcdefgjkvu]\).*$/\1/' )
      623 func=$( echo $cspec | sed -e 's/^complete//' -e 's/[^ ]*$//' )
      624 COMPREPLY=( $( eval compgen $func $cur ) )
      625 elif [ "${cspec#*-A}" != "$cspec" ]; then
      626 # complete -A <type>
      627 func=${cspec#*-A }
      628 func=${func%% *}
      629 COMPREPLY=( $( compgen -A $func $cur ) )
      630 fi
      631 else
      632 COMPREPLY=( $( compgen -f $cur ) )
      633 fi
      634 }
      635 
      636 
      637 complete -o default -F _my_command nohup exec eval trace truss strace sotruss gdb
      638 complete -o default -F _my_command command type which man nice
      639 
      640 # 本地變量:
      641 # mode:shell-script
      642 # sh-shell:bash
      643 # End:

      posted @ 2016-02-17 13:34  民工程序員  閱讀(874)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 最近中文字幕完整版2019| 成人动漫在线观看| 成人av一区二区亚洲精| 天堂网在线观看| 欧美日本在线一区二区三区| 亚洲日本精品国产第一区| 免费看欧美全黄成人片| 亚洲欧美人成网站在线观看看| 美女黄网站人色视频免费国产| 久久99热只有频精品6狠狠| 精选国产av精选一区二区三区| 国内精品九九久久久精品| 久久精品国产精品亚洲 | 伊人久久大香线蕉av色婷婷色 | 国产真人做受视频在线观看| 欧美 亚洲 日韩 在线综合| 成人无码午夜在线观看| 亚洲综合国产一区二区三区| 久久综合激情网| 久久99久久99精品免观看| 九九热视频在线观看精品| 久久精品国产蜜臀av| 国产99青青成人A在线| 国产自拍一区二区三区在线| 欧美日韩中文国产一区| 国产一区二区亚洲一区二区三区| 97精品人妻系列无码人妻| 日韩高清亚洲日韩精品一区二区| 夜夜躁狠狠躁日日躁| 中文字幕一区二区网站| 欧美成本人视频免费播放| 一区二区三区黄色一级片| 国产精品久久久久av福利动漫| 色噜噜狠狠一区二区三区果冻| 丰满人妻一区二区三区高清精品| 久久久久国产精品人妻| 国产成人精彩在线视频| 欧美日韩不卡视频合集| 国产成人精品国内自产色| 成人免费看片又大又黄| 国内自拍视频一区二区三区|