COMMENT(!MOD!zsh/parameter Access to internal hash tables via special associative arrays. !MOD!) cindex(parameters, special) The tt(zsh/parameter) module gives access to some of the internal hash tables used by the shell by defining some special parameters. startitem() vindex(options) item(tt(options))( The keys for this associative array are the names of the options that can be set and unset using the tt(setopt) and tt(unsetopt) builtins. The value of each key is either the string tt(on) if the option is currently set, or the string tt(off) if the option is unset. Setting a key to one of these strings is like setting or unsetting the option, respectively. Unsetting a key in this array is like setting it to the value tt(off). ) vindex(commands) item(tt(commands))( This array gives access to the command hash table. The keys are the names of external commands, the values are the pathnames of the files that would be executed when the command would be invoked. Setting a key in this array defines a new entry in this table in the same way as with the tt(hash) builtin. Unsetting a key as in `tt(unset "commands[foo]")' removes the entry for the given key from the command hash table. ) vindex(functions) item(tt(functions))( This associative array maps names of enabled functions to their definitions. Setting a key in it is like defining a function with the name given by the key and the body given by the value. Unsetting a key removes the definition for the function named by the key. ) vindex(dis_functions) item(tt(dis_functions))( Like tt(functions) but for disabled functions. ) vindex(builtins) item(tt(builtins))( This associative array gives information about the builtin commands currently enabled. The keys are the names of the builtin commands and the values are either `tt(undefined)' for builtin commands that will automatically be loaded from a module if invoked or `tt(defined)' for builtin commands that are already loaded. ) vindex(dis_builtins) item(tt(dis_builtins))( Like tt(builtins) but for disabled builtin commands. ) vindex(reswords) item(tt(reswords))( This array contains the enabled reserved words. ) vindex(dis_reswords) item(tt(dis_reswords))( Like tt(reswords) but for disabled reserved words. ) vindex(aliases) item(tt(aliases))( This maps the names of the regular aliases currently enabled to their expansions. ) vindex(dis_aliases) item(tt(dis_aliases))( Like tt(raliases) but for disabled regular aliases. ) vindex(galiases) item(tt(galiases))( Like tt(raliases), but for global aliases. ) vindex(dis_galiases) item(tt(dis_galiases))( Like tt(galiases) but for disabled global aliases. ) vindex(parameters) item(tt(parameters))( The keys in this associative array are the names of the parameters currently defined. The values are strings describing the type of the parameter, in the same format used by the tt(t) parameter flag, see ifzman(\ zmanref(zshexpn) )\ ifnzman(\ noderef(Parameter Expansion) )\ . Setting or unsetting keys in this array is not possible. ) vindex(modules) item(tt(modules))( An associative array giving information about modules. The keys are the names of the modules loaded, registered to be autoloaded, or aliased. The value says which state the named module is in and is one of the strings `tt(loaded)', `tt(autoloaded)', or `tt(alias:)var(name)', where var(name) is the name the module is aliased to. Setting or unsetting keys in this array is not possible. ) vindex(dirstack) item(tt(dirstack))( A normal array holding the elements of the directory stack. Note that the output of the tt(dirs) builtin command includes one more directory, the current working directory. ) vindex(history) item(tt(history))( This associative array maps history event numbers to the full history lines. ) vindex(historywords) item(tt(historywords))( A special array containing the words stored in the history. ) vindex(jobdirs) item(tt(jobdirs))( This associative array maps job numbers to the directories from which the job was started (which may not be the current directory of the job). ) vindex(jobtexts) item(tt(jobtexts))( This associative array maps job numbers to the texts of the command lines that were used to start the jobs. ) vindex(jobstates) item(tt(jobstates))( This associative array gives information about the states of the jobs currently known. The keys are the job numbers and the values are strings of the form `var(job-state):var(mark):var(pid)tt(=)var(state)tt(...)'. The var(job-state) gives the state the whole job is currently in, one of `tt(running)', `tt(suspended)', or `tt(done)'. The var(mark) is `tt(+)' for the current job, `tt(-)' for the previous job and empty otherwise. This is followed by one `var(pid)tt(=)var(state)' for every process in the job. The var(pid)s are, of course, the process IDs and the var(state) describes the state of that process. ) vindex(nameddirs) item(tt(nameddirs))( This associative array maps the names of named directories to the pathnames they stand for. ) vindex(userdirs) item(tt(userdirs))( This associative array maps user names to the pathnames of their home directories. ) vindex(funcstack) item(tt(funcstack))( This array contains the names of the functions currently being executed. The first element is the name of the function using the parameter. ) enditem()