| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | zsh-syntax-highlighting / highlighters / main | 
					
						
							|  |  |  | --------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This is the `main` highlighter, that highlights: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * Commands | 
					
						
							|  |  |  | * Options | 
					
						
							|  |  |  | * Arguments | 
					
						
							|  |  |  | * Paths | 
					
						
							|  |  |  | * Strings | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This highlighter is active by default. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### How to tweak it
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This highlighter defines the following styles: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `unknown-token` - unknown tokens / errors | 
					
						
							|  |  |  | * `reserved-word` - shell reserved words (`if`, `for`) | 
					
						
							|  |  |  | * `alias` - aliases | 
					
						
							|  |  |  | * `suffix-alias` - suffix aliases (requires zsh 5.1.1 or newer) | 
					
						
							|  |  |  | * `builtin` - shell builtin commands (`shift`, `pwd`, `zstyle`) | 
					
						
							|  |  |  | * `function` - function names | 
					
						
							|  |  |  | * `command` - command names | 
					
						
							|  |  |  | * `precommand` - precommand modifiers (e.g., `noglob`, `builtin`) | 
					
						
							|  |  |  | * `commandseparator` - command separation tokens (`;`, `&&`) | 
					
						
							|  |  |  | * `hashed-command` - hashed commands | 
					
						
							|  |  |  | * `path` - existing filenames | 
					
						
							| 
									
										
										
										
											2016-06-11 14:14:06 +02:00
										 |  |  | * `path_pathseparator` - path separators in filenames (`/`); if unset, `path` is used (default) | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | * `path_prefix` - prefixes of existing filenames | 
					
						
							| 
									
										
										
										
											2016-06-11 14:14:06 +02:00
										 |  |  | * `path_prefix_pathseparator` - path separators in prefixes of existing filenames (`/`); if unset, `path_prefix` is used (default) | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | * `globbing` - globbing expressions (`*.txt`) | 
					
						
							|  |  |  | * `history-expansion` - history expansion expressions (`!foo` and `^foo^bar`) | 
					
						
							| 
									
										
										
										
											2018-03-10 15:03:02 -06:00
										 |  |  | * `command-substitution` - command substitutions (`$(echo foo)`) | 
					
						
							| 
									
										
										
										
											2018-10-13 08:14:42 -05:00
										 |  |  | * `command-substitution-unquoted` - an unquoted command substitution (`$(echo foo)`) | 
					
						
							|  |  |  | * `command-substitution-quoted` - a quoted command substitution (`"$(echo foo)"`) | 
					
						
							| 
									
										
										
										
											2018-04-14 14:00:03 -05:00
										 |  |  | * `command-substitution-delimiter` - command substitution delimiters (`$(` and `)`) | 
					
						
							| 
									
										
										
										
											2018-10-13 08:14:42 -05:00
										 |  |  | * `command-substitution-delimiter-unquoted` - an unquoted command substitution delimiters (`$(` and `)`) | 
					
						
							|  |  |  | * `command-substitution-delimiter-quoted` - a quoted command substitution delimiters (`"$(` and `)"`) | 
					
						
							| 
									
										
										
										
											2018-03-10 15:03:25 -06:00
										 |  |  | * `process-substitution` - process substitutions (`<(echo foo)`) | 
					
						
							| 
									
										
										
										
											2018-04-14 14:00:03 -05:00
										 |  |  | * `process-substitution-delimiter` - process substitution delimiters (`<(` and `)`) | 
					
						
							| 
									
										
										
										
											2018-01-13 14:43:02 +00:00
										 |  |  | * `single-hyphen-option` - single-hyphen options (`-o`) | 
					
						
							|  |  |  | * `double-hyphen-option` - double-hyphen options (`--option`) | 
					
						
							| 
									
										
										
										
											2018-01-13 14:43:37 +00:00
										 |  |  | * `back-quoted-argument` - backtick command substitution (`` `foo` ``) | 
					
						
							|  |  |  | * `back-quoted-argument-unclosed` - unclosed backtick command substitution (`` `foo ``) | 
					
						
							| 
									
										
										
										
											2018-04-14 14:00:03 -05:00
										 |  |  | * `back-quoted-argument-delimiter` - backtick command substitution delimiters (`` ` ``) | 
					
						
							| 
									
										
										
										
											2018-01-13 14:43:02 +00:00
										 |  |  | * `single-quoted-argument` - single-quoted arguments (`` 'foo' ``) | 
					
						
							|  |  |  | * `single-quoted-argument-unclosed` - unclosed single-quoted arguments (`` 'foo ``) | 
					
						
							|  |  |  | * `double-quoted-argument` - double-quoted arguments (`` "foo" ``) | 
					
						
							|  |  |  | * `double-quoted-argument-unclosed` - unclosed double-quoted arguments (`` "foo ``) | 
					
						
							|  |  |  | * `dollar-quoted-argument` - dollar-quoted arguments (`` $'foo' ``) | 
					
						
							|  |  |  | * `dollar-quoted-argument-unclosed` - unclosed dollar-quoted arguments (`` $'foo ``) | 
					
						
							| 
									
										
										
										
											2017-11-14 22:43:40 -06:00
										 |  |  | * `rc-quote` - two single quotes inside single quotes when the `RC_QUOTES` option is set (`` 'foo''bar' ``) | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | * `dollar-double-quoted-argument` - parameter expansion inside double quotes (`$foo` inside `""`) | 
					
						
							| 
									
										
										
										
											2018-01-13 14:43:37 +00:00
										 |  |  | * `back-double-quoted-argument` -  backslash escape sequences inside double-quoted arguments (`\"` in `"foo\"bar"`) | 
					
						
							|  |  |  | * `back-dollar-quoted-argument` -  backslash escape sequences inside dollar-quoted arguments (`\x` in `$'\x48'`) | 
					
						
							|  |  |  | * `assign` - parameter assignments (`x=foo` and `x=( )`) | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | * `redirection` - redirection operators (`<`, `>`, etc) | 
					
						
							|  |  |  | * `comment` - comments, when `setopt INTERACTIVE_COMMENTS` is in effect (`echo # foo`) | 
					
						
							| 
									
										
										
										
											2020-02-25 17:37:46 +00:00
										 |  |  | * `comment` - elided parameters in command position (`$x ls` when `$x` is unset or empty) | 
					
						
							| 
									
										
										
										
											2020-03-17 03:59:30 +00:00
										 |  |  | * `named-fd` - named file descriptor (the `fd` in `echo foo {fd}>&2`) | 
					
						
							|  |  |  | * `numeric-fd` - numeric file descriptor (the `2` in `echo foo {fd}>&2`) | 
					
						
							| 
									
										
										
										
											2018-05-26 09:39:25 -04:00
										 |  |  | * `arg0` - a command word other than one of those enumerated above (other than a command, precommand, alias, function, or shell builtin command). | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | * `default` - everything else | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To override one of those styles, change its entry in `ZSH_HIGHLIGHT_STYLES`, | 
					
						
							|  |  |  | for example in `~/.zshrc`: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-13 16:12:41 +08:00
										 |  |  | ```zsh | 
					
						
							|  |  |  | # Declare the variable
 | 
					
						
							|  |  |  | typeset -A ZSH_HIGHLIGHT_STYLES | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # To differentiate aliases from other command types
 | 
					
						
							|  |  |  | ZSH_HIGHLIGHT_STYLES[alias]='fg=magenta,bold' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # To have paths colored instead of underlined
 | 
					
						
							|  |  |  | ZSH_HIGHLIGHT_STYLES[path]='fg=cyan' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # To disable highlighting of globbing expressions
 | 
					
						
							|  |  |  | ZSH_HIGHLIGHT_STYLES[globbing]='none' | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-11-17 21:11:09 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-24 07:39:44 +00:00
										 |  |  | The syntax for values is the same as the syntax of "types of highlighting" of | 
					
						
							|  |  |  | the zsh builtin `$zle_highlight` array, which is documented in [the `zshzle(1)` | 
					
						
							|  |  |  | manual page][zshzle-Character-Highlighting]. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-21 14:48:47 -06:00
										 |  |  | #### Parameters
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-24 07:27:54 -05:00
										 |  |  | To avoid partial path lookups on a path, add the path to the `ZSH_HIGHLIGHT_DIRS_BLACKLIST` array. | 
					
						
							| 
									
										
										
										
											2018-01-21 14:48:47 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-13 16:12:41 +08:00
										 |  |  | ```zsh | 
					
						
							| 
									
										
										
										
											2019-07-24 07:27:54 -05:00
										 |  |  | ZSH_HIGHLIGHT_DIRS_BLACKLIST+=(/mnt/slow_share) | 
					
						
							| 
									
										
										
										
											2019-01-13 16:12:41 +08:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2018-01-21 14:48:47 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-16 17:24:58 +00:00
										 |  |  | ### Useless trivia
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Forward compatibility.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | zsh-syntax-highlighting attempts to be forward-compatible with zsh. | 
					
						
							|  |  |  | Specifically, we attempt to facilitate highlighting _command word_ types that | 
					
						
							|  |  |  | had not yet been invented when this version of zsh-syntax-highlighting was | 
					
						
							|  |  |  | released. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A _command word_ is something like a function name, external command name, et | 
					
						
							|  |  |  | cetera.  (See | 
					
						
							|  |  |  | [Simple Commands & Pipelines in `zshmisc(1)`][zshmisc-Simple-Commands-And-Pipelines] | 
					
						
							|  |  |  | for a formal definition.) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If a new _kind_ of command word is ever added to zsh — something conceptually | 
					
						
							|  |  |  | different than "function" and "alias" and "external command" — then command words | 
					
						
							|  |  |  | of that (new) kind will be highlighted by the style `arg0_$kind`, | 
					
						
							|  |  |  | where `$kind` is the output of `type -w` on the new kind of command word.  If that | 
					
						
							|  |  |  | style is not defined, then the style `arg0` will be used instead. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [zshmisc-Simple-Commands-And-Pipelines]: http://zsh.sourceforge.net/Doc/Release/Shell-Grammar.html#Simple-Commands-_0026-Pipelines | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-24 07:39:44 +00:00
										 |  |  | [zshzle-Character-Highlighting]: http://zsh.sourceforge.net/Doc/Release/Zsh-Line-Editor.html#Character-Highlighting |