add bash man draft

This commit is contained in:
Jerry Lee
2014-09-13 19:29:00 +08:00
parent 7cf69a596f
commit 922389674a
7 changed files with 2436 additions and 0 deletions

92
bash-3-man/README.md Normal file
View File

@@ -0,0 +1,92 @@
[`bash 2` `man`中文翻译](http://ahei.info/chinese-bash-man.htm) - 袁乙钧 \<bbbush@163.com\>
本翻译在上面的基础上更新到`bash 3`
Bash man
===============================
![bash](images/bash.png "bash")[.](https://www.behance.net/gallery/7384837/DJ-BASH-Logo-Design)
目录
-------------
1. [概要](overview.md#概要)
1. [版权所有](overview.md#版权所有)
1. [描述](overview.md#描述)
1. [选项](overview.md#选项)
1. [参数](overview.md#参数)
1. [启动](overview.md#启动)
1. [定义](overview.md#定义)
1. [保留字](overview.md#保留字)
1. [`shell`语法](#shell语法)
- [Simple Commands 简单命令](#lbAL)
- [Pipelines 管道](#lbAM)
- [Lists 序列](#lbAN)
- [Compound Commands 复合命令](#lbAO)
1. [注释(COMMENTS)](#lbAP)
1. [引用(QUOTING)](#lbAQ)
1. [参数(PARAMETERS)](#lbAR)
- [Positional Parameters 位置参数](#lbAS)
- [Special Parameters 特殊参数](#lbAT)
- [Shell Variables 变量](#lbAU)
- [Arrays](#lbAV)
1. [扩展(EXPANSION)](#lbAW)
- [Brace Expansion](#lbAX)
- [Tilde Expansion](#lbAY)
- [Parameter Expansion](#lbAZ)
- [Command Substitution](#lbBA)
- [Arithmetic Expansion](#lbBB)
- [Process Substitution](#lbBC)
- [Word Splitting](#lbBD)
- [Pathname Expansion](#lbBE)
- [Quote Removal](#lbBF)
1. [重定向(REDIRECTION)](#lbBG)
- [Redirecting Input](#lbBH)
- [Redirecting Output](#lbBI)
- [Appending Redirected Output (添加到重定向后的输出尾部)](#lbBJ)
- [Redirecting Standard Output and Standard Error](#lbBK)
- [Here Documents](#lbBL)
- [Here Strings](#lbBM)
- [Duplicating File Descriptors (复制文件描述符)](#lbBN)
- [Moving File Descriptors](#lbBO)
- [Opening File Descriptors for Reading and Writing](#lbBP)
1. [别名(ALIASES)](#lbBQ)
1. [函数(FUNCTIONS)](#lbBR)
1. [算术求值(ARITHMETIC EVALUATION)](#lbBS)
1. [条件表达式(CONDITIONAL EXPRESSIONS)](#lbBT)
1. [简单命令扩展(SIMPLE COMMAND EXPANSION)](#lbBU)
1. [命令执行(COMMAND EXECUTION)](#lbBV)
1. [命令执行环境(COMMAND EXECUTION ENVIRONMENT)](#lbBW)
1. [环境(ENVIRONMENT)](#lbBX)
1. [退出状态(EXIT STATUS)](#lbBY)
1. [信号(SIGNALS)](#lbBZ)
1. [作业控制(JOB CONTROL)](#lbCA)
1. [提示符(PROMPTING)](#lbCB)
1. [readline库(READLINE)](#lbCC)
- [Readline Notation](#lbCD)
- [Readline Initialization 初始化](#lbCE)
- [Readline Key Bindings](#lbCF)
- [Readline Variables](#lbCG)
- [Readline Conditional Constructs](#lbCH)
- [Searching](#lbCI)
- [Readline Command Names](#lbCJ)
- [Commands for Moving 移动](#lbCK)
- [Commands for Manipulating the History 操纵历史行](#lbCL)
- [Commands for Changing Text 改变文本](#lbCM)
- [Killing and Yanking 剪切和粘贴](#lbCN)
- [Numeric Arguments 数值参数](#lbCO)
- [Completing 补全](#lbCP)
- [Keyboard Macros 宏](#lbCQ)
- [Miscellaneous](#lbCR)
- [Programmable Completion 可编程补全](#lbCS)
1. [历史(HISTORY)](#lbCT)
1. [历史扩展(HISTORY EXPANSION)](#lbCU)
- [Event Designators](#lbCV)
- [Word Designators](#lbCW)
- [修饰符 (Modifiers)](#lbCX)
1. [shell 内建命令(SHELL BUILTIN COMMANDS)](#lbCY)
1. [受限的shell(RESTRICTED SHELL)](#lbCZ)
1. [参见(SEE ALSO)](#lbDA)
1. [文件(FILES)](#lbDB)
1. [作者(AUTHORS)](#lbDC)
1. [报告BUGS (BUG REPORTS)](#lbDD)
1. [BUGS](#lbDE)

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
bash-3-man/images/bash.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 63 KiB

144
bash-3-man/overview.md Normal file
View File

@@ -0,0 +1,144 @@
名字
-------------
`bash` - `GNU Bourne-Again SHell``GNU` `Bourne`二世命令解释程序)
概要
-------------
```bash
bash [options] [file]
```
版权所有
-------------
`Bash``Free Software Foundation, Inc`版权所有 1989-2002。
描述
-------------
`Bash`是一个与`sh`兼容的命令解释程序,可以执行从标准输入或者文件中读取的命令。
`Bash`也整合了`Korn``C` `Shell``ksh``csh`)中的优秀特性。
`Bash`的目标是成为遵循`IEEE` `POSIX` `Shell`和工具规范的实现。
选项
-------------
除了在`set`内建命令的文档中讲述的单字符选项之外,`bash`在启动时还解释下列选项。
- `-c string`
如果有`-c`选项,那么命令将从`string`中读取。如果`string`后面有参数,它们将用于给位置参数 (以`$0`起始) 赋值。
- `-i`
如果有`-i`选项,`shell`将交互地执行。
- `-l`
选项使得`bash`以类似登录`shell``login shell`)的方式启动(参见下面的【启动】一节)。
- `-r`
如果有`-r`选项,`shell`成为受限的(`restricted`)(参见下面的【受限的`shell`一节)。
- `-s`
如果有 -s 选项,或者如果选项处理完以后,没有参数剩余,那么命令将从标准输入读取。 这个选项允许在启动一个交互 shell 时可以设置位置参数。
- `-D`
向标准输出打印一个以 $ 为前导的,以双引号引用的字符串列表。 这是在当前语言环境不是 C 或 POSIX 时,脚本中需要翻译的字符串。 这个选项隐含了 -n 选项;不会执行命令。
- `[-+]O [shopt_option]`
shopt_option 是一个 shopt 内建命令可接受的选项 (参见下面的 shell 内建命令(SHELL BUILTIN COMMANDS) 章节)。 如果有 shopt_option-O 将设置那个选项的取值; +O 取消它。 如果没有给出 shopt_optionshopt 将在标准输出上打印设为允许的选项的名称和值。 如果启动选项是 +O输出将以一种可以重用为输入的格式显示。
- `--`
-- 标志选项的结束,禁止其余的选项处理。任何 -- 之后的参数将作为文件名和参数对待。参数 - 与此等价。
Bash 也解释一些多字节的选项。在命令行中,这些选项必须置于需要被识别的单字符参数之前。
- `--dump-po-strings`
等价于 -D但是输出是 GNU gettext po (可移植对象) 文件格式
- `--dump-strings`
等价于 -D
- `--help`
在标准输出显示用法信息并成功退出
- `--init-file file`
`--rcfile file`
如果 shell 是交互的,执行 file 中的命令,而不是标准的个人初始化文件 ~/.bashrc (参见下面的 启动(INVOCATION) 章节)
- `--login`
等价于 -l
- `--noediting`
如果 shell 是交互的,不使用 GNU readline 库来读命令行
- `--noprofile`
不读取系统范围的启动文件 /etc/profile 或者任何个人初始化文件 ~/.bash_profile, ~/.bash_login, 或 ~/.profile 。默认情况下, bash 在作为登录 shell 启动时读取这些文件 (参见下面的 启动(INVOCATION) 章节)
- `--norc`
如果 shell 是交互的,不读取/执行个人初始化文件 ~/.bashrc 这个选项在 shell 以 sh 命令启动时是默认启用的
- `--posix`
如果默认操作与 POSIX 1003.2 标准不同的话,改变 bash 的行为来符合标准 (posix mode)
- `--restricted`
shell 成为受限的 (参见下面的 受限的shell(RESTRICTED SHELL) 章节)
- `--rpm-requires`
产生一个为使脚本运行,需要的文件的列表。 这个选项包含了 -n 选项。 它是为了避免进行编译期错误检测时的限制-- Backticks, [] tests, 还有 evals 不会被解释,一些依赖关系可能丢失
- `--verbose`
等价于 -v
- `--version`
在标准输出显示此 bash 的版本信息并成功退出。
参数
-------------
如果选项处理之后仍有参数剩余,并且没有指定 -c 或 -s 选项,第一个参数将假定为一个包含 shell 命令的文件的名字。 如果 bash 是以这种方式启动的, $0 将设置为这个文件的名字,位置参数将设置为剩余的其他参数。 Bash 从这个文件中读取并执行命令,然后退出。 Bash 的退出状态是脚本中执行的最后一个命令的退出状态。 如果没有执行命令退出状态是0。 尝试的步骤是先试图打开在当前目录中的这个文件,接下来, 如果没有找到shell 将搜索脚本的 PATH 环境变量中的路径。
启动(INVOCATION)
login shell 登录 shell参数零的第一个字符是 - ,或者启动时指定了 --login 选项的 shell。
interactive 交互的 shell是一个启动时没有指定非选项的参数并且没有指定 -c 选项,标准输出和标准输入都连接到了终端 (在 isatty(3) 中判定) 的shell或者启动时指定了 -i 选项的 shell。如果 bash 是交互的, PS1 环境变量将被设置,并且 $- 包含 i ,允许一个 shell 脚本或者一个启动文件来检测这一状态。
下列段落描述了 bash 如何执行它的启动文件。如果这些启动文件中的任一个存在但是不可读取, bash 将报告一个错误。文件名中的波浪号 (~,tilde) 将像 EXPANSION 章节中 Tilde Expansion 段描述的那样展开。
当 bash 是作为交互的登录 shell 启动的,或者是一个非交互的 shell 但是指定了 --login 选项, 它首先读取并执行 /etc/profile 中的命令,只要那个文件存在。 读取那个文件之后,它以如下的顺序查找 ~/.bash_profile, ~/.bash_login, 和 ~/.profile, 从存在并且可读的第一个文件中读取并执行其中的命令。 --noprofile 选项可以用来在 shell 启动时阻止它这样做。
当一个登录 shell 退出时, bash 读取并执行文件 ~/.bash_logout 中的命令,只要它存在。
当一个交互的 shell 但不是登录 shell 启动时, bash 从文件 ~/.bashrc 中读取并执行命令,只要它存在。可以用 --norc 选项来阻止它这样做。 --rcfile file 选项将强制 bash 读取并执行文件 file 中的命令,而不是 ~/.bashrc 中的。
当 bash 以非交互的方式启动时,例如在运行一个 shell 脚本时,它在环境中查找变量 BASH_ENV ,如果它存在则将它的值展开,使用展开的值作为一个文件的名称,读取并执行。 Bash 运作的过程就如同执行了下列命令:
if [ -n "$BASH_ENV" ]; then . "$BASH_ENV"; fi
但是没有使用 PATH 变量的值来搜索那个文件名。
如果 bash 以名称 sh 启动,它试图模仿 (mimic) sh 历史版本的启动过程,尽可能地相似,同时也遵循 POSIX 标准。 当作为交互式登录 shell 启动时,或者是非交互但使用了 --login 选项 启动的时候,它首先尝试读取并执行文件 /etc/profile 和 ~/.profile, 中的命令. 选项 --noprofile 用于避免这种行为.当使用命令 sh 来启动一个交互式的 shell 时, bash 查找环境变量 ENV, 如果有定义的话就扩展它的值,然后使用扩展后的值作为要读取和执行的文件 的名称.由于使用 sh 启动的 shell 不会读取和执行任何其他的启动文件,选项 --rcfile 没有意义.使用名称 sh 启动的非交互的 shell 不会读取任何其他启动文件.当以 sh 启动时, bash 在读取启动文件之后进入 posix 模式.
当 bash 以 posix 模式启动时,(和使用 --posix 命令行参数效果相同),它遵循 POSIX 标准. 这种模式下,交互式 shell 扩展 ENV 环境变量的值,读取并执行以扩展后值为文件名的配置文件. 不会读取其他文件.
Bash 试着检测它是不是由远程 shell 守护程序,通常为 rshd 启动的.如果 bash 发现它是由 rshd 启动的,它将读取并执行 ~/.bashrc 文件中的命令, 只要这个文件存在并且可读.如果以 sh 命令启动,它不会这样做. 选项 --norc 可以用来阻止这种行为,选项 --rcfile 用来强制读取另一个文件,但是通常 rshd 不会允许它们, 或者用它们来启动 shell.
如果 shell 是以与真实用户(组) id 不同的有效用户(组) id 来启动的, 并且没有 - 选项,那么它不会读取启动文件, 也不会从环境中继承 shell 函数. 环境变量中如果出现 SHELLOPTS 它将被忽略.有效用户 id 将设置为真实用户 id. 如果启动时给出了 -
选项,那么启动时的行为是类似的, 但是不会重置有效用户 id.
定义
-------------
下列定义在文档余下部分中通用.
blank 空白
一个空格或是 tab .
word 词
一个字符序列, shell 将它们视为一个结构单元. 也称为一个 token片段。
name 名称
一个只由字母,数字和下划线构成的词,并且以字符或下划线起始. 也称为一个 word identifier标识符.
metacharacter 元字符
一个字符, 如果不是引用的话, 将成为词的分隔符. 它是如下字符之一:
| & ; ( ) < > space tab
control operator 控制操作符
一个 token(标识), 拥有控制功能. 它是如下符号之一:
|| & && ; ;; ( ) | <newline>
保留字
-------------
**保留字**是对`shell`有特殊意义的词。
如果
- 不是在引用中
- 并且
- 简单命令的起始词或参见下面的【shell语法】一节或者`case``for`命令第三个单词
下列词被识别为保留的:
```bash
! case do done elif else esac fi for function if in select then until while { } time [[ ]]
```

2200
bash-3-man/z.md Normal file

File diff suppressed because it is too large Load Diff