From e966036f05b5881bb51830cc2674457eb6e34aab Mon Sep 17 00:00:00 2001 From: Hanson Char Date: Sun, 28 Jan 2024 17:01:50 -0800 Subject: [PATCH] Fix hyperlinks of markdown pages at depth 2 find docs/ -depth 2 -name '*.md' | xargs grep '(.*/' -l | \ xargs -I{} \ sed -i '' \ -e 's%(/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)\(.md\)\{0\})%(../\1/\2.md)%g' \ -e 's%(/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)#\([0-9a-zA-Z_-][0-9a-zA-Z_-]*\))%(../\1/\2.md#\3)%g' \ -e 's%(/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)\(.md\)\{0\})%(../\1/\2/\3.md)%g' \ -e 's%(/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)/\([^/#).][^/#).]*\)#\([0-9a-zA-Z_-][0-9a-zA-Z_-]*\))%(../\1/\2/\3.md#\4)%g' \ -e 's%](\([^:.>)#][^:.>)#]*\))%](../\1.md)%g' \ -e 's%](\([^:.>)#][^:.>)#]*\)#\([^:.>)#][^:.>)#]*\))%](../\1.md#\2)%g' \ {} Related to https://github.com/flokoe/bash-hackers-wiki/issues/10 --- docs/commands/classictest.md | 14 ++-- docs/dict/directory.md | 8 +-- docs/dict/end_of_options.md | 2 +- docs/dict/file.md | 18 ++--- docs/dict/globbing.md | 6 +- docs/dict/hardlink.md | 12 ++-- docs/dict/parameter.md | 12 ++-- docs/dict/posix.md | 2 +- docs/dict/special_file.md | 6 +- docs/dict/symlink.md | 6 +- docs/howto/dissectabadoneliner.md | 8 +-- docs/howto/getopts_tutorial.md | 18 ++--- docs/howto/redirection_tutorial.md | 4 +- docs/internals/shell_options.md | 22 +++--- docs/scripting/bashbehaviour.md | 18 ++--- docs/scripting/bashchanges.md | 32 ++++----- docs/scripting/basics.md | 12 ++-- docs/scripting/debuggingtips.md | 24 +++---- docs/scripting/newbie_traps.md | 28 ++++---- docs/scripting/nonportable.md | 14 ++-- docs/scripting/obsolete.md | 24 +++---- docs/scripting/posparams.md | 38 +++++------ docs/scripting/processtree.md | 6 +- docs/scripting/style.md | 14 ++-- docs/snipplets/add_color_to_your_scripts.md | 2 +- docs/snipplets/pause_command.md | 2 +- docs/snipplets/prargs.md | 2 +- docs/snipplets/print_horizontal_line.md | 6 +- docs/snipplets/rndstr.md | 8 +-- docs/snipplets/wrapperargs.md | 2 +- docs/syntax/arith_expr.md | 48 ++++++------- docs/syntax/arrays.md | 28 ++++---- docs/syntax/basicgrammar.md | 74 ++++++++++----------- docs/syntax/pattern.md | 26 ++++---- docs/syntax/pe.md | 56 ++++++++-------- docs/syntax/quoting.md | 16 ++--- docs/syntax/redirection.md | 26 ++++---- docs/syntax/shellvars.md | 60 ++++++++--------- docs/syntax/words.md | 12 ++-- 39 files changed, 358 insertions(+), 358 deletions(-) diff --git a/docs/commands/classictest.md b/docs/commands/classictest.md index abc1ed5..7c156b3 100644 --- a/docs/commands/classictest.md +++ b/docs/commands/classictest.md @@ -61,7 +61,7 @@ fi As you definitely noted, the filename contains spaces. Since we call a normal ordinary command (`test` or `[`) the shell will word-split the expansion of the variable `mymusic`: You need to quote it when you don't want the `test`-command to complain about too many arguments for this test-type! -If you didn't understand it, please read the [article about words\...](/syntax/words). +If you didn't understand it, please read the [article about words\...](../syntax/words.md). Please also note that the file-tests want **one filename** to test. Don't give a glob (filename-wildcards) as it can expand to many filenames => **too many arguments!** @@ -138,7 +138,7 @@ Since Bash 4.1, all tests related to permissions respect ACLs, if the underlying | **-o** | True, if either \ **or** is true (OR). | | **!** | True, if is **false** (NOT). | | **(** **)** | Group a test (for precedence). **Attention:** In normal shell-usage, the `(` and `)` must be escaped; use `\(` and `\)`! | -| **-o** | True, if the [shell option](/internals/shell_options) is set. | +| **-o** | True, if the [shell option](../internals/shell_options.md) is set. | | **-v** | True if the variable has been set. Use `var[n]` for array elements. | | **-R** | True if the variable has been set and is a nameref variable (since 4.3-alpha) | @@ -503,18 +503,18 @@ Some code snipplets follow, different ways of shell reaction is used. - **check if a variable is defined/non-NULL** - `test "$MYVAR"` - `[ "$MYVAR" ]` - - **Note:** There are possibilities to make a difference if a variable is *undefined* or *NULL* - see [Parameter Expansion - Using an alternate value](/syntax/pe#use_an_alternate_value) + - **Note:** There are possibilities to make a difference if a variable is *undefined* or *NULL* - see [Parameter Expansion - Using an alternate value](../syntax/pe.md#use_an_alternate_value) - **check if a directory exists, if not, create it** - `test ! -d /home/user/foo && mkdir /home/user/foo` - `[ ! -d /home/user/foo ] && mkdir /home/user/foo` - `if [ ! -d /home/user/foo ]; then mkdir /home/user/foo; fi` - **check if minimum one parameter was given, and that one is "Hello"** - `test $# -ge 1 -a "$1" = "Hello" || exit 1` - - `[ $# -ge 1 ] && [ "$1" = "Hello" ] || exit 1` (see [lists description](/syntax/basicgrammar#lists)) + - `[ $# -ge 1 ] && [ "$1" = "Hello" ] || exit 1` (see [lists description](../syntax/basicgrammar.md#lists)) ### Listing directories -Using a [for-loop](/syntax/ccmd/classic_for) to iterate through all entries of a directory, if an entry is a directory (`[ -d "$fn" ]`), print its name: +Using a [for-loop](../syntax/ccmd/classic_for.md) to iterate through all entries of a directory, if an entry is a directory (`[ -d "$fn" ]`), print its name: ```bash for fn in *; do @@ -524,8 +524,8 @@ done ## See also -- Internal: [conditional expression](/syntax/ccmd/conditional_expression) (aka "the new test command") -- Internal: [the if-clause](/syntax/ccmd/if_clause) +- Internal: [conditional expression](../syntax/ccmd/conditional_expression.md) (aka "the new test command") +- Internal: [the if-clause](../syntax/ccmd/if_clause.md) [^1]: Of course, one can wonder what is the use of including the parenthesis in the specification without defining the behaviour with diff --git a/docs/dict/directory.md b/docs/dict/directory.md index aaff034..b9ff99d 100644 --- a/docs/dict/directory.md +++ b/docs/dict/directory.md @@ -1,7 +1,7 @@ # Directory In terms of UNIX(r), a directory is a special file which contains a list -of [hardlinks](/dict/terms/hardlink) to other files. These other files +of [hardlinks](../dict/terms/hardlink.md) to other files. These other files also can be directories of course, so it\'s possible to create a \"hierarchy of directories\" - the UNIX(r)-typical filesystem structure. @@ -10,6 +10,6 @@ all other directory entries are **subdirectories** of it. ## See also -- [hardlink](/dict/terms/hardlink) -- [file](/dict/terms/file) -- [special file](/dict/terms/special_file) +- [hardlink](../dict/terms/hardlink.md) +- [file](../dict/terms/file.md) +- [special file](../dict/terms/special_file.md) diff --git a/docs/dict/end_of_options.md b/docs/dict/end_of_options.md index 146a3fd..2132b16 100644 --- a/docs/dict/end_of_options.md +++ b/docs/dict/end_of_options.md @@ -28,4 +28,4 @@ except ## See also - Scripting article, internal: - [getopts_tutorial](/howto/getopts_tutorial) + [getopts_tutorial](../howto/getopts_tutorial.md) diff --git a/docs/dict/file.md b/docs/dict/file.md index d83d86e..fe99d1a 100644 --- a/docs/dict/file.md +++ b/docs/dict/file.md @@ -1,8 +1,8 @@ # File -A file is a pool of data in the [filesystem](/dict/terms/filesystem). On +A file is a pool of data in the [filesystem](../dict/terms/filesystem.md). On userlevel, it\'s referenced using a name, a -[hardlink](/dict/terms/hardlink) to the file. +[hardlink](../dict/terms/hardlink.md) to the file. If a file is not referenced anymore (number of hardlinks to it drops to 0) then the space allocated for that file is re-used, unless it\'s still @@ -10,15 +10,15 @@ used by some process. The file-data splits into actual payload (file contents) and some metadata like filesize, filemode or timestamps. The metadata is stored -in the [inode](/dict/terms/inode). +in the [inode](../dict/terms/inode.md). -Strictly spoken, a [hardlink](/dict/terms/hardlink) (also called -\"filename\") points to the [inode](/dict/terms/inode) which organizes a +Strictly spoken, a [hardlink](../dict/terms/hardlink.md) (also called +\"filename\") points to the [inode](../dict/terms/inode.md) which organizes a file, not to the file itself. ## See also -- [filesystem](/dict/terms/filesystem) -- [filetimes](/dict/terms/filetimes) -- [hardlink](/dict/terms/hardlink) -- [inode](/dict/terms/inode) +- [filesystem](../dict/terms/filesystem.md) +- [filetimes](../dict/terms/filetimes.md) +- [hardlink](../dict/terms/hardlink.md) +- [inode](../dict/terms/inode.md) diff --git a/docs/dict/globbing.md b/docs/dict/globbing.md index 698767b..330d0b6 100644 --- a/docs/dict/globbing.md +++ b/docs/dict/globbing.md @@ -23,9 +23,9 @@ which serves the same purpose. ## See also -- [shell](/dict/terms/shell) -- [hardlink](/dict/terms/hardlink) +- [shell](../dict/terms/shell.md) +- [hardlink](../dict/terms/hardlink.md) ## See also (article) -- [pathname expansion](/syntax/expansion/globs) +- [pathname expansion](../syntax/expansion/globs.md) diff --git a/docs/dict/hardlink.md b/docs/dict/hardlink.md index d355ca9..2bbc01c 100644 --- a/docs/dict/hardlink.md +++ b/docs/dict/hardlink.md @@ -4,16 +4,16 @@ Also the article for: - filename -A hardlink associates a *filename* with a [file](/dict/terms/file). That +A hardlink associates a *filename* with a [file](../dict/terms/file.md). That name is an entry in a directory listing. Of course a file can have more hardlinks to it (usually the number of hardlinks to a file is limited), but all hardlinks to a file must reside on the same -[filesystem](/dict/terms/filesystem) as the file itself! +[filesystem](../dict/terms/filesystem.md) as the file itself! What you usually call a file is just a name for that file, and thus, a hardlink. -The difference between a [symbolic link](/dict/terms/symlink) and a hard +The difference between a [symbolic link](../dict/terms/symlink.md) and a hard link is that there is no easy way to differentiate between a \'real\' file and a hard link, let\'s take a look at the example: @@ -46,6 +46,6 @@ is freed when the last hard link pointing to it is deleted. ## See also -- [file](/dict/terms/file) -- [filesystem](/dict/terms/filesystem) -- [symlink](/dict/terms/symlink) +- [file](../dict/terms/file.md) +- [filesystem](../dict/terms/filesystem.md) +- [symlink](../dict/terms/symlink.md) diff --git a/docs/dict/parameter.md b/docs/dict/parameter.md index 9778bfc..b29a5e0 100644 --- a/docs/dict/parameter.md +++ b/docs/dict/parameter.md @@ -40,7 +40,7 @@ A positional parameter is denoted by a number other than `0` (zero). Positional parameters reflect the shell\'s arguments that are not given to the shell itself (in practise, the script arguments, also the function arguments). You can\'t directly assign to the positional -parameters, however, [the set builtin command](/commands/builtin/set) +parameters, however, [the set builtin command](../commands/builtin/set.md) can be used to indirectly set them. The first to ninth positional parameter is referenced by `$1` to `$9`. @@ -50,7 +50,7 @@ by the number given in curly braces, i.e., `${10}` or `${432}`. Unlike popular belief, `$0` is *not a positional parameter*. See also the [scripting article about handling positional -parameters](/scripting/posparams). +parameters](../scripting/posparams.md). ## special parameters @@ -58,10 +58,10 @@ There are a bunch of special parameters, which are set by the shell. Direct assignment to them is not possible. These parameter names are formed of one character. -Please see [shellvars](/syntax/shellvars). +Please see [shellvars](../syntax/shellvars.md). ## See also -- Syntax article, internal: [pe](/syntax/pe) -- Syntax article, internal: [shellvars](/syntax/shellvars) -- Scripting article, internal: [posparams](/scripting/posparams) +- Syntax article, internal: [pe](../syntax/pe.md) +- Syntax article, internal: [shellvars](../syntax/shellvars.md) +- Scripting article, internal: [posparams](../scripting/posparams.md) diff --git a/docs/dict/posix.md b/docs/dict/posix.md index 5d699a4..a7658f7 100644 --- a/docs/dict/posix.md +++ b/docs/dict/posix.md @@ -13,4 +13,4 @@ behaviour of the system shell and some utilities (commands). ## See also -- Dictionary, internal: [shell](/dict/terms/shell) +- Dictionary, internal: [shell](../dict/terms/shell.md) diff --git a/docs/dict/special_file.md b/docs/dict/special_file.md index b7d168d..5a636c5 100644 --- a/docs/dict/special_file.md +++ b/docs/dict/special_file.md @@ -14,6 +14,6 @@ too. ## See also -- [file](/dict/terms/file) -- [filename](/dict/terms/hardlink) -- [directory](/dict/terms/directory) +- [file](../dict/terms/file.md) +- [filename](../dict/terms/hardlink.md) +- [directory](../dict/terms/directory.md) diff --git a/docs/dict/symlink.md b/docs/dict/symlink.md index 6b1a7d0..625d46a 100644 --- a/docs/dict/symlink.md +++ b/docs/dict/symlink.md @@ -10,6 +10,6 @@ it can ## See also -- [hardlink](/dict/terms/hardlink) -- [filesystem](/dict/terms/filesystem) -- [directory](/dict/terms/directory) +- [hardlink](../dict/terms/hardlink.md) +- [filesystem](../dict/terms/filesystem.md) +- [directory](../dict/terms/directory.md) diff --git a/docs/howto/dissectabadoneliner.md b/docs/howto/dissectabadoneliner.md index f5cce7a..417f54b 100644 --- a/docs/howto/dissectabadoneliner.md +++ b/docs/howto/dissectabadoneliner.md @@ -32,13 +32,13 @@ In fact, there is a POSIX(r)-compliant command to do this: `basename` The implementation here is suboptimal in several ways, but the only thing that\'s genuinely error-prone with this is \"`echo $i`\". Echoing an *unquoted* variable means -[wordsplitting](/syntax/expansion/wordsplit) will take place, so any +[wordsplitting](../syntax/expansion/wordsplit.md) will take place, so any whitespace in `$i` will essentially be normalized. In `sh` it is necessary to use an external command and a subshell to achieve the goal, but we can eliminate the pipe (subshells, external commands, and pipes carry extra overhead when they launch, so they can really hurt performance in a loop). Just for good measure, let\'s use the more -readable, [modern](/syntax/expansion/cmdsubst) `$()` construct instead +readable, [modern](../syntax/expansion/cmdsubst.md) `$()` construct instead of the old style backticks: ``` bash @@ -47,7 +47,7 @@ sh $ for i in *.zip; do j=$(basename "$i" ".zip"); mkdir $j; cd $j; unzip ../$i; In Bash we don\'t need the subshell or the external basename command. See [Substring removal with parameter -expansion](/syntax/pe#substring_removal): +expansion](../syntax/pe.md#substring_removal): ``` bash bash $ for i in *.zip; do j="${i%.zip}"; mkdir $j; cd $j; unzip ../$i; cd ..; done @@ -65,7 +65,7 @@ hurt: When a following command depends on the success of a previous command(s), check for success! You can do this with the \"`&&`\" conjunction, that way, if the previous command fails, bash will not try to execute the following command(s). It\'s fully POSIX(r). Oh, and -remember what I said about [wordsplitting](/syntax/expansion/wordsplit) +remember what I said about [wordsplitting](../syntax/expansion/wordsplit.md) in the previous step? Well, if you don\'t quote `$j`, wordsplitting can happen again. diff --git a/docs/howto/getopts_tutorial.md b/docs/howto/getopts_tutorial.md index 73c5e20..8bbc721 100644 --- a/docs/howto/getopts_tutorial.md +++ b/docs/howto/getopts_tutorial.md @@ -23,7 +23,7 @@ are: Some other methods to parse positional parameters - using neither **getopt** nor **getopts** - are described in: [How to handle positional -parameters](/scripting/posparams). +parameters](../scripting/posparams.md). ### Terminology @@ -82,15 +82,15 @@ left to parse, it\'s easy to use in a while-loop: parsing on the first non-option argument (a string that doesn\'t begin with a hyphen (`-`) that isn\'t an argument for any option in front of it). It will also stop parsing when it sees the `--` (double-hyphen), -which means [end of options](/dict/terms/end_of_options). +which means [end of options](../dict/terms/end_of_options.md). ### Used variables variable description ------------------------------------ --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - [OPTIND](/syntax/shellvars#OPTIND) Holds the index to the next argument to be processed. This is how `getopts` \"remembers\" its own status between invocations. Also useful to shift the positional parameters after processing with `getopts`. `OPTIND` is initially set to 1, and **needs to be re-set to 1 if you want to parse anything again with getopts** - [OPTARG](/syntax/shellvars#OPTARG) This variable is set to any argument for an option found by `getopts`. It also contains the option flag of an unknown option. - [OPTERR](/syntax/shellvars#OPTERR) (Values 0 or 1) Indicates if Bash should display error messages generated by the `getopts` builtin. The value is initialized to **1** on every shell startup - so be sure to always set it to **0** if you don\'t want to see annoying messages! **`OPTERR` is not specified by POSIX for the `getopts` builtin utility \-\-- only for the C `getopt()` function in `unistd.h` (`opterr`).** `OPTERR` is bash-specific and not supported by shells such as ksh93, mksh, zsh, or dash. + [OPTIND](../syntax/shellvars.md#OPTIND) Holds the index to the next argument to be processed. This is how `getopts` \"remembers\" its own status between invocations. Also useful to shift the positional parameters after processing with `getopts`. `OPTIND` is initially set to 1, and **needs to be re-set to 1 if you want to parse anything again with getopts** + [OPTARG](../syntax/shellvars.md#OPTARG) This variable is set to any argument for an option found by `getopts`. It also contains the option flag of an unknown option. + [OPTERR](../syntax/shellvars.md#OPTERR) (Values 0 or 1) Indicates if Bash should display error messages generated by the `getopts` builtin. The value is initialized to **1** on every shell startup - so be sure to always set it to **0** if you don\'t want to see annoying messages! **`OPTERR` is not specified by POSIX for the `getopts` builtin utility \-\-- only for the C `getopt()` function in `unistd.h` (`opterr`).** `OPTERR` is bash-specific and not supported by shells such as ksh93, mksh, zsh, or dash. `getopts` also uses these variables for error reporting (they\'re set to value-combinations which arent possible in normal operation). @@ -133,7 +133,7 @@ messages. #### Custom arguments to parse The `getopts` utility parses the [positional -parameters](/scripting/posparams) of the current shell or function by +parameters](../scripting/posparams.md) of the current shell or function by default (which means it parses `"$@"`). You can give your own set of arguments to the utility to parse. Whenever @@ -346,9 +346,9 @@ Let\'s provide **the argument**: ## See also -- Internal: [posparams](/scripting/posparams) -- Internal: [case](/syntax/ccmd/case) -- Internal: [while_loop](/syntax/ccmd/while_loop) +- Internal: [posparams](../scripting/posparams.md) +- Internal: [case](../syntax/ccmd/case.md) +- Internal: [while_loop](../syntax/ccmd/while_loop.md) - POSIX [getopts(1)](http://pubs.opengroup.org/onlinepubs/9699919799/utilities/getopts.html#tag_20_54) and diff --git a/docs/howto/redirection_tutorial.md b/docs/howto/redirection_tutorial.md index da3fae2..a509b8a 100644 --- a/docs/howto/redirection_tutorial.md +++ b/docs/howto/redirection_tutorial.md @@ -653,7 +653,7 @@ recommendations: ``` - **Never** use the Csh `&>foo` and `>&foo` shorthand redirects. Use - the long form `>foo 2>&1`. (see: [obsolete](obsolete)) + the long form `>foo 2>&1`. (see: [obsolete](../obsolete.md)) ```{=html} @@ -694,4 +694,4 @@ The last example comes from this post: # See also -- Internal: [Redirection syntax overview](/syntax/redirection) +- Internal: [Redirection syntax overview](../syntax/redirection.md) diff --git a/docs/internals/shell_options.md b/docs/internals/shell_options.md index 9fddca5..bf15ae0 100644 --- a/docs/internals/shell_options.md +++ b/docs/internals/shell_options.md @@ -6,7 +6,7 @@ This information was taken from a Bash version \"`4.1`\", every now and then new options are added, so likely, this list isn\'t complete. The shell-options can be set with the [shopt builtin -command](/commands/builtin/shopt). +command](../commands/builtin/shopt.md). ## Shell options @@ -78,8 +78,8 @@ stopped. If set, Bash checks the window size after each command and, if necessary, updates the values of the variables -[LINES](/syntax/shellvars#LINES) and -[COLUMNS](/syntax/shellvars#COLUMNS). +[LINES](../syntax/shellvars.md#LINES) and +[COLUMNS](../syntax/shellvars.md#COLUMNS). ### cmdhist @@ -174,7 +174,7 @@ match a glob. Shell mode: all Default: off If set, Bash includes filenames beginning with a `.` (dot) in the -results of [pathname expansion](/syntax/expansion/globs). +results of [pathname expansion](../syntax/expansion/globs.md). ### execfail @@ -209,7 +209,7 @@ If set, behavior intended for use by debuggers is enabled. ------------- ----------- ---------- ------------- Shell mode: all Default: off -If set, the extended [pattern matching](/syntax/pattern) features are +If set, the extended [pattern matching](../syntax/pattern.md) features are enabled. See the important note below under [Parser configurations](#parser_configurations). @@ -220,7 +220,7 @@ configurations](#parser_configurations). Shell mode: all Default: on If set, `$'string'` and `$"string"` quoting is performed within -[parameter expansions](/syntax/pe) enclosed in double quotes. See the +[parameter expansions](../syntax/pe.md) enclosed in double quotes. See the important note below under [Parser configurations](#parser_configurations). @@ -240,7 +240,7 @@ result in an error message. Shell mode: interactive Default: on If set, the suffixes specified by the -[FIGNORE](/syntax/shellvars#FIGNORE) shell variable cause words to be +[FIGNORE](../syntax/shellvars.md#FIGNORE) shell variable cause words to be ignored when performing word completion even if the ignored words are the only possible completions. This option is enabled by default. @@ -280,7 +280,7 @@ message format\". Shell mode: interactive (?) Default: off If set, the history list is appended to the file named by the value of -the [HISTFILE](/syntax/shellvars#HISTFILE) variable when the shell +the [HISTFILE](../syntax/shellvars.md#HISTFILE) variable when the shell exits, rather than overwriting the file. ### histreedit @@ -324,7 +324,7 @@ interactive login shell exits. ------------- ------------------------ ---------- --------- Shell mode: interactive Default: on -Allow [commenting](/scripting/basics#comments) in interactive shells, on +Allow [commenting](../scripting/basics.md#comments) in interactive shells, on by default. ### lastpipe @@ -505,5 +505,5 @@ parsed: ## See also -- Internal: [shopt builtin command](/commands/builtin/shopt) -- Internal: [set builtin command](/commands/builtin/set) +- Internal: [shopt builtin command](../commands/builtin/shopt.md) +- Internal: [set builtin command](../commands/builtin/set.md) diff --git a/docs/scripting/bashbehaviour.md b/docs/scripting/bashbehaviour.md index 10e9254..1e9d1ad 100644 --- a/docs/scripting/bashbehaviour.md +++ b/docs/scripting/bashbehaviour.md @@ -67,7 +67,7 @@ conforming to the POSIX(r) standard as well. The profile files read are `/etc/profile` and `~/.profile`, if it\'s a login shell. If it\'s not a login shell, the environment variable -[ENV](/syntax/shellvars#ENV) is evaluated and the resulting filename is +[ENV](../syntax/shellvars.md#ENV) is evaluated and the resulting filename is used as the name of the startup file. After the startup files are read, Bash enters the [POSIX(r) compatiblity @@ -83,7 +83,7 @@ mode (for running, not for starting!)](#posix_run_mode). When Bash is started in POSIX(r) mode, it follows the POSIX(r) standard for startup files. In this mode, **interactive shells** expand the -[ENV](/syntax/shellvars#ENV) variable and commands are read and executed +[ENV](../syntax/shellvars.md#ENV) variable and commands are read and executed from the file whose name is the expanded value.\ No other startup files are read. Hence, a non-interactive shell doesn\'t read any startup files in POSIX(r) mode. @@ -92,7 +92,7 @@ read any startup files in POSIX(r) mode. - the commandline option `--posix` is specified - the environment variable - [POSIXLY_CORRECT](/syntax/shellvars#POSIXLY_CORRECT) is set + [POSIXLY_CORRECT](../syntax/shellvars.md#POSIXLY_CORRECT) is set ### Quick startup file reference @@ -301,12 +301,12 @@ FIXME help me to find out what breaks in POSIX(r) mode! - Bash starting as `sh` (the basename of `argv[0]` is `sh`) - starting Bash with the commandline option `--posix` - on startup, the environment variable - [POSIXLY_CORRECT](/syntax/shellvars#POSIXLY_CORRECT) is set + [POSIXLY_CORRECT](../syntax/shellvars.md#POSIXLY_CORRECT) is set - the command `set -o posix` [**Tests for the POSIX(r) mode:**]{.underline} -- the variable [SHELLOPTS](/syntax/shellvars#SHELLOPTS) contains +- the variable [SHELLOPTS](../syntax/shellvars.md#SHELLOPTS) contains `posix` in its list ### Restricted shell @@ -316,9 +316,9 @@ far more controlled and limited than the standard shell mode. It acts like normal Bash with the following restrictions: - the `cd` command can\'t be used to change directories -- the variables [SHELL](/syntax/shellvars#SHELL), - [PATH](/syntax/shellvars#PATH), [ENV](/syntax/shellvars#ENV) and - [BASH_ENV](/syntax/shellvars#BASH_ENV) can\'t be set or unset +- the variables [SHELL](../syntax/shellvars.md#SHELL), + [PATH](../syntax/shellvars.md#PATH), [ENV](../syntax/shellvars.md#ENV) and + [BASH_ENV](../syntax/shellvars.md#BASH_ENV) can\'t be set or unset - command names that contain a `/` (slash) can\'t be called (hence you\'re limited to `PATH`) - filenames containing a `/` (slash) can\'t be specified as argument @@ -327,7 +327,7 @@ like normal Bash with the following restrictions: to the `-p` option of the `hash` builtin command - function definitions are not inherited from the environment at shell startup -- the environment variable [SHELLOPTS](/syntax/shellvars#SHELLOPTS) is +- the environment variable [SHELLOPTS](../syntax/shellvars.md#SHELLOPTS) is ignored at startup - redirecting output using the `>`, `>|`, `<>`, `>&`, `&>`, and `>>` redirection operators isn\'t allowed diff --git a/docs/scripting/bashchanges.md b/docs/scripting/bashchanges.md index 771507b..a9f18d6 100644 --- a/docs/scripting/bashchanges.md +++ b/docs/scripting/bashchanges.md @@ -19,8 +19,8 @@ Note that the `shopt` builtin command first appeared in Bash 2.0. For this topic, see also -- [shell_options](/internals/shell_options) -- [set](/commands/builtin/set) +- [shell_options](../internals/shell_options.md) +- [set](../commands/builtin/set.md) Feature or change description Appeared in Bash version See also/remarks --------------------------------- -------------------------- --------------------------------------------------------------------------------- @@ -77,7 +77,7 @@ For this topic, see also For this topic, see also -- [printf](/commands/builtin/printf) +- [printf](../commands/builtin/printf.md) Feature or change description Appeared in Bash version See also/remarks ------------------------------------------------------------- -------------------------- -------------------------------------------------------- @@ -98,8 +98,8 @@ For this topic, see also For this topic, see also -- [conditional_expression](/syntax/ccmd/conditional_expression) -- [classictest](/commands/classictest) +- [conditional_expression](../syntax/ccmd/conditional_expression.md) +- [classictest](../commands/classictest.md) Feature or change description Appeared in Bash version See also/remarks -------------------------------------------------------------------- -------------------------- -------------------------------------------------------------------------------------- @@ -121,23 +121,23 @@ For this topic, see also `bashbug` new 1.14.0 `select` new 1.14.0 `disown` new 2.0 - `shopt` new 2.0 [shopt](/commands/builtin/shopt) + `shopt` new 2.0 [shopt](../commands/builtin/shopt.md) `declare` new options `-a` and `-F` 2.0 `enable` builtin has basic plugin support (dlopen) 2.0 `exec` options `-l`, `-c` and `-a` 2.0 - `read` options `-p`, `-e` and `-a` 2.0 [read](/commands/builtin/read) - `readonly` option `-a` 2.0 [arrays](/syntax/arrays) + `read` options `-p`, `-e` and `-a` 2.0 [read](../commands/builtin/read.md) + `readonly` option `-a` 2.0 [arrays](../syntax/arrays.md) `time` new keyword 2.0 `shopt` `-p` (reusable output) 2.02 `umask` `-p` (reusable output) 2.02 `complete` new 2.04-devel for and together with support for programmable completion `compgen` new 2.04-devel for and together with support for programmable completion - `read` options `-t`, `-n`, `-d`, `-s` 2.04-devel [read](/commands/builtin/read) + `read` options `-t`, `-n`, `-d`, `-s` 2.04-devel [read](../commands/builtin/read.md) `for ((...;...;...))` new 2.04-devel KSH93 `set` print shell functions in a format reusable as input 2.05-beta1 `for` allow an empty word list 2.05a-alpha1 - `read` new option `-u` 2.05b-alpha1 [read](/commands/builtin/read) - `caller` new 3.0 [caller](/commands/builtin/caller) + `read` new option `-u` 2.05b-alpha1 [read](../commands/builtin/read.md) + `caller` new 3.0 [caller](../commands/builtin/caller.md) `coproc` new 4.0-alpha `declare` new options `-l` and `-u` 4.0-alpha together with case-changing expansion forms `case` new action list terminators \'\';;& and \'\';& 4.0-alpha ksh93: only `;&`. zsh and mksh: `;|`. mksh: all 4, (`;;&` is undocumented Bash compatibility) @@ -170,7 +170,7 @@ For this topic, see also `history` option `-d` allows negative numbers to index from the end of the history list 5.0-alpha `umask` allows modes greater than octal 777 5.0-alpha `times` honors current locale settings when printing decimal points 5.0-alpha - `kill` New options `-n SIGNUMBER` and `-s SIGNAME` 5.0-beta2 [kill](/commands/builtin/kill) + `kill` New options `-n SIGNUMBER` and `-s SIGNAME` 5.0-beta2 [kill](../commands/builtin/kill.md) `select` Support for an empty wordlist following `in` 5.0-beta2 `read` Option `-e` (use ReadLine to obtain input) now works with arbitrary file descriptors (given by `-u` option) 5.1-alpha `trap` `-p` option prints signals with SIG_DFL/SIG_IGN on shell start (POSIX mode) 5.1-alpha @@ -241,7 +241,7 @@ For this topic, see also For this topic, see also -- [pe](/syntax/pe). +- [pe](../syntax/pe.md). Feature or change description Appeared in Bash version Remarks ------------------------------------------------------------------------------------------------------ -------------------------- --------------------------------------------------------------------------------------------------------------- @@ -282,8 +282,8 @@ For this topic, see also For this topic, see also -- [arith_expr](/syntax/arith_expr) -- [arith](/syntax/expansion/arith) +- [arith_expr](../syntax/arith_expr.md) +- [arith](../syntax/expansion/arith.md) Feature or change description Appeared in Bash version Remarks -------------------------------------------- -------------------------- ------------------------------------------- @@ -299,7 +299,7 @@ For this topic, see also For this topic, see also -- [redirection](/syntax/redirection) +- [redirection](../syntax/redirection.md) Feature or change description Appeared in Bash version Remarks --------------------------------------------------------------------------------------- -------------------------- --------- diff --git a/docs/scripting/basics.md b/docs/scripting/basics.md index 3fc3571..dfecd92 100644 --- a/docs/scripting/basics.md +++ b/docs/scripting/basics.md @@ -71,7 +71,7 @@ interpreter specified by the shebang. \ **Additional note:** When you specify `#!/bin/sh` as shebang and that\'s a link to a Bash, then Bash will run in POSIX(r) mode! See: -- [Bash behaviour](/scripting/bashbehaviour). +- [Bash behaviour](../scripting/bashbehaviour.md). A common method is to specify a shebang like @@ -113,7 +113,7 @@ When you write a script: To learn more about the standard filedescriptors, especially about redirection and piping, see: -- [An illustrated redirection tutorial](/howto/redirection_tutorial) +- [An illustrated redirection tutorial](../howto/redirection_tutorial.md) ## Variable names @@ -184,7 +184,7 @@ else fi ``` -Read more about [the test command](/commands/classictest) +Read more about [the test command](../commands/classictest.md) A common exit code check method uses the \"`||`\" or \"`&&`\" operators. This lets you execute a command based on whether or not the previous @@ -247,7 +247,7 @@ it, effectively, the entire block was ignored. The here-document-tag was quoted here **to avoid substitutions** in the \"commented\" text! Check [redirection with -here-documents](/syntax/redirection#tag_heredoc) for more +here-documents](../syntax/redirection.md#tag_heredoc) for more ## Variable scope @@ -279,7 +279,7 @@ program\". for example a *subshell*, they will be set there, but you will **never** have access to them outside of that subshell. One way to create a subshell is the pipe. It\'s all mentioned in a small article about [Bash -in the processtree](/scripting/processtree)! +in the processtree](../scripting/processtree.md)! ### Local variables @@ -352,6 +352,6 @@ export myvariable Remember that the *exported* variable is a **copy**. There is no provision to \"copy it back to the parent.\" See the article about [Bash -in the process tree](/scripting/processtree)! +in the process tree](../scripting/processtree.md)! [^1]: under specific circumstances, also by the shell itself diff --git a/docs/scripting/debuggingtips.md b/docs/scripting/debuggingtips.md index d172cfd..769040b 100644 --- a/docs/scripting/debuggingtips.md +++ b/docs/scripting/debuggingtips.md @@ -55,13 +55,13 @@ Insert **echos** everywhere you can, and print to `stderr`: echo "DEBUG: current i=$i" >&2 If you read input from **anywhere**, such as a file or [command -substitution](/syntax/expansion/cmdsubst), print the debug output with +substitution](../syntax/expansion/cmdsubst.md), print the debug output with literal quotes, to see leading and trailing spaces! pid=$(< fooservice.pid) echo "DEBUG: read from file: pid=\"$pid\"" >&2 -Bash\'s [printf](/commands/builtin/printf) command has the `%q` format, +Bash\'s [printf](../commands/builtin/printf.md) command has the `%q` format, which is handy for verifying whether strings are what they appear to be. foo=$(< inputfile) @@ -77,18 +77,18 @@ There are two useful debug outputs for that task (both are written to - print commands to be executed to `stderr` as if they were read from input (script file or keyboard) - print everything **before** any ([substitution and - expansion](/syntax/expansion/intro), \...) is applied + expansion](../syntax/expansion/intro.md), \...) is applied - `set -x` mode (`set -o xtrace`) - print everything as if it were executed, after [substitution and - expansion](/syntax/expansion/intro) is applied + expansion](../syntax/expansion/intro.md) is applied - indicate the depth-level of the subshell (by default by prefixing a `+` (plus) sign to the displayed command) - indicate the recognized words after [word - splitting](/syntax/expansion/wordsplit) by marking them like + splitting](../syntax/expansion/wordsplit.md) by marking them like `'x y'` - in shell version 4.1, this debug output can be printed to a configurable file descriptor, rather than sdtout by setting the - [BASH_XTRACEFD](/syntax/shellvars#BASH_XTRACEFD) variable. + [BASH_XTRACEFD](../syntax/shellvars.md#BASH_XTRACEFD) variable. **[Hint:]{.underline}** These modes can be entered when calling Bash: @@ -98,7 +98,7 @@ There are two useful debug outputs for that task (both are written to ### Simple example of how to interpret xtrace output Here\'s a simple command (a string comparison using the [classic test -command](/commands/classictest)) executed while in `set -x` mode: +command](../commands/classictest.md)) executed while in `set -x` mode: set -x foo="bar baz" @@ -126,7 +126,7 @@ MESSAGES ;) ). Let\'s check it\... (by AnMaster) `xtrace` output would be more useful if it contained source file and -line number. Add this assignment [PS4](/syntax/shellvars#PS4) at the +line number. Add this assignment [PS4](../syntax/shellvars.md#PS4) at the beginning of your script to enable the inclusion of that information: export PS4='+(${BASH_SOURCE}:${LINENO}): ${FUNCNAME[0]:+${FUNCNAME[0]}(): }' @@ -220,7 +220,7 @@ This can be wrapped in a shell function for more readable code. Usually indicates exactly what it says: An unexpected end of file. It\'s unexpected because Bash waits for the closing of a [compound -command](/syntax/ccmd/intro): +command](../syntax/ccmd/intro.md): - did you close your `do` with a `done`? - did you close your `if` with a `fi`? @@ -231,7 +231,7 @@ command](/syntax/ccmd/intro): **[Note:]{.underline}** It seems that here-documents (tested on versions `1.14.7`, `2.05b`, `3.1.17` and `4.0`) are correctly terminated when there is an EOF before the end-of-here-document tag (see -[redirection](/syntax/redirection)). The reason is unknown, but it seems +[redirection](../syntax/redirection.md)). The reason is unknown, but it seems to be deliberate. Bash 4.0 added an extra message for this: `` warning: here-document at line delimited by end-of-file (wanted `') `` @@ -247,7 +247,7 @@ These *unmatched errors* occur with: - double-quote pairs - single-quote pairs (also `$'string'`!) -- missing a closing `}` with [parameter expansion syntax](/syntax/pe) +- missing a closing `}` with [parameter expansion syntax](../syntax/pe.md) ### Too many arguments @@ -366,7 +366,7 @@ the possibility that`^M` is involved. Find and eliminate it! \ ## See also -- [the set builtin command](/commands/builtin/set) (for `-v` and `-x`) +- [the set builtin command](../commands/builtin/set.md) (for `-v` and `-x`) FIXME diff --git a/docs/scripting/newbie_traps.md b/docs/scripting/newbie_traps.md index e494181..ae6a886 100644 --- a/docs/scripting/newbie_traps.md +++ b/docs/scripting/newbie_traps.md @@ -25,8 +25,8 @@ mode]{.underline}. See also: -- [Bash startup mode: SH mode](/scripting/bashbehaviour#sh_mode) -- [Bash run mode: POSIX mode](/scripting/bashbehaviour#posix_run_mode) +- [Bash startup mode: SH mode](../scripting/bashbehaviour.md#sh_mode) +- [Bash run mode: POSIX mode](../scripting/bashbehaviour.md#posix_run_mode) ### Your script named \"test\" doesn\'t execute @@ -63,7 +63,7 @@ filename expansion happens **after** that, so there is a chance that Please see: -- [brace](/syntax/expansion/brace) +- [brace](../syntax/expansion/brace.md) ## Test-command @@ -74,7 +74,7 @@ Please see: Please see: - [The classic test command - - pitfalls](/commands/classictest#pitfalls_summarized) + pitfalls](../commands/classictest.md#pitfalls_summarized) ## Variables @@ -163,7 +163,7 @@ of the referenced variables/parameters. i.e. **not** (`$PATH`): echo "The first character of PATH is ${PATH:0:1}" Note that if you are using variables in [arithmetic -expressions](/syntax/arith_expr), then the bare **name** is allowed: +expressions](../syntax/arith_expr.md), then the bare **name** is allowed: ((a=$a+7)) # Add 7 to a ((a = a + 7)) # Add 7 to a. Identical to the previous command. @@ -173,10 +173,10 @@ expressions](/syntax/arith_expr), then the bare **name** is allowed: Please see: -- [words](/syntax/words) -- [quoting](/syntax/quoting) -- [wordsplit](/syntax/expansion/wordsplit) -- [pe](/syntax/pe) +- [words](../syntax/words.md) +- [quoting](../syntax/quoting.md) +- [wordsplit](../syntax/expansion/wordsplit.md) +- [pe](../syntax/pe.md) ### Exporting @@ -206,7 +206,7 @@ In this case, the export command is of no use. Please see: -- [processtree](/scripting/processtree) +- [processtree](../scripting/processtree.md) ## Exit codes @@ -243,7 +243,7 @@ you need only a \"true/false\" exit indication, there\'s no need for See also: -- [Exit codes](/scripting/basics#exit_codes) +- [Exit codes](../scripting/basics.md#exit_codes) ### Output vs. Return Value @@ -277,6 +277,6 @@ Make sure you\'re using the form you intended: Please see: -- [intro](/syntax/ccmd/intro) -- [cmdsubst](/syntax/expansion/cmdsubst) -- [grouping_subshell](/syntax/ccmd/grouping_subshell) +- [intro](../syntax/ccmd/intro.md) +- [cmdsubst](../syntax/expansion/cmdsubst.md) +- [grouping_subshell](../syntax/ccmd/grouping_subshell.md) diff --git a/docs/scripting/nonportable.md b/docs/scripting/nonportable.md index 3d99885..95950cd 100644 --- a/docs/scripting/nonportable.md +++ b/docs/scripting/nonportable.md @@ -8,7 +8,7 @@ syntax, with some extensions and derivations. If scripts need to be portable, some of the BASH-specific syntax elements should be avoided. Others should be avoided for all scripts, e.g. if there is a corresponding POSIX(r)-compatible syntax (see -[obsolete](/scripting/obsolete)). +[obsolete](../scripting/obsolete.md)). Some syntax elements have a BASH-specific, and a portable[^1]) pendant. In these cases the portable syntax should be preferred. @@ -26,7 +26,7 @@ In these cases the portable syntax should be preferred. `(( MATH ))` `: $(( MATH ))` POSIX(r) does\'t define an arithmetic compund command, many shells don\'t know it. Using the pseudo-command `:` and the arithmetic expansion `$(( ))` is a kind of workaround here. **Attention:** Not all shell support assignment like `$(( a = 1 + 1 ))`! Also see below for a probably more portable solution. all POSIX(r) compatible shells - `[[\ EXPRESSION\ ]]` `[ EXPRESSION ]`\ The Bashish test keyword is reserved by POSIX(r), but not defined. Use the old fashioned way with the `test` command. See [the classic test command](/commands/classictest) POSIX(r) and others + `[[\ EXPRESSION\ ]]` `[ EXPRESSION ]`\ The Bashish test keyword is reserved by POSIX(r), but not defined. Use the old fashioned way with the `test` command. See [the classic test command](../commands/classictest.md) POSIX(r) and others or\ `test EXPRESSION` @@ -98,7 +98,7 @@ Why? (list of known behaviours) variables or the build options, especially KSH93 and Bash) For these, and possibly other, reasons, POSIX (SUS) standardized the -existance of [the `printf` command](/commands/builtin/printf). +existance of [the `printf` command](../commands/builtin/printf.md). ### Parameter expansions @@ -112,7 +112,7 @@ existance of [the `printf` command](/commands/builtin/printf). #### PWD -[PWD](/syntax/shellvars#PWD) is POSIX but not Bourne. Most shells are +[PWD](../syntax/shellvars.md#PWD) is POSIX but not Bourne. Most shells are *not POSIX* in that they don\'t ignore the value of the `PWD` environment variable. Workaround to fix the value of `PWD` at the start of your script: @@ -121,7 +121,7 @@ of your script: #### RANDOM -[RANDOM](/syntax/shellvars#RANDOM) is Bash/KSH/ZSH specific variable +[RANDOM](../syntax/shellvars.md#RANDOM) is Bash/KSH/ZSH specific variable that will give you a random number up to 32767 (2\^15-1). Among many other available external options, you can use awk to generate a random number. There are multiple implementations of awk and which version your @@ -147,12 +147,12 @@ complaining about possible stupid code!* #### SECONDS -[SECONDS](/syntax/shellvars#SECONDS) is KSH/ZSH/Bash specific. Avoid it. +[SECONDS](../syntax/shellvars.md#SECONDS) is KSH/ZSH/Bash specific. Avoid it. Find another method. ### Check for a command in PATH -The [PATH](/syntax/shellvars#PATH) variable is a colon-delimited list of +The [PATH](../syntax/shellvars.md#PATH) variable is a colon-delimited list of directory names, so it\'s basically possible to run a loop and check every `PATH` component for the command you\'re looking for and for executability. diff --git a/docs/scripting/obsolete.md b/docs/scripting/obsolete.md index 344f317..d770a16 100644 --- a/docs/scripting/obsolete.md +++ b/docs/scripting/obsolete.md @@ -5,7 +5,7 @@ This (incomplete) page describes some syntax and commands considered obsolete by some measure. A thorough discussion of the rationale is beyond the scope of this page. See the [portability -page](/scripting/nonportable) for a discussion on portability issues. +page](../scripting/nonportable.md) for a discussion on portability issues. This first table lists syntax that is tolerated by Bash but has few if any legitimate uses. These features exist mostly for Bourne, csh, or @@ -18,9 +18,9 @@ of POSIX, and some may be incompatible with POSIX. Syntax Replacement Description ---------------------------------- --------------------------------------------------------- -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - `&>FILE` and `>&FILE` `>FILE 2>&1` This redirection syntax is short for `>FILE 2>&1` and originates in the C Shell. The latter form is especially uncommon and should never be used, and the explicit form using separate redirections is preferred over both. These shortcuts contribute to confusion about the copy descriptor because the syntax is unclear. They also introduce parsing ambiguity, and conflict with POSIX. Shells without this feature treat `cmd1 &>file cmd2` as: \"background `cmd1` and then execute `cmd2` with its stdout redirected to `file`\", which is the correct interpretation of this expression. See: [redirection](/syntax/redirection) \`\$ { bash; dash \/dev/null&\>/dev/fd/2 echo bar\' foo echo bar bar\` - `$[EXPRESSION]` `$((EXPRESSION))` This undocumented syntax is completely replaced by the POSIX-conforming arithmetic expansion `$((EXPRESSION))`. It is unimplemented almost everywhere except Bash and Zsh. See [arithmetic expansion](/syntax/expansion/arith). [Some discussion](http://lists.gnu.org/archive/html/bug-bash/2012-04/msg00034.html). - `COMMAND\ |&\ COMMAND` `COMMAND 2>&1 | COMMAND` This is an alternate pipeline operator derived from Zsh. Officially, it is not considered deprecated by Bash, but I highly discourage it. It conflicts with the list operator used for [coprocess](/syntax/keywords/coproc) creation in most Korn shells. It also has confusing behavior. The stdout is redirected first like an ordinary pipe, while the stderr is actually redirected last \-- after other redirects preceding the pipe operator. Overall, it\'s pointless syntax bloat. Use an explicit redirect instead. + `&>FILE` and `>&FILE` `>FILE 2>&1` This redirection syntax is short for `>FILE 2>&1` and originates in the C Shell. The latter form is especially uncommon and should never be used, and the explicit form using separate redirections is preferred over both. These shortcuts contribute to confusion about the copy descriptor because the syntax is unclear. They also introduce parsing ambiguity, and conflict with POSIX. Shells without this feature treat `cmd1 &>file cmd2` as: \"background `cmd1` and then execute `cmd2` with its stdout redirected to `file`\", which is the correct interpretation of this expression. See: [redirection](../syntax/redirection.md) \`\$ { bash; dash \/dev/null&\>/dev/fd/2 echo bar\' foo echo bar bar\` + `$[EXPRESSION]` `$((EXPRESSION))` This undocumented syntax is completely replaced by the POSIX-conforming arithmetic expansion `$((EXPRESSION))`. It is unimplemented almost everywhere except Bash and Zsh. See [arithmetic expansion](../syntax/expansion/arith.md). [Some discussion](http://lists.gnu.org/archive/html/bug-bash/2012-04/msg00034.html). + `COMMAND\ |&\ COMMAND` `COMMAND 2>&1 | COMMAND` This is an alternate pipeline operator derived from Zsh. Officially, it is not considered deprecated by Bash, but I highly discourage it. It conflicts with the list operator used for [coprocess](../syntax/keywords/coproc.md) creation in most Korn shells. It also has confusing behavior. The stdout is redirected first like an ordinary pipe, while the stderr is actually redirected last \-- after other redirects preceding the pipe operator. Overall, it\'s pointless syntax bloat. Use an explicit redirect instead. `function\ NAME()\ COMPOUND-CMD` `NAME()\ COMPOUND-CMD` or `function\ NAME\ {\ CMDS;\ }` This is an amalgamation between the Korn and POSIX style function definitions - using both the `function` keyword and parentheses. It has no useful purpose and no historical basis or reason to exist. It is not specified by POSIX. It is accepted by Bash, mksh, zsh, and perhaps some other Korn shells, where it is treated as identical to the POSIX-style function. It is not accepted by AT&T ksh. It should never be used. See the next table for the `function` keyword. Bash doesn\'t have this feature documented as expressly deprecated. `for x; { ...;}` `do`, `done`, `in`, `esac`, etc. This undocumented syntax replaces the `do` and `done` reserved words with braces. Many Korn shells support various permutations on this syntax for certain compound commands like `for`, `case`, and `while`. Which ones and certain details like whether a newline or semicolon are required vary. Only `for` works in Bash. Needless to say, don\'t use it. @@ -34,11 +34,11 @@ historical reasons. ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- Syntax Replacement Description ----------------------------------------------------------------------------------------------------- ----------------------------------------------------------------------------------------------------------------------------------------------------- ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - Unquoted expansions, [wordsplit](/syntax/expansion/wordsplit), and [globs](/syntax/expansion/globs) [Proper quoting](http://mywiki.wooledge.org/Quotes), Ksh/Bash-style [arrays](/syntax/arrays), The \"\$@\" expansion, [read](/commands/builtin/read) *Quoting errors* are a broad category of common mistakes brought about by a few unintuitive features carried over from the Bourne shell due to complaints of broken scripts and changes in previously documented behavior. Most of the important expansions are performed at the same time from left to right. However, a few expansions, most notably word-splitting and globbing, and in shells other than Bash, [brace expansion](/syntax/expansion/brace), are performed **on the results of previous expansions, by default, unless they are quoted.** This means that the act of expanding an unquoted variable in an ordinary argument context, depending on the value of the variable, can yield different results depending on possibly uncontrolled side-effects like the value of `IFS`, and the names of files in the current working directory. You can\'t get globbing without word-splitting, or vice versa (without `set -f`). [You can\'t store a command or character-delimited list in a variable and safely evaluate it with unquoted expansion](http://mywiki.wooledge.org/BashFAQ/050). If possible, always choose a shell that supports Korn shell arrays such as Bash. They are a vital but non-standard feature for writing clean, safe scripts. Well-written scripts don\'t use word-splitting. A few exceptions are listed on the [word splitting page](/syntax/expansion/wordsplit). A significant proportion of the issues on the famous [Pitfalls list](http://mywiki.wooledge.org/BashPitfalls) fall under this category. See also: *[Don\'t read lines with for!](http://mywiki.wooledge.org/DontReadLinesWithFor)* + Unquoted expansions, [wordsplit](../syntax/expansion/wordsplit.md), and [globs](../syntax/expansion/globs.md) [Proper quoting](http://mywiki.wooledge.org/Quotes), Ksh/Bash-style [arrays](../syntax/arrays.md), The \"\$@\" expansion, [read](../commands/builtin/read.md) *Quoting errors* are a broad category of common mistakes brought about by a few unintuitive features carried over from the Bourne shell due to complaints of broken scripts and changes in previously documented behavior. Most of the important expansions are performed at the same time from left to right. However, a few expansions, most notably word-splitting and globbing, and in shells other than Bash, [brace expansion](../syntax/expansion/brace.md), are performed **on the results of previous expansions, by default, unless they are quoted.** This means that the act of expanding an unquoted variable in an ordinary argument context, depending on the value of the variable, can yield different results depending on possibly uncontrolled side-effects like the value of `IFS`, and the names of files in the current working directory. You can\'t get globbing without word-splitting, or vice versa (without `set -f`). [You can\'t store a command or character-delimited list in a variable and safely evaluate it with unquoted expansion](http://mywiki.wooledge.org/BashFAQ/050). If possible, always choose a shell that supports Korn shell arrays such as Bash. They are a vital but non-standard feature for writing clean, safe scripts. Well-written scripts don\'t use word-splitting. A few exceptions are listed on the [word splitting page](../syntax/expansion/wordsplit.md). A significant proportion of the issues on the famous [Pitfalls list](http://mywiki.wooledge.org/BashPitfalls) fall under this category. See also: *[Don\'t read lines with for!](http://mywiki.wooledge.org/DontReadLinesWithFor)* - `` `COMMANDS` `` `$(COMMANDS)` This is the older Bourne-compatible form of the [command substitution](/syntax/expansion/cmdsubst). Both the `` `COMMANDS` `` and `$(COMMANDS)` syntaxes are specified by POSIX, but the latter is [greatly]{.underline} preferred, though the former is unfortunately still very prevalent in scripts. New-style command substitutions are widely implemented by every modern shell (and then some). The only reason for using backticks is for compatibility with a real Bourne shell (like Heirloom). Backtick command substitutions require special escaping when nested, and examples found in the wild are improperly quoted more often than not. See: *[Why is \$(\...) preferred over \`\...\` (backticks)?](http://mywiki.wooledge.org/BashFAQ/082)*. + `` `COMMANDS` `` `$(COMMANDS)` This is the older Bourne-compatible form of the [command substitution](../syntax/expansion/cmdsubst.md). Both the `` `COMMANDS` `` and `$(COMMANDS)` syntaxes are specified by POSIX, but the latter is [greatly]{.underline} preferred, though the former is unfortunately still very prevalent in scripts. New-style command substitutions are widely implemented by every modern shell (and then some). The only reason for using backticks is for compatibility with a real Bourne shell (like Heirloom). Backtick command substitutions require special escaping when nested, and examples found in the wild are improperly quoted more often than not. See: *[Why is \$(\...) preferred over \`\...\` (backticks)?](http://mywiki.wooledge.org/BashFAQ/082)*. - `[\ EXPRESSION\ ]`\\ and\\ `test\ EXPRESSION` `[[\ EXPRESSION\ ]]` `test` and `[` are the Bourne/POSIX commands for evaluating test expressions (they are almost identical, and `[` is somewhat more common). The expressions consist of regular arguments, unlike the Ksh/Bash `[[` command. While the issue is analogous to `let` vs `((`, the advantages of `[[` vs `[` are even more important because the arguments/expansions aren\'t just concatenated into one expression. With the classic `[` command, the number of arguments is significant. If at all possible, use the [conditional expression](/syntax/ccmd/conditional_expression) (\"new test command\") `[[ EXPRESSION ]]`. Unless there is a need for POSIX compatibility, there are only a few reasons to use `[`. `[[` is one of the most portable and consistent non-POSIX ksh extensions available. See: [conditional_expression](/syntax/ccmd/conditional_expression) and *[What is the difference between test, \[ and \[\[ ?](http://mywiki.wooledge.org/BashFAQ/031)* + `[\ EXPRESSION\ ]`\\ and\\ `test\ EXPRESSION` `[[\ EXPRESSION\ ]]` `test` and `[` are the Bourne/POSIX commands for evaluating test expressions (they are almost identical, and `[` is somewhat more common). The expressions consist of regular arguments, unlike the Ksh/Bash `[[` command. While the issue is analogous to `let` vs `((`, the advantages of `[[` vs `[` are even more important because the arguments/expansions aren\'t just concatenated into one expression. With the classic `[` command, the number of arguments is significant. If at all possible, use the [conditional expression](../syntax/ccmd/conditional_expression.md) (\"new test command\") `[[ EXPRESSION ]]`. Unless there is a need for POSIX compatibility, there are only a few reasons to use `[`. `[[` is one of the most portable and consistent non-POSIX ksh extensions available. See: [conditional_expression](../syntax/ccmd/conditional_expression.md) and *[What is the difference between test, \[ and \[\[ ?](http://mywiki.wooledge.org/BashFAQ/031)* `set -e`, `set -o errexit`\ proper control flow and error handling `set -e` causes untested non-zero exit statuses to be fatal. It is a debugging feature intended for use only during development and should not be used in production code, especially init scripts and other high-availability scripts. Do not be tempted to think of this as \"error handling\"; it\'s not, it\'s just a way to find the place you\'ve *forgotten* to put error handling.\ and the `ERR` trap Think of it as akin to `use strict` in Perl or `throws` in C++: tough love that makes you write better code. Many guides recommend avoiding it entirely because of the apparently-complex rules for when non-zero statuses cause the script to abort. Conversely, large software projects with experienced coders may recommend or even mandate its use.\ @@ -64,15 +64,15 @@ surprised if you run across someone telling you not to use these. Syntax Replacement Description ------------------------------- --------------------------------------------------------------------- ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - `function\ NAME\ {\ CMDS;\ }` `NAME()\ COMPOUND-CMD` This is the ksh form of function definition created to extend the Bourne and POSIX form with modified behaviors and additional features like local variables. The idea was for new-style functions to be analogous to regular builtins with their own environment and scope, while POSIX-style functions are more like special builtins. `function` is supported by almost every ksh-derived shell including Bash and Zsh, but isn\'t specified by POSIX. Bash treats all function styles the same, but this is unusual. `function` has some preferable characteristics in many ksh variants, making it more portable for scripts that use non-POSIX extensions by some measures. If you\'re going to use the `function` keyword, it implies that you\'re either targeting Ksh specifically, or that you have detailed knowledge of how to compensate for differences across shells. It should always be used consistently with `typeset`, but never used with `declare` or `local`. Also in ksh93, the braces are not a [command group](/syntax/ccmd/grouping_plain), but a required part of the syntax (unlike Bash and others). See [shell function definitions](/syntax/basicgrammar#shell_function_definitions) + `function\ NAME\ {\ CMDS;\ }` `NAME()\ COMPOUND-CMD` This is the ksh form of function definition created to extend the Bourne and POSIX form with modified behaviors and additional features like local variables. The idea was for new-style functions to be analogous to regular builtins with their own environment and scope, while POSIX-style functions are more like special builtins. `function` is supported by almost every ksh-derived shell including Bash and Zsh, but isn\'t specified by POSIX. Bash treats all function styles the same, but this is unusual. `function` has some preferable characteristics in many ksh variants, making it more portable for scripts that use non-POSIX extensions by some measures. If you\'re going to use the `function` keyword, it implies that you\'re either targeting Ksh specifically, or that you have detailed knowledge of how to compensate for differences across shells. It should always be used consistently with `typeset`, but never used with `declare` or `local`. Also in ksh93, the braces are not a [command group](../syntax/ccmd/grouping_plain.md), but a required part of the syntax (unlike Bash and others). See [shell function definitions](../syntax/basicgrammar.md#shell_function_definitions) `typeset` `declare`, `local`, `export`, `readonly` This is closely related to the above, and should often be used together. `typeset` exists primarily for `ksh` compatibility, but is marked as \"deprecated\" in Bash (though I don\'t entirely agree with this). This makes some sense, because future compatibility can\'t be guaranteed, and any compatibility at all, requires understanding the non-POSIX features of other shells and their differences. Using `declare` instead of `typeset` emphasizes your intention to be \"Bash-only\", and definitely breaks everywhere else (except possibly zsh if you\'re lucky). The issue is further complicated by Dash and the [Debian policy](http://www.debian.org/doc/debian-policy/ch-files.html#s-scripts) requirement for a `local` builtin, which is itself not entirely compatible with Bash and other shells. - \'\'let \'EXPR\' \'\' `((EXPR))` or `[\ $((EXPR))\ -ne\ 0 ]` `let` is the \"simple command\" variant of arithmetic evaluation command, which takes regular arguments. Both `let` and `((expr))` were present in ksh88, and everything that supports one should support the other. Neither are POSIX. The compound variant is preferable because it doesn\'t take regular arguments for [wordsplitting](/syntax/expansion/wordsplit) and [globbing](/syntax/expansion/globs), which makes it safer and clearer. It is also usually faster, especially in Bash, where compound commands are typically significantly faster. Some of the (few) reasons for using `let` are detailed on the [let](/commands/builtin/let) page. See [arithmetic evaluation compound command](/syntax/ccmd/arithmetic_eval) - `eval` Depends. Often code can be restructured to use better alternatives. `eval` is thrown in here for good measure, as sadly it is so often misused that any use of `eval` (even the rare clever one) is immediately dismissed as wrong by experts, and among the most immediate solutions abused by beginners. In reality, there are correct ways to use `eval`, and even cases in which it\'s necessary, even in sophisticated shells like Bash and Ksh. `eval` is unusual in that it is less frequently appropriate in more feature-rich shells than in more minimal shells like Dash, where it is used to compensate for more limitations. If you find yourself needing `eval` too frequently, it might be a sign that you\'re either better off using a different language entirely, or trying to borrow an idiom from some other paradigm that isn\'t well suited to the shell language. By the same token, there are some cases in which working too hard to avoid `eval` ends up adding a lot of complexity and sacrificing all portability. Don\'t substitute a clever `eval` for something that\'s a bit \"too clever\", just to avoid the `eval`, yet, take reasonable measures to avoid it where it is sensible to do so. See: [eval](/commands/builtin/eval) and [Eval command and security issues](http://mywiki.wooledge.org/BashFAQ/048). + \'\'let \'EXPR\' \'\' `((EXPR))` or `[\ $((EXPR))\ -ne\ 0 ]` `let` is the \"simple command\" variant of arithmetic evaluation command, which takes regular arguments. Both `let` and `((expr))` were present in ksh88, and everything that supports one should support the other. Neither are POSIX. The compound variant is preferable because it doesn\'t take regular arguments for [wordsplitting](../syntax/expansion/wordsplit.md) and [globbing](../syntax/expansion/globs.md), which makes it safer and clearer. It is also usually faster, especially in Bash, where compound commands are typically significantly faster. Some of the (few) reasons for using `let` are detailed on the [let](../commands/builtin/let.md) page. See [arithmetic evaluation compound command](../syntax/ccmd/arithmetic_eval.md) + `eval` Depends. Often code can be restructured to use better alternatives. `eval` is thrown in here for good measure, as sadly it is so often misused that any use of `eval` (even the rare clever one) is immediately dismissed as wrong by experts, and among the most immediate solutions abused by beginners. In reality, there are correct ways to use `eval`, and even cases in which it\'s necessary, even in sophisticated shells like Bash and Ksh. `eval` is unusual in that it is less frequently appropriate in more feature-rich shells than in more minimal shells like Dash, where it is used to compensate for more limitations. If you find yourself needing `eval` too frequently, it might be a sign that you\'re either better off using a different language entirely, or trying to borrow an idiom from some other paradigm that isn\'t well suited to the shell language. By the same token, there are some cases in which working too hard to avoid `eval` ends up adding a lot of complexity and sacrificing all portability. Don\'t substitute a clever `eval` for something that\'s a bit \"too clever\", just to avoid the `eval`, yet, take reasonable measures to avoid it where it is sensible to do so. See: [eval](../commands/builtin/eval.md) and [Eval command and security issues](http://mywiki.wooledge.org/BashFAQ/048). ## See also -- [Non-portable syntax and command uses](/scripting/nonportable) -- [bashchanges](/scripting/bashchanges) +- [Non-portable syntax and command uses](../scripting/nonportable.md) +- [bashchanges](../scripting/bashchanges.md) - [Greg\'s BashFAQ 061: List of essential features added (with the Bash version tag)](BashFAQ>061) - [Bash \<-\> POSIX Portability guide with a focus on diff --git a/docs/scripting/posparams.md b/docs/scripting/posparams.md index 8009d8c..498e609 100644 --- a/docs/scripting/posparams.md +++ b/docs/scripting/posparams.md @@ -10,12 +10,12 @@ parameters are described below: Parameter(s) Description ------------------ ------------------------------------------------------------------------------------------------------------------------------------ - `$0` the first positional parameter, equivalent to `argv[0]` in C, see [the first argument](/scripting/posparams#the_first_argument) + `$0` the first positional parameter, equivalent to `argv[0]` in C, see [the first argument](../scripting/posparams.md#the_first_argument) `$FUNCNAME` the function name ([**attention**]{.underline}: inside a function, `$0` is still the `$0` of the shell, **not** the function name) `$1 ... $9` the argument list elements from 1 to 9 - `${10} ... ${N}` the argument list elements beyond 9 (note the [parameter expansion](/syntax/pe) syntax!) - `$*` all positional parameters except `$0`, see [mass usage](/scripting/posparams#mass_usage) - `$@` all positional parameters except `$0`, see [mass usage](/scripting/posparams#mass_usage) + `${10} ... ${N}` the argument list elements beyond 9 (note the [parameter expansion](../syntax/pe.md) syntax!) + `$*` all positional parameters except `$0`, see [mass usage](../scripting/posparams.md#mass_usage) + `$@` all positional parameters except `$0`, see [mass usage](../scripting/posparams.md#mass_usage) `$#` the number of arguments, not counting `$0` These positional parameters reflect exactly what was given to the script @@ -25,7 +25,7 @@ Option-switch parsing (e.g. `-h` for displaying help) is not performed at this point. See also [the dictionary entry for -\"parameter\"](/dict/terms/parameter). +\"parameter\"](../dict/terms/parameter.md). ## The first argument @@ -105,7 +105,7 @@ There are several ways to loop through the positional parameters. ------------------------------------------------------------------------ -You can code a [C-style for-loop](/syntax/ccmd/c_for) using `$#` as the +You can code a [C-style for-loop](../syntax/ccmd/c_for.md) using `$#` as the end value. On every iteration, the `shift`-command is used to shift the argument list: @@ -136,7 +136,7 @@ a given wordlist. The loop uses the positional parameters as a wordlist: The next method is similar to the first example (the `for` loop), but it doesn\'t test for reaching `$#`. It shifts and checks if `$1` still -expands to something, using the [test command](/commands/classictest): +expands to something, using the [test command](../commands/classictest.md): while [ "$1" ] do @@ -147,7 +147,7 @@ expands to something, using the [test command](/commands/classictest): Looks nice, but has the disadvantage of stopping when `$1` is empty (null-string). Let\'s modify it to run as long as `$1` is defined (but may be null), using [parameter expansion for an alternate -value](/syntax/pe#use_an_alternate_value): +value](../syntax/pe.md#use_an_alternate_value): while [ "${1+defined}" ]; do echo "$1" @@ -157,7 +157,7 @@ value](/syntax/pe#use_an_alternate_value): ### Getopts There is a [small tutorial dedicated to -`getopts`](/howto/getopts_tutorial) (*under construction*). +`getopts`](../howto/getopts_tutorial.md) (*under construction*). ## Mass usage @@ -203,8 +203,8 @@ Well, let\'s just say: **You almost always want a quoted `"$@"`!** Another way to mass expand the positional parameters is similar to what is possible for a range of characters using [substring -expansion](/syntax/pe#substring_expansion) on normal parameters and the -mass expansion range of [arrays](/syntax/arrays). +expansion](../syntax/pe.md#substring_expansion) on normal parameters and the +mass expansion range of [arrays](../syntax/arrays.md). `${@:START:COUNT}` @@ -237,7 +237,7 @@ when the positional parameters are in use. A `START` of `1` begins at ## Setting Positional Parameters Setting positional parameters with command line arguments, is not the -only way to set them. The [builtin command, set](/commands/builtin/set) +only way to set them. The [builtin command, set](../commands/builtin/set.md) may be used to \"artificially\" change the positional parameters from inside the script or function: @@ -382,16 +382,16 @@ options\" for `ls` and doesn\'t change anything after it: ### Using getopts There is a [small tutorial dedicated to -`getopts`](/howto/getopts_tutorial) (*under construction*). +`getopts`](../howto/getopts_tutorial.md) (*under construction*). ## See also -- Internal: [getopts_tutorial](/howto/getopts_tutorial) -- Internal: [while_loop](/syntax/ccmd/while_loop) -- Internal: [c_for](/syntax/ccmd/c_for) -- Internal: [arrays](/syntax/arrays) (for equivalent syntax for +- Internal: [getopts_tutorial](../howto/getopts_tutorial.md) +- Internal: [while_loop](../syntax/ccmd/while_loop.md) +- Internal: [c_for](../syntax/ccmd/c_for.md) +- Internal: [arrays](../syntax/arrays.md) (for equivalent syntax for mass-expansion) - Internal: [Substring expansion on a - parameter](/syntax/pe#substring_expansion) (for equivalent syntax + parameter](../syntax/pe.md#substring_expansion) (for equivalent syntax for mass-expansion) -- Dictionary, internal: [parameter](/dict/terms/parameter) +- Dictionary, internal: [parameter](../dict/terms/parameter.md) diff --git a/docs/scripting/processtree.md b/docs/scripting/processtree.md index dbcc6ee..0b64ebf 100644 --- a/docs/scripting/processtree.md +++ b/docs/scripting/processtree.md @@ -26,8 +26,8 @@ need to put it into the environment with the bash builtin command export MYVAR -Common system variables like [PATH](/syntax/shellvars#PATH) or -[HOME](/syntax/shellvars#HOME) are usually part of the environment (as +Common system variables like [PATH](../syntax/shellvars.md#PATH) or +[HOME](../syntax/shellvars.md#HOME) are usually part of the environment (as set by login scripts or programs). ## Executing programs @@ -163,7 +163,7 @@ are run inside a subshell: ### Command substitution -With [command substitution](/syntax/expansion/cmdsubst) you re-use the +With [command substitution](../syntax/expansion/cmdsubst.md) you re-use the output of another command as text in your command line, for example to set a variable. The other command is run in a subshell: diff --git a/docs/scripting/style.md b/docs/scripting/style.md index d9bbafd..8d5ebe9 100644 --- a/docs/scripting/style.md +++ b/docs/scripting/style.md @@ -33,7 +33,7 @@ many may prefer 4 spaces, see below in the discussion section): Speaking of hard-tabs: Avoid them if possible. They only make trouble. I can imagine one case where they\'re useful: Indenting -[here-documents](/syntax/redirection#here_documents). +[here-documents](../syntax/redirection.md#here_documents). ### Breaking up lines @@ -55,7 +55,7 @@ supports the visual impression of \"these belong together\". ### Breaking compound commands -[Compound commands](/syntax/ccmd/intro) form the structures that make a +[Compound commands](../syntax/ccmd/intro.md) form the structures that make a shell script different from a stupid enumeration of commands. Usually they contain a kind of \"head\" and a \"body\" that contains command lists. This type of compound command is relatively easy to indent. @@ -242,7 +242,7 @@ Bash, but is not a good idea. ### Command substitution As noted in [the article about command -substitution](/syntax/expansion/cmdsubst), you should use the `$( ... )` +substitution](../syntax/expansion/cmdsubst.md), you should use the `$( ... )` form. If portability is a concern, use the backquoted form `` ` ... ` ``. @@ -279,7 +279,7 @@ The basic structure of a script simply reads: ### The shebang If possible (I know it\'s not always possible!), use [a -shebang](/dict/terms/shebang). +shebang](../dict/terms/shebang.md). Be careful with `/bin/sh`: The argument that \"on Linux `/bin/sh` is Bash\" **is a lie** (and technically irrelevant) @@ -314,7 +314,7 @@ have to ensure they\'re in a specific order. The portable form of the function definition should be used, without the `function` keyword (here using the [grouping compound -command](/syntax/ccmd/grouping_plain)): +command](../syntax/ccmd/grouping_plain.md)): getargs() { ... @@ -358,7 +358,7 @@ Example: ### Exit meaningfully -The [exit code](/dict/terms/exit_status) is your only way to directly +The [exit code](../dict/terms/exit_status.md) is your only way to directly communicate with the calling process without any special provisions. If your script exits, provide a meaningful exit code. That minimally @@ -380,7 +380,7 @@ of their C programs.\"** *\-- Robert Firth* - if the script is interactive, if it works for you and if you think this is a nice feature, you can try to [save the terminal content - and restore it](/snipplets/screen_saverestore) after execution + and restore it](../snipplets/screen_saverestore.md) after execution - output clean and understandable screen messages - if applicable, you can use colors or specific prefixes to tag error and warning messages diff --git a/docs/snipplets/add_color_to_your_scripts.md b/docs/snipplets/add_color_to_your_scripts.md index 9f4bd28..3c4e611 100644 --- a/docs/snipplets/add_color_to_your_scripts.md +++ b/docs/snipplets/add_color_to_your_scripts.md @@ -29,7 +29,7 @@ reset the color changes in bash. Like so \.... echo -e "$COL_YELLOW This is yellow $COL_RESET" But also see the notes in [the article about using -terminalcodes](/scripting/terminalcodes) about generating codes and +terminalcodes](../scripting/terminalcodes.md) about generating codes and hardwiring codes. This snipplet sets up associative arrays for basic color codes using diff --git a/docs/snipplets/pause_command.md b/docs/snipplets/pause_command.md index fd24122..e1f44a2 100644 --- a/docs/snipplets/pause_command.md +++ b/docs/snipplets/pause_command.md @@ -6,7 +6,7 @@ LastUpdate_dt: 2010-07-31 Contributors: Jan Schampera type: snipplet ------------------------------------------------------------------------ From the [example section of the read -command](/commands/builtin/read#examples), something that acts similar +command](../commands/builtin/read.md#examples), something that acts similar to the MSDOS `pause` command: pause() { diff --git a/docs/snipplets/prargs.md b/docs/snipplets/prargs.md index ecaf782..b17328e 100644 --- a/docs/snipplets/prargs.md +++ b/docs/snipplets/prargs.md @@ -13,7 +13,7 @@ Check this script (save it as script file or make a function): printf '"%b"\n' "$0" "$@" | nl -v0 -s": " -It uses the [printf command](/commands/builtin/printf) to generate a +It uses the [printf command](../commands/builtin/printf.md) to generate a list of arguments, even with escape sequences interpreted. This list is shown formatted by the nl(1) utility. diff --git a/docs/snipplets/print_horizontal_line.md b/docs/snipplets/print_horizontal_line.md index fd391d5..eb1b76c 100644 --- a/docs/snipplets/print_horizontal_line.md +++ b/docs/snipplets/print_horizontal_line.md @@ -78,7 +78,7 @@ naturally, invisible. What you see is the dash, repeated 20 times. printf '%.0s-' {1..20}; echo ``` -If the 20 is variable, you can use [eval](/commands/builtin/eval) to +If the 20 is variable, you can use [eval](../commands/builtin/eval.md) to insert the expansion (take care that using `eval` is potentially dangerous if you evaluate external data): @@ -95,7 +95,7 @@ eval printf %.1s '-{1..'"${COLUMNS:-$(tput cols)}"\}; echo You can also do it the crazy ormaaj way™ following basically the same principle as this [string reverse -example](/commands/builtin/eval#expansion_side-effects). It completely +example](../commands/builtin/eval.md#expansion_side-effects). It completely depends on Bash due to its brace expansion evaluation order and array parameter parsing details. As above, the eval only inserts the COLUMNS expansion into the expression and isn\'t involved in the rest, other @@ -132,4 +132,4 @@ hr() { ## Related articles -- [printf](/commands/builtin/printf) +- [printf](../commands/builtin/printf.md) diff --git a/docs/snipplets/rndstr.md b/docs/snipplets/rndstr.md index 044a3ca..c97aa4a 100644 --- a/docs/snipplets/rndstr.md +++ b/docs/snipplets/rndstr.md @@ -67,11 +67,11 @@ rndstr() The remaining examples don\'t use quite the same tricks, which will hopefully be explained elsewhere eventually. See -[unset](commands/builtin/unset#scope) for why doing assignments in this +[unset](../commands/builtin/unset.md#scope) for why doing assignments in this way works well. This next example is a variation on -[print_horizontal_line](/snipplets/print_horizontal_line). We\'re using +[print_horizontal_line](../snipplets/print_horizontal_line.md). We\'re using the printf field width specifier to truncate the values of a `sequence expansion` to one character. @@ -81,12 +81,12 @@ printf '%.1s' "${a[RANDOM%${#a[@]}]}"{0..9} $'\n' ``` The extra detail that makes this work is to notice that in Bash, [brace -expansion](syntax/expansion/brace) is usually the very first type of +expansion](../syntax/expansion/brace.md) is usually the very first type of expansion to be processed, always before parameter expansion. Bash is unique in this respect \-- all other shells with a brace expansion feature perform it almost last, just before pathname expansion. First the sequence expansion generates ten parameters, then the parameters are -expanded left-to-right causing the [arithmetic](/syntax/arith_expr) for +expanded left-to-right causing the [arithmetic](../syntax/arith_expr.md) for each to be evaluated individually, resulting in independent selection of random element of `a`. To get ten of the same element, put the array selection inside the format string where it will only be evaluated once, diff --git a/docs/snipplets/wrapperargs.md b/docs/snipplets/wrapperargs.md index 59341b4..aaa1bb4 100644 --- a/docs/snipplets/wrapperargs.md +++ b/docs/snipplets/wrapperargs.md @@ -40,7 +40,7 @@ There are two (maybe more) easy options: - writing out singlequoted strings and handle the embedded singlequotes -- the [printf command](/commands/builtin/printf) knows the `%q` format +- the [printf command](../commands/builtin/printf.md) knows the `%q` format specification, which will print a string (like `%s` does), but with all shell special characters escaped diff --git a/docs/syntax/arith_expr.md b/docs/syntax/arith_expr.md index 9d59071..5037b26 100644 --- a/docs/syntax/arith_expr.md +++ b/docs/syntax/arith_expr.md @@ -4,13 +4,13 @@ Arithmetic expressions are used in several situations: -- [arithmetic evaluation command](/syntax/ccmd/arithmetic_eval) -- [arithmetic expansion](/syntax/expansion/arith) -- [substring parameter expansion](/syntax/pe#substring_expansion) -- [the `let` builtin command](/commands/builtin/let) -- [C-style for loop](/syntax/ccmd/c_for) -- [array indexing](/syntax/arrays) -- [conditional expressions](/syntax/ccmd/conditional_expression) +- [arithmetic evaluation command](../syntax/ccmd/arithmetic_eval.md) +- [arithmetic expansion](../syntax/expansion/arith.md) +- [substring parameter expansion](../syntax/pe.md#substring_expansion) +- [the `let` builtin command](../commands/builtin/let.md) +- [C-style for loop](../syntax/ccmd/c_for.md) +- [array indexing](../syntax/arrays.md) +- [conditional expressions](../syntax/ccmd/conditional_expression.md) - Assignment statements, and arguments to declaration commands of variables with the integer attribute. @@ -95,7 +95,7 @@ and what numbers are and how they are built, then you don\'t need different bases. If you want to convert between the usual bases (octal, decimal, hex), -use [the printf command](/commands/builtin/printf) and its format +use [the printf command](../commands/builtin/printf.md) and its format strings. ## Shell variables @@ -121,7 +121,7 @@ When variables are referenced, the notation `1 + $X` is equivalent to the notation `1 + X`, both are allowed. When variables are referenced like `$X`, the rules of [parameter -expansion](/syntax/pe) apply and are performed **before** the expression +expansion](../syntax/pe.md) apply and are performed **before** the expression is evaluated. Thus, a construct like `${MYSTRING:4:3}` is valid inside an arithmetic expression. @@ -130,7 +130,7 @@ an arithmetic expression. Unlike command exit and return codes, arithmetic expressions evaluate to logical \"true\" when they are not 0. When they are 0, they evaluate to \"false\". The [arithmetic evaluation compound -command](/syntax/ccmd/arithmetic_eval) reverses the \"truth\" of an +command](../syntax/ccmd/arithmetic_eval.md) reverses the \"truth\" of an arithmetic expression to match the \"truth\" of command exit codes: - if the arithmetic expression brings up a value not 0 (arithmetic @@ -153,16 +153,16 @@ That means, the following `if`-clause will execute the `else`-thread: Operator Description --------------------- ---------------------------------------------------------------------------------------------------- ` = ` normal assignment - ` *= ` equivalent to ` = * `, see [calculation operators](/syntax/arith_expr#calculations) - ` /= ` equivalent to ` = / `, see [calculation operators](/syntax/arith_expr#calculations) - ` %= ` equivalent to ` = % `, see [calculation operators](/syntax/arith_expr#calculations) - ` += ` equivalent to ` = + `, see [calculation operators](/syntax/arith_expr#calculations) - ` -= ` equivalent to ` = - `, see [calculation operators](/syntax/arith_expr#calculations) - ` <<= ` equivalent to ` = << `, see [bit operations](/syntax/arith_expr#bit_operations) - ` >>= ` equivalent to ` = >> `, see [bit operations](/syntax/arith_expr#bit_operations) - ` &= ` equivalent to ` = & `, see [bit operations](/syntax/arith_expr#bit_operations) - ` ^= ` equivalent to ` = ^ `, see [bit operations](/syntax/arith_expr#bit_operations) - ` |= ` equivalent to ` = | `, see [bit operations](/syntax/arith_expr#bit_operations) + ` *= ` equivalent to ` = * `, see [calculation operators](../syntax/arith_expr.md#calculations) + ` /= ` equivalent to ` = / `, see [calculation operators](../syntax/arith_expr.md#calculations) + ` %= ` equivalent to ` = % `, see [calculation operators](../syntax/arith_expr.md#calculations) + ` += ` equivalent to ` = + `, see [calculation operators](../syntax/arith_expr.md#calculations) + ` -= ` equivalent to ` = - `, see [calculation operators](../syntax/arith_expr.md#calculations) + ` <<= ` equivalent to ` = << `, see [bit operations](../syntax/arith_expr.md#bit_operations) + ` >>= ` equivalent to ` = >> `, see [bit operations](../syntax/arith_expr.md#bit_operations) + ` &= ` equivalent to ` = & `, see [bit operations](../syntax/arith_expr.md#bit_operations) + ` ^= ` equivalent to ` = ^ `, see [bit operations](../syntax/arith_expr.md#bit_operations) + ` |= ` equivalent to ` = | `, see [bit operations](../syntax/arith_expr.md#bit_operations) ### Calculations @@ -336,8 +336,8 @@ under set -e. \ ## Arithmetic expressions in Bash -- [The C-style for-loop](/syntax/ccmd/c_for) -- [Arithmetic expansion](/syntax/expansion/arith) +- [The C-style for-loop](../syntax/ccmd/c_for.md) +- [Arithmetic expansion](../syntax/expansion/arith.md) - [Arithmetic evaluation compound - command](/syntax/ccmd/arithmetic_eval) -- [The \"let\" builtin command](/commands/builtin/let) + command](../syntax/ccmd/arithmetic_eval.md) +- [The \"let\" builtin command](../commands/builtin/let.md) diff --git a/docs/syntax/arrays.md b/docs/syntax/arrays.md index 512c631..c85dc0a 100644 --- a/docs/syntax/arrays.md +++ b/docs/syntax/arrays.md @@ -31,7 +31,7 @@ Bash supports two different types of ksh-like one-dimensional arrays. arrays are **always sparse**, meaning indexes are not necessarily contiguous. All syntax used for both assigning and dereferencing indexed arrays is an [arithmetic evaluation - context](/syntax/arith_expr) (see [#Referencing](#Referencing)). As + context](../syntax/arith_expr.md) (see [#Referencing](#Referencing)). As in C and many other languages, the numerical array indexes start at 0 (zero). Indexed arrays are the most common, useful, and portable type. Indexed arrays were first introduced to Bourne-like shells by @@ -69,7 +69,7 @@ The overall syntax is `arrname[subscript]` - where for indexed arrays, arrays, any nonempty string. Subscripts are first processed for parameter and arithmetic expansions, and command and process substitutions. When used within parameter expansions or as an argument -to the [unset](commands/builtin/unset) builtin, the special subscripts +to the [unset](../commands/builtin/unset.md) builtin, the special subscripts `*` and `@` are also accepted which act upon arrays analogously to the way the `@` and `*` special parameters act upon the positional parameters. In parsing the subscript, bash ignores any text that follows @@ -77,7 +77,7 @@ the closing bracket up to the end of the parameter name. With few exceptions, names of this form may be used anywhere ordinary parameter names are valid, such as within [arithmetic -expressions](/syntax/arith_expr), [parameter expansions](/syntax/pe), +expressions](../syntax/arith_expr.md), [parameter expansions](../syntax/pe.md), and as arguments to builtins that accept parameter names. An *array* is a Bash parameter that has been given the `-a` (for indexed) or `-A` (for associative) *attributes*. However, any regular (non-special or @@ -118,7 +118,7 @@ variables. Syntax Description --------------------------------- ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - `ARRAY[N]=VALUE` Sets the element `N` of the **indexed** array `ARRAY` to `VALUE`. **`N` can be any valid [arithmetic expression](/syntax/arith_expr)**. + `ARRAY[N]=VALUE` Sets the element `N` of the **indexed** array `ARRAY` to `VALUE`. **`N` can be any valid [arithmetic expression](../syntax/arith_expr.md)**. `ARRAY[STRING]=VALUE` Sets the element indexed by `STRING` of the **associative array** `ARRAY`. `ARRAY=VALUE` As above. If no index is given, as a default the zeroth element is set to `VALUE`. Careful, this is even true of associative arrays - there is no error if no key is specified, and the value is assigned to string index \"0\". `ARRAY=(E1\ E2\ ...)` Compound array assignment - sets the whole array `ARRAY` to the given list of elements indexed sequentially starting at zero. The array is unset before assignment unless the += operator is used. When the list is empty (`ARRAY=()`), the array will be set to an empty array. This method obviously does not use explicit indexes. An **associative array** can **not** be set like that! Clearing an associative array using `ARRAY=()` works. @@ -132,20 +132,20 @@ As of now, arrays can\'t be exported. ### Getting values \ For completeness and details on several parameter expansion -variants, see the [article about parameter expansion](/syntax/pe) and +variants, see the [article about parameter expansion](../syntax/pe.md) and check the notes about arrays. \ Syntax Description ----------------------------------------------------------------------- ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- `${ARRAY[N]}` Expands to the value of the index `N` in the **indexed** array `ARRAY`. If `N` is a negative number, it\'s treated as the offset from the maximum assigned index (can\'t be used for assignment) - 1 `${ARRAY[S]}` Expands to the value of the index `S` in the **associative** array `ARRAY`. - `"${ARRAY[@]}" ${ARRAY[@]} "${ARRAY[*]}" ${ARRAY[*]}` Similar to [mass-expanding positional parameters](/scripting/posparams#mass_usage), this expands to all elements. If unquoted, both subscripts `*` and `@` expand to the same result, if quoted, `@` expands to all elements individually quoted, `*` expands to all elements quoted as a whole. - `"${ARRAY[@]:N:M}" ${ARRAY[@]:N:M} "${ARRAY[*]:N:M}" ${ARRAY[*]:N:M}` Similar to what this syntax does for the characters of a single string when doing [substring expansion](/syntax/pe#substring_expansion), this expands to `M` elements starting with element `N`. This way you can mass-expand individual indexes. The rules for quoting and the subscripts `*` and `@` are the same as above for the other mass-expansions. + `"${ARRAY[@]}" ${ARRAY[@]} "${ARRAY[*]}" ${ARRAY[*]}` Similar to [mass-expanding positional parameters](../scripting/posparams.md#mass_usage), this expands to all elements. If unquoted, both subscripts `*` and `@` expand to the same result, if quoted, `@` expands to all elements individually quoted, `*` expands to all elements quoted as a whole. + `"${ARRAY[@]:N:M}" ${ARRAY[@]:N:M} "${ARRAY[*]:N:M}" ${ARRAY[*]:N:M}` Similar to what this syntax does for the characters of a single string when doing [substring expansion](../syntax/pe.md#substring_expansion), this expands to `M` elements starting with element `N`. This way you can mass-expand individual indexes. The rules for quoting and the subscripts `*` and `@` are the same as above for the other mass-expansions. For clarification: When you use the subscripts `@` or `*` for mass-expanding, then the behaviour is exactly what it is for `$@` and `$*` when [mass-expanding the positional -parameters](/scripting/posparams#mass_usage). You should read this +parameters](../scripting/posparams.md#mass_usage). You should read this article to understand what\'s going on. ### Metadata @@ -166,7 +166,7 @@ article to understand what\'s going on. ### Destruction -The [unset](commands/builtin/unset) builtin command is used to destroy +The [unset](../commands/builtin/unset.md) builtin command is used to destroy (unset) arrays or individual elements of arrays. -------------------------------------------------------------------------------------------------- @@ -182,12 +182,12 @@ The [unset](commands/builtin/unset) builtin command is used to destroy -------------------------------------------------------------------------------------------------- It is best to [explicitly specify --v](commands/builtin/unset#portability_considerations) when unsetting +-v](../commands/builtin/unset.md#portability_considerations) when unsetting variables with unset. \ Specifying unquoted array elements as arguments to any command, such as with the syntax above **may cause [pathname -expansion](/syntax/expansion/globs) to occur** due to the presence of +expansion](../syntax/expansion/globs.md) to occur** due to the presence of glob characters. Example: You are in a directory with a file named `x1`, and you want to @@ -678,10 +678,10 @@ to generate these results. ## See also -- [Parameter expansion](/syntax/pe) (contains sections for arrays) -- [classic_for](/syntax/ccmd/classic_for) (contains some examples to +- [Parameter expansion](../syntax/pe.md) (contains sections for arrays) +- [classic_for](../syntax/ccmd/classic_for.md) (contains some examples to iterate over arrays) -- [declare](/commands/builtin/declare) +- [declare](../commands/builtin/declare.md) - [BashFAQ 005 - How can I use array variables?](http://mywiki.wooledge.org/BashFAQ/005) - A very detailed discussion on arrays with many examples. diff --git a/docs/syntax/basicgrammar.md b/docs/syntax/basicgrammar.md index ec9b616..f8d0fb9 100644 --- a/docs/syntax/basicgrammar.md +++ b/docs/syntax/basicgrammar.md @@ -42,7 +42,7 @@ issue to report back to the calling program. **base** for all higher constructs. Everything you execute, from pipelines to functions, finally ends up in (many) simple commands. That\'s why Bash only has one method to [expand and execute a simple -command](/syntax/grammar/parser_exec). \ +command](../syntax/grammar/parser_exec.md). \ ## Pipelines @@ -82,7 +82,7 @@ acts on) exit code 0 (TRUE) and the `then` part of the `if` stanza is executed. One could say we checked for \"`not grep "^root" /etc/passwd`\". -The [set option pipefail](/commands/builtin/set#attributes) determines +The [set option pipefail](../commands/builtin/set.md#attributes) determines the behavior of how bash reports the exit code of a pipeline. If it\'s set, then the exit code (`$?`) is the last command that exits with non zero status, if none fail, it\'s zero. If it\'s not set, then `$?` @@ -111,7 +111,7 @@ syntax: FIXME Missing an additional article about list operators -A list is a sequence of one or more [pipelines](basicgrammar#pipelines) +A list is a sequence of one or more [pipelines](../basicgrammar.md#pipelines) separated by one of the operators `;`, `&`, `&&`, or `││`, and optionally terminated by one of `;`, `&`, or ``. @@ -132,7 +132,7 @@ Your whole Bash script technically is one big single list! ## Compound Commands -See also the [list of compound commands](/syntax/ccmd/intro). +See also the [list of compound commands](../syntax/ccmd/intro.md). There are two forms of compound commands: @@ -151,24 +151,24 @@ overview): Compound command syntax Description ------------------------------------------------------------ --------------------------------------------------------------------------------------------------------------------------------------------------------- - `( )` Execute `` in an extra subshell =\> [article](/syntax/ccmd/grouping_subshell) - `{ ; }` Execute `` as separate group (but not in a subshell) =\> [article](/syntax/ccmd/grouping_plain) - `(( ))` Evaluate the arithmetic expression `` =\> [article](/syntax/ccmd/arithmetic_eval) - `[[ ]]` Evaluate the conditional expression `` (aka \"the new test command\") =\> [article](/syntax/ccmd/conditional_expression) - `for in ; do ; done` Executes `` while setting the variable `` to one of `` on every iteration (classic for-loop) =\> [article](/syntax/ccmd/classic_for) - `for (( ; ; )) ; do ; done` C-style for-loop (driven by arithmetic expressions) =\> [article](/syntax/ccmd/c_for) - `select in ; do ; done` Provides simple menus =\> [article](/syntax/ccmd/user_select) - `case in ) ;; ... esac` Decisions based on pattern matching - executing `` on match =\> [article](/syntax/ccmd/case) - `if ; then ; else ; fi` The if clause: makes decisions based on exit codes =\> [article](/syntax/ccmd/if_clause) - `while ; do ; done` Execute `` while `` returns TRUE (exit code) =\> [article](/syntax/ccmd/while_loop) - `until ; do ; done` Execute `` until `` returns TRUE (exit code) =\> [article](/syntax/ccmd/until_loop) + `( )` Execute `` in an extra subshell =\> [article](../syntax/ccmd/grouping_subshell.md) + `{ ; }` Execute `` as separate group (but not in a subshell) =\> [article](../syntax/ccmd/grouping_plain.md) + `(( ))` Evaluate the arithmetic expression `` =\> [article](../syntax/ccmd/arithmetic_eval.md) + `[[ ]]` Evaluate the conditional expression `` (aka \"the new test command\") =\> [article](../syntax/ccmd/conditional_expression.md) + `for in ; do ; done` Executes `` while setting the variable `` to one of `` on every iteration (classic for-loop) =\> [article](../syntax/ccmd/classic_for.md) + `for (( ; ; )) ; do ; done` C-style for-loop (driven by arithmetic expressions) =\> [article](../syntax/ccmd/c_for.md) + `select in ; do ; done` Provides simple menus =\> [article](../syntax/ccmd/user_select.md) + `case in ) ;; ... esac` Decisions based on pattern matching - executing `` on match =\> [article](../syntax/ccmd/case.md) + `if ; then ; else ; fi` The if clause: makes decisions based on exit codes =\> [article](../syntax/ccmd/if_clause.md) + `while ; do ; done` Execute `` while `` returns TRUE (exit code) =\> [article](../syntax/ccmd/while_loop.md) + `until ; do ; done` Execute `` until `` returns TRUE (exit code) =\> [article](../syntax/ccmd/until_loop.md) ## Shell Function Definitions FIXME Missing an additional article about shell functions A shell function definition makes a [compound -command](basicgrammar#compound_commands) available via a new name. When +command](../basicgrammar.md#compound_commands) available via a new name. When the function runs, it has its own \"private\" set of positional parameters and I/O descriptors. It acts like a script-within-the-script. Simply stated: **You\'ve created a new command.** @@ -183,7 +183,7 @@ looks like: print_help() { echo "Sorry, no help available"; } As above, a function definition can have any [compound -command](basicgrammar#compound_commands) as a body. Structures like +command](../basicgrammar.md#compound_commands) as a body. Structures like countme() for ((x=1;x<=9;x++)); do echo $x; done @@ -265,17 +265,17 @@ Weird function names should not be used. Quote from the maintainer: ## Grammar summary -- a [simple command](basicgrammar#simple_commands) is just a command +- a [simple command](../basicgrammar.md#simple_commands) is just a command and its arguments -- a [pipeline](basicgrammar#pipelines) is one or more [simple - command](basicgrammar#simple_commands) probably connected in a pipe -- a [list](basicgrammar#lists) is one or more - [pipelines](basicgrammar#pipelines) connected by special operators -- a [compound command](basicgrammar#compound_commands) is a - [list](basicgrammar#lists) or a special command that forms a new +- a [pipeline](../basicgrammar.md#pipelines) is one or more [simple + command](../basicgrammar.md#simple_commands) probably connected in a pipe +- a [list](../basicgrammar.md#lists) is one or more + [pipelines](../basicgrammar.md#pipelines) connected by special operators +- a [compound command](../basicgrammar.md#compound_commands) is a + [list](../basicgrammar.md#lists) or a special command that forms a new meta-command -- a [function definition](basicgrammar#shell_function_definitions) - makes a [compound command](basicgrammar#compound_commands) available +- a [function definition](../basicgrammar.md#shell_function_definitions) + makes a [compound command](../basicgrammar.md#compound_commands) available under a new name, and a separate environment ## Examples for classification @@ -304,12 +304,12 @@ FIXME more\... cp mymusic.mp3 /data/mp3 fi -- the [compound command](basicgrammar#compound_commands) for the `if` +- the [compound command](../basicgrammar.md#compound_commands) for the `if` clause -- the [list](basicgrammar#lists) that `if` **checks** actually - contains the [simple command](basicgrammar#simple_commands) +- the [list](../basicgrammar.md#lists) that `if` **checks** actually + contains the [simple command](../basicgrammar.md#simple_commands) `[ -d /data/mp3 ]` -- the [list](basicgrammar#lists) that `if` **executes** contains a +- the [list](../basicgrammar.md#lists) that `if` **executes** contains a simple command (`cp mymusic.mp3 /data/mp3`) Let\'s invert test command exit code, only one thing changes: @@ -318,15 +318,15 @@ Let\'s invert test command exit code, only one thing changes: cp mymusic.mp3 /data/mp3 fi -- the [list](basicgrammar#lists) that `if` **checks** contains a - [pipeline](basicgrammar#pipelines) now (because of the `!`) +- the [list](../basicgrammar.md#lists) that `if` **checks** contains a + [pipeline](../basicgrammar.md#pipelines) now (because of the `!`) ## See also -- Internal: [List of compound commands](/syntax/ccmd/intro) +- Internal: [List of compound commands](../syntax/ccmd/intro.md) - Internal: [Parsing and execution of simple - commands](/syntax/grammar/parser_exec) -- Internal: [Quoting and escaping](/syntax/quoting) + commands](../syntax/grammar/parser_exec.md) +- Internal: [Quoting and escaping](../syntax/quoting.md) - Internal: [Introduction to expansions and - substitutions](/syntax/expansion/intro) -- Internal: [Some words about words\...](/syntax/words) + substitutions](../syntax/expansion/intro.md) +- Internal: [Some words about words\...](../syntax/words.md) diff --git a/docs/syntax/pattern.md b/docs/syntax/pattern.md index e292ad5..e0bb24b 100644 --- a/docs/syntax/pattern.md +++ b/docs/syntax/pattern.md @@ -4,14 +4,14 @@ A pattern is a **string description**. Bash uses them in various ways: -- [Pathname expansion](/syntax/expansion/globs) (Globbing - matching +- [Pathname expansion](../syntax/expansion/globs.md) (Globbing - matching filenames) - Pattern matching in [conditional - expressions](/syntax/ccmd/conditional_expression) -- [Substring removal](/syntax/pe#substring_removal) and [search and - replace](/syntax/pe#search_and_replace) in [Parameter - Expansion](/syntax/pe) -- Pattern-based branching using the [case command](/syntax/ccmd/case) + expressions](../syntax/ccmd/conditional_expression.md) +- [Substring removal](../syntax/pe.md#substring_removal) and [search and + replace](../syntax/pe.md#search_and_replace) in [Parameter + Expansion](../syntax/pe.md) +- Pattern-based branching using the [case command](../syntax/ccmd/case.md) The pattern description language is relatively easy. Any character that\'s not mentioned below matches itself. The `NUL` character may not @@ -75,7 +75,7 @@ Some simple examples using normal pattern matching: ## Extended pattern language -If you set the [shell option](/internals/shell_options) `extglob`, Bash +If you set the [shell option](../internals/shell_options.md) `extglob`, Bash understands some powerful patterns. A `` is one or more patterns, separated by the pipe-symbol (`PATTERN|PATTERN`). @@ -99,13 +99,13 @@ patterns, separated by the pipe-symbol (`PATTERN|PATTERN`). option classification description ------------------- ------------------------------------- ------------------------------------------------------------------------------- - `dotglob` [globbing](/syntax/expansion/globs) see [Pathname expansion customization](/syntax/expansion/globs#Customization) + `dotglob` [globbing](../syntax/expansion/globs.md) see [Pathname expansion customization](../syntax/expansion/globs.md#Customization) `extglob` global enable/disable extended pattern matching language, as described above - `failglob` [globbing](/syntax/expansion/globs) see [Pathname expansion customization](/syntax/expansion/globs#Customization) - `nocaseglob` [globbing](/syntax/expansion/globs) see [Pathname expansion customization](/syntax/expansion/globs#Customization) + `failglob` [globbing](../syntax/expansion/globs.md) see [Pathname expansion customization](../syntax/expansion/globs.md#Customization) + `nocaseglob` [globbing](../syntax/expansion/globs.md) see [Pathname expansion customization](../syntax/expansion/globs.md#Customization) `nocasematch` pattern/string matching perform pattern matching without regarding the case of individual letters - `nullglob` [globbing](/syntax/expansion/globs) see [Pathname expansion customization](/syntax/expansion/globs#Customization) - `globasciiranges` [globbing](/syntax/expansion/globs) see [Pathname expansion customization](/syntax/expansion/globs#Customization) + `nullglob` [globbing](../syntax/expansion/globs.md) see [Pathname expansion customization](../syntax/expansion/globs.md#Customization) + `globasciiranges` [globbing](../syntax/expansion/globs.md) see [Pathname expansion customization](../syntax/expansion/globs.md#Customization) ## Bugs and Portability considerations @@ -155,7 +155,7 @@ double extglob negation. The aforementioned ksh93 pattern is equivalent in Bash to: `[[ fo0bar == !(!(fo[0-9])|!(+([[:alnum:]])))bar ]]`, which is technically more portable, but ugly. -\* ksh93\'s [printf](commands/builtin/printf) builtin can translate from +\* ksh93\'s [printf](../commands/builtin/printf.md) builtin can translate from shell patterns to ERE and back again using the `%R` and `%P` format specifiers respectively. diff --git a/docs/syntax/pe.md b/docs/syntax/pe.md index db9d535..23c6c80 100644 --- a/docs/syntax/pe.md +++ b/docs/syntax/pe.md @@ -9,7 +9,7 @@ is an entity that stores values and is referenced by a **name**, a **number** or a **special symbol**. - parameters referenced by a name are called **variables** (this also - applies to [arrays](/syntax/arrays)) + applies to [arrays](../syntax/arrays.md)) - parameters referenced by a number are called **positional parameters** and reflect the arguments given to a shell - parameters referenced by a **special symbol** are auto-set @@ -25,10 +25,10 @@ check what it can be, try the overview section below! **Arrays** can be special cases for parameter expansion, every applicable description mentions arrays below. Please also see the -[article about arrays](/syntax/arrays). +[article about arrays](../syntax/arrays.md). For a more technical view what a parameter is and which types exist, -[see the dictionary entry for \"parameter\"](/dict/terms/parameter). +[see the dictionary entry for \"parameter\"](../dict/terms/parameter.md). ## Overview @@ -113,7 +113,7 @@ positional parameters (arguments to a script) beyond `$9`: ### Simple usage: Arrays -See also the [article about general array syntax](/syntax/arrays) +See also the [article about general array syntax](../syntax/arrays.md) For arrays you always need the braces. The arrays are expanded by individual indexes or mass arguments. An individual index behaves like a @@ -172,15 +172,15 @@ prefix to the parameter name. Specifically, indirection isn\'t possible on the `${!var@}`, `${!var*}`, `${!var[@]}`, `${!var[*]}`, and `${#var}` forms. This means the `!` prefix can\'t be used to retrieve the indices of an array, the length of a string, or number of elements in an array -indirectly (see [syntax/arrays#indirection](syntax/arrays#indirection) +indirectly (see [syntax/arrays#indirection](../syntax/arrays.md#indirection) for workarounds). Additionally, the `!`-prefixed parameter expansion conflicts with ksh-like shells which have the more powerful \"name-reference\" form of indirection, where the exact same syntax is used to expand to the name of the variable being referenced. -Indirect references to [array names](/syntax/arrays) are also possible +Indirect references to [array names](../syntax/arrays.md) are also possible since the Bash 3 series (exact version unknown), but undocumented. See -[syntax/arrays#indirection](syntax/arrays#indirection) for details. +[syntax/arrays#indirection](../syntax/arrays.md#indirection) for details. Chet has added an initial implementation of the ksh `nameref` declaration command to the git devel branch. (`declare -n`, `local -n`, @@ -237,7 +237,7 @@ names or titles. Just assign it to an array: `declare -a title=(my hello world john smith)` -For [array](/syntax/arrays) expansion, the case modification applies to +For [array](../syntax/arrays.md) expansion, the case modification applies to **every expanded element, no matter if you expand an individual index or mass-expand** the whole array using `@` or `*` subscripts. Some examples: @@ -275,7 +275,7 @@ This will show all defined variable names (not values!) beginning with $ echo ${!BASH*} BASH BASH_ARGC BASH_ARGV BASH_COMMAND BASH_LINENO BASH_SOURCE BASH_SUBSHELL BASH_VERSINFO BASH_VERSION -This list will also include [array names](/syntax/arrays). +This list will also include [array names](../syntax/arrays.md). ## Substring removal @@ -290,7 +290,7 @@ This list will also include [array names](/syntax/arrays). This one can **expand only a part** of a parameter\'s value, **given a pattern to describe what to remove** from the string. The pattern is interpreted just like a pattern to describe a filename to match -(globbing). See [Pattern matching](/syntax/pattern) for more. +(globbing). See [Pattern matching](../syntax/pattern.md) for more. Example string (*just a quote from a big man*): @@ -300,7 +300,7 @@ Example string (*just a quote from a big man*): `${PARAMETER#PATTERN}` and `${PARAMETER##PATTERN}` -This form is to remove the described [pattern](/syntax/pattern) trying +This form is to remove the described [pattern](../syntax/pattern.md) trying to **match it from the beginning of the string**. The operator \"`#`\" will try to remove the shortest text matching the pattern, while \"`##`\" tries to do it with the longest text matching. Look at the @@ -353,7 +353,7 @@ on your needs, you might need to adjust shortest/longest match. ### Substring removal: Arrays As for most parameter expansion features, working on -[arrays](/syntax/arrays) **will handle each expanded element**, for +[arrays](../syntax/arrays.md) **will handle each expanded element**, for individual expansion and also for mass expansion. Simple example, removing a trailing `is` from all array elements (on @@ -378,7 +378,7 @@ All other variants of this expansion behave the same. `${PARAMETER//PATTERN}` This one can substitute (*replace*) a substring [matched by a -pattern](/syntax/pattern), on expansion time. The matched substring will +pattern](../syntax/pattern.md), on expansion time. The matched substring will be entirely removed and the given string will be inserted. Again some example string for the tests: @@ -438,7 +438,7 @@ specifying an empty replacement: ### Search and replace: Arrays -This parameter expansion type applied to [arrays](/syntax/arrays) +This parameter expansion type applied to [arrays](../syntax/arrays.md) **applies to all expanded elements**, no matter if an individual element is expanded, or all elements using the mass expansion syntaxes. @@ -472,7 +472,7 @@ There\'s not much to say about it, mh? ### (String) length: Arrays -For [arrays](/syntax/arrays), this expansion type has two meanings: +For [arrays](../syntax/arrays.md), this expansion type has two meanings: - For **individual** elements, it reports the string length of the element (as for every \"normal\" parameter) @@ -507,7 +507,7 @@ is negative, it\'s taken as a second offset into the string, counting from the end of the string. `OFFSET` and `LENGTH` can be **any** [arithmetic -expression](/syntax/arith_expr). **Take care:** The `OFFSET` starts at +expression](../syntax/arith_expr.md). **Take care:** The `OFFSET` starts at 0, not at 1! Example string (a quote from a big man): @@ -544,7 +544,7 @@ the colon: ${MYSTRING:(-10):5} Why? Because it\'s interpreted as the parameter expansion syntax to [use -a default value](/syntax/pe#use_a_default_value). +a default value](../syntax/pe.md#use_a_default_value). ### Negative Length Value @@ -558,11 +558,11 @@ then: `Be liberal in what you accept, and conservative in what you send` This works since Bash 4.2-alpha, see also -[bashchanges](/scripting/bashchanges). +[bashchanges](../scripting/bashchanges.md). ### Substring/Element expansion: Arrays -For [arrays](/syntax/arrays), this expansion type has again 2 meanings: +For [arrays](../syntax/arrays.md), this expansion type has again 2 meanings: - For **individual** elements, it expands to the specified substring (as for every "normal" parameter) @@ -609,7 +609,7 @@ gender. Note that the default value is **used on expansion time**, it is ### Use a default value: Arrays -For [arrays](/syntax/arrays), the behaviour is very similar. Again, you +For [arrays](../syntax/arrays.md), the behaviour is very similar. Again, you have to make a difference between expanding an individual element by a given index and mass-expanding the array using the `@` and `*` subscripts. @@ -671,7 +671,7 @@ Example code (please try the example cases yourself): `${PARAMETER=WORD}` This one works like the [using default -values](/syntax/pe#use_a_default_value), but the default text you give +values](../syntax/pe.md#use_a_default_value), but the default text you give is not only expanded, but also **assigned** to the parameter, if it was unset or null. Equivalent to using a default value, when you omit the `:` (colon), as shown in the second form, the default value will only be @@ -693,7 +693,7 @@ Let\'s change our code example from above: ### Assign a default value: Arrays -For [arrays](/syntax/arrays) this expansion type is limited. For an +For [arrays](../syntax/arrays.md) this expansion type is limited. For an individual index, it behaves like for a \"normal\" parameter, the default value is assigned to this one element. The mass-expansion subscripts `@` and `*` **can not be used here** because it\'s not @@ -742,7 +742,7 @@ if variables you need (and that can be empty) are undefined: ### Use an alternate value: Arrays -Similar to the cases for [arrays](/syntax/arrays) to expand to a default +Similar to the cases for [arrays](../syntax/arrays.md) to expand to a default value, this expansion behaves like for a \"normal\" parameter when using individual array elements by index, but reacts differently when using the mass-expansion subscripts `@` and `*`: @@ -819,8 +819,8 @@ Removing the first 6 characters from a text string: `${arr[@]}`, `$*`, and `${arr[*]}` when [IFS](http://mywiki.wooledge.org/IFS) is set to null. POSIX is unclear about the expected behavior. A null IFS causes both [word - splitting](/syntax/expansion/wordsplit) and [pathname - expansion](/syntax/expansion/globs) to behave randomly. Since there + splitting](../syntax/expansion/wordsplit.md) and [pathname + expansion](../syntax/expansion/globs.md) to behave randomly. Since there are few good reasons to leave `IFS` set to null for more than the duration of a command or two, and even fewer to expand `$@` and `$*` unquoted, this should be a rare issue. **Always quote @@ -1051,6 +1051,6 @@ the difference may introduce a possible compatibility problem. ## See also - Internal: [Introduction to expansion and - substitution](/syntax/expansion/intro) -- Internal: [Arrays](/syntax/arrays) -- Dictionary, internal: [parameter](/dict/terms/parameter) + substitution](../syntax/expansion/intro.md) +- Internal: [Arrays](../syntax/arrays.md) +- Dictionary, internal: [parameter](../dict/terms/parameter.md) diff --git a/docs/syntax/quoting.md b/docs/syntax/quoting.md index 46ae4c6..e42066c 100644 --- a/docs/syntax/quoting.md +++ b/docs/syntax/quoting.md @@ -71,14 +71,14 @@ meaning to bash. [Exception:]{.underline} Inside a single-quoted string Inside a weak-quoted string there\'s **no special interpretion of**: - spaces as word-separators (on inital command line splitting and on - [word splitting](/syntax/expansion/wordsplit)!) + [word splitting](../syntax/expansion/wordsplit.md)!) - single-quotes to introduce strong-quoting (see below) - characters for pattern matching - tilde expansion - pathname expansion - process substitution -Everything else, especially [parameter expansion](/syntax/pe), is +Everything else, especially [parameter expansion](../syntax/pe.md), is performed! ls -l "*" @@ -197,7 +197,7 @@ documentation](http://www.gnu.org/software/gettext/manual/html_node/bash.html) ### String lists in for-loops -The [classic for loop](/syntax/ccmd/classic_for) uses a list of words to +The [classic for loop](../syntax/ccmd/classic_for.md) uses a list of words to iterate through. The list can also be in a variable: mylist="DOG CAT BIRD HORSE" @@ -221,7 +221,7 @@ is seen as **one word**. The for loop iterates exactly one time, with ### Working out the test-command The command `test` or `[ ... ]` ([the classic test -command](/commands/classictest)) is an ordinary command, so ordinary +command](../commands/classictest.md)) is an ordinary command, so ordinary syntax rules apply. Let\'s take string comparison as an example: [ WORD = WORD ] @@ -259,16 +259,16 @@ Now the command has three parameters, which makes sense for a binary (two argument) operator. **[Hint:]{.underline}** Inside the [conditional -expression](/syntax/ccmd/conditional_expression) (`[[ ]]`) Bash doesn\'t +expression](../syntax/ccmd/conditional_expression.md) (`[[ ]]`) Bash doesn\'t perform word splitting, and thus you don\'t need to quote your variable references - they are always seen as \"one word\". ## See also -- Internal: [Some words about words\...](/syntax/words) -- Internal: [Word splitting](/syntax/expansion/wordsplit) +- Internal: [Some words about words\...](../syntax/words.md) +- Internal: [Word splitting](../syntax/expansion/wordsplit.md) - Internal: [Introduction to expansions and - substitutions](/syntax/expansion/intro) + substitutions](../syntax/expansion/intro.md) ```{=html} diff --git a/docs/syntax/redirection.md b/docs/syntax/redirection.md index f8bba2b..8044b01 100644 --- a/docs/syntax/redirection.md +++ b/docs/syntax/redirection.md @@ -5,7 +5,7 @@ Redirection makes it possible to control where the output of a command goes to, and where the input of a command comes from. It\'s a mighty tool that, together with pipelines, makes the shell powerful. The redirection operators are checked whenever a [simple command is about to -be executed](/syntax/grammar/parser_exec). +be executed](../syntax/grammar/parser_exec.md). Under normal circumstances, there are 3 files open, accessible by the file descriptors 0, 1 and 2, all connected to your terminal: @@ -79,7 +79,7 @@ This redirects the file descriptor number `N` to the target `TARGET`. If **truncated** before writing starts. If the option `noclobber` is set with [the set -builtin](/commands/builtin/set), with cause the redirection to fail, +builtin](../commands/builtin/set.md), with cause the redirection to fail, when `TARGET` names a regular file that already exists. You can manually override that behaviour by forcing overwrite with the redirection operator `>|` instead of `>`. @@ -108,7 +108,7 @@ Since Bash4, there\'s `&>>TARGET`, which is equivalent to \This syntax is deprecated and should not be used. See the page about [obsolete and deprecated -syntax](/scripting/obsolete).\ +syntax](../scripting/obsolete.md).\ ## Appending redirected output and error output @@ -160,9 +160,9 @@ used to mark the end of input later: As you see, substitutions are possible. To be precise, the following substitutions and expansions are performed in the here-document data: -- [Parameter expansion](/syntax/pe) -- [Command substitution](/syntax/expansion/cmdsubst) -- [Arithmetic expansion](/syntax/expansion/arith) +- [Parameter expansion](../syntax/pe.md) +- [Command substitution](../syntax/expansion/cmdsubst.md) +- [Arithmetic expansion](../syntax/expansion/arith.md) You can avoid that by quoting the tag: @@ -238,14 +238,14 @@ How to make a program quiet (assuming all output goes to `STDOUT` and ## See also - Internal: [Illustrated Redirection - Tutorial](/howto/redirection_tutorial) + Tutorial](../howto/redirection_tutorial.md) - Internal: [The noclobber - option](/commands/builtin/set#tag_noclobber) -- Internal: [The exec builtin command](/commands/builtin/exec) + option](../commands/builtin/set.md#tag_noclobber) +- Internal: [The exec builtin command](../commands/builtin/exec.md) - Internal: [Simple commands parsing and - execution](/syntax/grammar/parser_exec) + execution](../syntax/grammar/parser_exec.md) - Internal: [Process substitution - syntax](/syntax/expansion/proc_subst) -- Internal: [Obsolete and deprecated syntax](/scripting/obsolete) + syntax](../syntax/expansion/proc_subst.md) +- Internal: [Obsolete and deprecated syntax](../scripting/obsolete.md) - Internal: [Nonportable syntax and command - uses](/scripting/nonportable) + uses](../scripting/nonportable.md) diff --git a/docs/syntax/shellvars.md b/docs/syntax/shellvars.md index d6f3133..bfa0510 100644 --- a/docs/syntax/shellvars.md +++ b/docs/syntax/shellvars.md @@ -5,23 +5,23 @@ -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- parameter character expansion description ----------- ------------------ ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- - `*` asterisk The positional parameters starting from the first. When used inside doublequotes (see [quoting](/syntax/quoting)), like `"$*"`, it expands to all positional parameters *as one word*, delimited by the first character of the `IFS` variable (a space in this example): `"$1 $2 $3 $4"`.\ + `*` asterisk The positional parameters starting from the first. When used inside doublequotes (see [quoting](../syntax/quoting.md)), like `"$*"`, it expands to all positional parameters *as one word*, delimited by the first character of the `IFS` variable (a space in this example): `"$1 $2 $3 $4"`.\ If `IFS` is unset, the delimiter used will be always a space, if `IFS` is NULL, the delimiter will be nothing, which effectively concatenates all the positional parameters without any delimiter.\ When used unquoted, it will just expand to the strings, one by one, not preserving the word boundaries (i.e. word splitting will split the text again, if it contains `IFS` characters.\ - See also the [scripting article about handling positional parameters](/scripting/posparams). + See also the [scripting article about handling positional parameters](../scripting/posparams.md). - `@` at-sign The positional parameters starting from the first. When used inside doublequotes (see [quoting](/syntax/quoting)), like `"$@"`, it expands all positional parameters *as separate words*: `"$1" "$2" "$3" "$4"`\ + `@` at-sign The positional parameters starting from the first. When used inside doublequotes (see [quoting](../syntax/quoting.md)), like `"$@"`, it expands all positional parameters *as separate words*: `"$1" "$2" "$3" "$4"`\ Without doublequotes, the behaviour is like the one of `*` without doublequotes.\ - See also the [scripting article about handling positional parameters](/scripting/posparams). + See also the [scripting article about handling positional parameters](../scripting/posparams.md). `#` hash mark Number of positional parameters (decimal)\ - See also the [scripting article about handling positional parameters](/scripting/posparams). + See also the [scripting article about handling positional parameters](../scripting/posparams.md). `?` question mark Status of the most recently executed foreground-pipeline (exit/return code) - `-` dash Current option flags set by the shell itself, on invocation, or using the [set builtin command](/commands/builtin/set). It\'s just a set of characters, like `himB` for `h`, `i`, `m` and `B`. + `-` dash Current option flags set by the shell itself, on invocation, or using the [set builtin command](../commands/builtin/set.md). It\'s just a set of characters, like `himB` for `h`, `i`, `m` and `B`. - `$` dollar-sign The process ID (PID) of the shell. In an [explicit subshell](/syntax/ccmd/grouping_subshell) it expands to the PID of the current \"main shell\", not the subshell. This is different from `$BASHPID`! + `$` dollar-sign The process ID (PID) of the shell. In an [explicit subshell](../syntax/ccmd/grouping_subshell.md) it expands to the PID of the current \"main shell\", not the subshell. This is different from `$BASHPID`! `!` exclamation mark The process ID (PID) of the most recently executed background pipeline (like started with `command &`) @@ -54,7 +54,7 @@ Bash. A colon-separated list of enabled shell options. Each word in the list is a valid argument for the `-s` option to the -[shopt builtin command](/commands/builtin/shopt). The options appearing +[shopt builtin command](../commands/builtin/shopt.md). The options appearing in `BASHOPTS` are those reported as on by `shopt`. If this variable is in the environment when Bash starts up, each shell option in the list will be enabled before reading any startup files. @@ -89,7 +89,7 @@ this array appear in the alias list; unsetting array elements cause aliases to be removed from the alias list. The associative key is the name of the alias as used with the [alias -builtin command](/commands/builtin/alias). +builtin command](../commands/builtin/alias.md). ### BASH_ARGC @@ -103,7 +103,7 @@ frame of the current Bash execution call stack. The number of parameters to the current subroutine (shell function or script executed with [`.` or `source` builtin -command](/commands/builtin/source)) is at the top of the stack. When a +command](../commands/builtin/source.md)) is at the top of the stack. When a subroutine is executed, the number of parameters passed is pushed onto `BASH_ARGC`. @@ -145,12 +145,12 @@ subsequently reset. An associative array variable whose members correspond to the internal hash table of commands as maintained by the [hash builtin -command](/commands/builtin/hash). Elements added to this array appear in +command](../commands/builtin/hash.md). Elements added to this array appear in the hash table; unsetting array elements cause commands to be removed from the hash table. The associative key is the name of the command as used with the[hash -builtin command](/commands/builtin/hash). +builtin command](../commands/builtin/hash.md). ### BASH_COMMAND @@ -454,7 +454,7 @@ element of `FUNCNAME` has corresponding elements in `BASH_LINENO` and `BASH_SOURCE` to describe the call stack. For instance, `${FUNCNAME[$i]}` was called from the file `${BASH_SOURCE[$i+1]}` at line number `${BASH_LINENO[$i]}`. The [caller builtin -command](/commands/builtin/caller) displays the current call stack using +command](../commands/builtin/caller.md) displays the current call stack using this information. This variable exists only when a shell function is executing. @@ -555,7 +555,7 @@ Example content: Set by Bash: yes Default: n/a An array variable created to hold the text read by the [mapfile builtin -command](/commands/builtin/mapfile) when no variable name is supplied. +command](../commands/builtin/mapfile.md) when no variable name is supplied. ### OLDPWD @@ -574,7 +574,7 @@ The previous working directory as set by the cd command. Set by Bash: yes Default: n/a The value of the last option argument processed by the [getopts builtin -command](/commands/builtin/getopts). +command](../commands/builtin/getopts.md). ### OPTIND @@ -584,7 +584,7 @@ command](/commands/builtin/getopts). Set by Bash: yes Default: n/a The index of the next argument to be processed by the [getopts builtin -command](/commands/builtin/getopts). +command](../commands/builtin/getopts.md). ### OSTYPE @@ -628,7 +628,7 @@ The process ID of the shell\'s parent process. Set by Bash: yes Default: n/a The current working directory as set by the [cd builtin -command](/commands/builtin/cd). +command](../commands/builtin/cd.md). ### RANDOM @@ -668,10 +668,10 @@ with `bind -x`. Variable: `REPLY` Since: unknown -------------- ------------------------------------------------------------ ------------ --------- Type: normal variable Read-only: no - Set by Bash: only by the [read builtin command](/commands/builtin/read) Default: n/a + Set by Bash: only by the [read builtin command](../commands/builtin/read.md) Default: n/a Set to the line of input read by the [read builtin -command](/commands/builtin/read) when no arguments are supplied that +command](../commands/builtin/read.md) when no arguments are supplied that name target variables. ### SECONDS @@ -698,7 +698,7 @@ is subsequently reset. A colon-separated list of enabled shell options. Each word in the list is a valid argument for the `-o` option to the [set builtin -command](/commands/builtin/set). The options appearing in `SHELLOPTS` +command](../commands/builtin/set.md). The options appearing in `SHELLOPTS` are those reported as on by `set -o`. If this variable is in the environment when Bash starts up, each shell @@ -736,9 +736,9 @@ If this parameter is set when Bash is executing a shell script, its value is interpreted as a filename containing commands to initialize the shell, as in `~/.bashrc`. The value of `BASH_ENV` is subjected to -- [parameter expansion](/syntax/pe) -- [command substitution](/syntax/expansion/cmdsubst) -- [arithmetic expansion](/syntax/expansion/arith) +- [parameter expansion](../syntax/pe.md) +- [command substitution](../syntax/expansion/cmdsubst.md) +- [arithmetic expansion](../syntax/expansion/arith.md) before being interpreted as a file name. @@ -770,7 +770,7 @@ unsetting it will result in the standard error being closed. Type: normal variable Read-only: no Set by Bash: no Default: n/a -The search path for the [cd builtin command](/commands/builtin/cd). +The search path for the [cd builtin command](../commands/builtin/cd.md). This is a colon-separated list of directories in which the shell looks for destination directories specified by the `cd` command. @@ -828,7 +828,7 @@ Similar to `BASH_ENV`: Used when the shell is invoked in POSIX(r) mode. Type: normal variable Read-only: no Set by Bash: no Default: n/a -The default editor for the [fc builtin command](/commands/builtin/fc). +The default editor for the [fc builtin command](../commands/builtin/fc.md). ### FIGNORE @@ -986,10 +986,10 @@ comment character to distinguish timestamps from other history lines. The home directory of the current user. -The default argument for the [cd builtin command](/commands/builtin/cd). +The default argument for the [cd builtin command](../commands/builtin/cd.md). The value of this variable is also used when performing [tilde -expansion](/syntax/expansion/tilde). +expansion](../syntax/expansion/tilde.md). ### HOSTFILE @@ -1177,7 +1177,7 @@ Example content: Set by Bash: yes Default: 1 (set on startup) If set to the value 1, Bash displays error messages generated by the -[getopts builtin command](/commands/builtin/getopts). +[getopts builtin command](../commands/builtin/getopts.md). `OPTERR` is initialized to 1 each time the shell is invoked or a shell script is executed. @@ -1368,9 +1368,9 @@ A trailing newline is added when the format string is displayed. Set by Bash: no Default: n/a If set to a value greater than zero, `TMOUT` is treated as the default -timeout for the [read builtin command](/commands/builtin/read). +timeout for the [read builtin command](../commands/builtin/read.md). -The [select command](/commands/builtin/select) terminates if input does +The [select command](../commands/builtin/select.md) terminates if input does not arrive after `TMOUT` seconds when input is coming from a terminal. In an interactive shell, the value is interpreted as the number of diff --git a/docs/syntax/words.md b/docs/syntax/words.md index d45d16d..5d622b5 100644 --- a/docs/syntax/words.md +++ b/docs/syntax/words.md @@ -90,7 +90,7 @@ take care of the spaces. But Bash also does another type of splitting. ## Word splitting For a more technical description, please read the [article about word -splitting](/syntax/expansion/wordsplit)! +splitting](../syntax/expansion/wordsplit.md)! The first kind of splitting is done to parse the command line into separate tokens. This is what was described above, it\'s a pure @@ -139,9 +139,9 @@ the command line\"): Word 1 Word 2 Word 3 Word 4 Word 5 Word 6 `echo` `The` `file` `is` `named` `$MYFILE` -A [parameter/variable expansion](/syntax/pe) is part of that command +A [parameter/variable expansion](../syntax/pe.md) is part of that command line, Bash will perform the substitution, and the [word -splitting](/syntax/expansion/wordsplit) on the results: +splitting](../syntax/expansion/wordsplit.md) on the results: Word splitting after substitution: ------------------------------------ -------- -------- -------- --------- -------- ------------ @@ -159,10 +159,10 @@ Now let\'s imagine we quoted `$MYFILE`, the command line now looks like: ***Bold Text*72i love this world**===== See also ===== -- Internal: [Quoting and character escaping](/syntax/quoting) -- Internal: [Word splitting](/syntax/expansion/wordsplit) +- Internal: [Quoting and character escaping](../syntax/quoting.md) +- Internal: [Word splitting](../syntax/expansion/wordsplit.md) - Internal: [Introduction to expansions and - substitutions](/syntax/expansion/intro) + substitutions](../syntax/expansion/intro.md) ```{=html}