Consistency in design and formatting update.

Khas'Mek 2015-05-31 08:28:30 -04:00
parent 4108a7c747
commit d79aecedec
1 changed files with 141 additions and 152 deletions

293
Design.md

@ -1,94 +1,89 @@
This page is a description of the current architecture and design of oh-my-zsh. This page is a description of the current architecture and design of oh-my-zsh.
This is a work in progress: we don't think there's anything outright wrong in it, but much may still be left out. This is a work in progress: we don't think there's anything outright wrong in it, but much may still be left out.
This page is not authoritative or normative: it was put together by oh-my-zsh users based on the current oh-my-zsh code; it's not a design document from the original oh-my-zsh authors. But it should serve as a useful guide to users and developers who want to get familiar with the oh-my-zsh codebase. This page is not authoritative or normative: it was put together by oh-my-zsh users based on the current oh-my-zsh code; it's not a design document from the original oh-my-zsh authors. But it should serve as a useful guide to users and developers who want to get familiar with the oh-my-zsh codebase.
## Overview
## Overview ##
What oh-my-zsh provides: What oh-my-zsh provides:
* Configuration of zsh itself, enabling advanced features - Configuration of zsh itself, enabling advanced features
* Theming - Theming
* Extra shell functionality & terse shortcuts - Extra shell functionality & terse shortcuts
* e.g. dir navigation - e.g. dir navigation
* Integration with third party programs and commands - Integration with third party programs and commands
* Completion, aliases, and auxiliary functions - Completion, aliases, and auxiliary functions
* Both OS-specific stuff and applications/utilities - Both OS-specific stuff and applications/utilities
* Auto-starting programs - Auto-starting programs
* e.g. the gpg-agent plugin - e.g. the gpg-agent plugin
It seems that plugins can get arbitrarily powerful and do whatever they want, so the user should understand what a given plugin does before enabling it. It seems that plugins can get arbitrarily powerful and do whatever they want, so the user should understand what a given plugin does before enabling it.
## Variables ## ## Variables
These are variables that base OMZ (excluding any plugins) uses. These are variables that base OMZ (excluding any plugins) uses. I've read through .oh-my-zsh so far, but not the lib/*.zsh files. More may be on the way.
I've read through .oh-my-zsh so far, but not the lib/*.zsh files. More may be on the way.
### Variables OMZ reads ### ### Variables OMZ reads
At initialization time: At initialization time:
In oh-my-zsh.sh: In oh-my-zsh.sh:
* `ZSH` - path to .oh-my-zsh (not zsh) installation - `ZSH` - path to .oh-my-zsh (not zsh) installation
* `plugins` - user-provided list of plugins to load - `plugins` - user-provided list of plugins to load
* `ZSH_CUSTOM` path to the oh-my-zsh (not zsh itself) customization dir - `ZSH_CUSTOM` path to the oh-my-zsh (not zsh itself) customization dir
* `ZSH_THEME` theme to load at startup - `ZSH_THEME` theme to load at startup
* `CASE_SENSITIVE` controls zsh completion matching - `CASE_SENSITIVE` controls zsh completion matching
* `COMPLETION_WAITING_DOTS` - `COMPLETION_WAITING_DOTS`
* `DISABLE_AUTO_UPDATE` ("true"/*) - `DISABLE_AUTO_UPDATE` ("true"/*)
* `DISABLE_AUTO_PROMPT` ("true"/*) - `DISABLE_AUTO_PROMPT` ("true"/*)
* `DISABLE_LS_COLORS` in lib/theme-and-appearance - `DISABLE_LS_COLORS` in lib/theme-and-appearance
* `ENABLE_CORRECTION` - `ENABLE_CORRECTION`
* `ZSH_CACHE_DIR` - `ZSH_CACHE_DIR`
* `ZSH_COMPDUMP` - `ZSH_COMPDUMP`
* `ZSH_THEME` - `ZSH_THEME`
* `ZSH_VERSION` - `ZSH_VERSION`
* `ZDOTDIR` - `ZDOTDIR`
* Standard Unix environment variables - Standard Unix environment variables
* `HOME` - `HOME`
* `HOST` - `HOST`
* `OSTYPE` - `OSTYPE`
The only required one is `$ZSH`. The rest either have defaults, or undef is fine and has an expected behavior. (Though if $plugins is unset, the git plugin won't get loaded. Will that break stuff?) The only required one is `$ZSH`. The rest either have defaults, or undef is fine and has an expected behavior. (Though if $plugins is unset, the git plugin won't get loaded. Will that break stuff?) All these `ZSH_*` variables are OMZ-specific, not standard `zsh` stuff. Except for `ZSH_VERSION`, which is a standard parameter provided by `zsh`.
All these `ZSH_*` variables are OMZ-specific, not standard `zsh` stuff. Except for `ZSH_VERSION`, which is a standard parameter provided by `zsh`.
### Variables OMZ provides or modifies
### Variables OMZ provides or modifies ###
In oh-my-zsh.sh: In oh-my-zsh.sh:
At init: At init:
* `SHORT_HOST` - `SHORT_HOST`
* `LSCOLORS` - `LSCOLORS`
* `SCREEN_NO` - `SCREEN_NO`
* `PS1` - `PS1`
* `POST_1_7_2_GIT` - `POST_1_7_2_GIT`
* `PAGER` - `PAGER`
* `LESS` - `LESS`
* `FX` special terminal control "effects" (reset/bold/no-bold/etc) - `FX` special terminal control "effects" (reset/bold/no-bold/etc)
* `FG` - `FG`
* `BG` - `BG`
At init (defaults if not provided): At init (defaults if not provided):
* `ZSH_CUSTOM` - defaults to `$ZSH/custom` - `ZSH_CUSTOM` - defaults to `$ZSH/custom`
* `ZSH_CACHE_DIR` - defaults to `$ZSH/cache` - `ZSH_CACHE_DIR` - defaults to `$ZSH/cache`
* `ZSH_COMPDUMP` - `ZSH_COMPDUMP`
* `ZSH_SPECTRUM_TEXT` - `ZSH_SPECTRUM_TEXT`
Modified at init: Modified at init:
* `fpath` - `fpath`
* `LC_CTYPE` - `LC_CTYPE`
Leaks: Leaks:
* `custom_config_file` - `custom_config_file`
### Variables plugins use
### Variables plugins use ### - `URLTOOLS_METHOD` - plugins/urltools uses it to manually select node/php/perl/python/etc
* `URLTOOLS_METHOD` - plugins/urltools uses it to manually select node/php/perl/python/etc
## Oh-My-Zsh Initialization ## ## Oh-My-Zsh Initialization ##
@ -96,64 +91,60 @@ Oh-my-zsh is initialized for the current `zsh` session by sourcing `$ZSH/oh-my-z
The basic steps of the oh-my-zsh initialization process are: The basic steps of the oh-my-zsh initialization process are:
* Check for updates - Check for updates
* Path defaulting - Path defaulting
* Load libs - Load libs
* Initialize completion system - Initialize completion system
* Load plugins - Load plugins
* Load custom user code - Load custom user code
* Load theme - Load theme
The initialization steps in detail: The initialization steps in detail:
* Check for updates - Check for updates
* Runs in a separate `zsh` process - Runs in a separate `zsh` process
* Does not load OMZ, so it's independent and doesn't use any OMZ files - Does not load OMZ, so it's independent and doesn't use any OMZ files
* Update `$fpath`: Add functions/ and completions/ - Update `$fpath`: Add functions/ and completions/
* (even though they don't exist in the current codebase) - (even though they don't exist in the current codebase)
* Set `$ZSH_CUSTOM` and `$ZSH_CACHE_DIR` - Set `$ZSH_CUSTOM` and `$ZSH_CACHE_DIR`
* Load lib ("config") files - Load lib ("config") files
* Discovers and sources all lib files, respecting custom overrides - Discovers and sources all lib files, respecting custom overrides
* Pre-load plugins (add to `$fpath`, but don't source) - Pre-load plugins (add to `$fpath`, but don't source)
* Set `$SHORT_HOST` - Set `$SHORT_HOST`
* Initialize Completion support - Initialize Completion support
* Set `$ZSH_COMPDUMP` - Set `$ZSH_COMPDUMP`
* Run `compinit`, using dump file - Run `compinit`, using dump file
* Load plugins - Load plugins
* Source each plugin specified in `$plugins` - Source each plugin specified in `$plugins`
* Load custom user code - Load custom user code
* Source each `$ZSH_CUSTOM/*.zsh` file - Source each `$ZSH_CUSTOM/*.zsh` file
* Load theme - Load theme
## Customization
## Customization ## In oh-my-zsh terms, _customization_ means adding or overriding zsh code, including its internals and implementation. It's not just a term for user-specified configuration.
In oh-my-zsh terms, "customization" means adding or overriding zsh code, including its internals and implementation. It's not just a term for user-specified configuration. Overriding internals can be done by adding `*.zsh` files to the `$ZSH_CUSTOM` root directory. All `*.zsh` files there will be sourced after OMZ loads and sources its own lib/* files. This allows you to redefine functions after the fact. (This will take place after any setup has called OMZ functions.) These are referred to as "config files" in oh-my-zsh.sh.
Overriding internals can be done by adding `*.zsh` files to the `$ZSH_CUSTOM` root directory. It's not documented in the _Customization_ page, but `$ZSH_CUSTOM/lib/*.zsh` do override the corresponding internals lib files. If a custom one is present, it is sourced instead of the one in the distribution.
All `*.zsh` files there will be sourced after OMZ loads and sources its own lib/* files. This allows you to redefine functions after the fact. (This will take place after any setup has called OMZ functions.)
These are referred to as "config files" in oh-my-zsh.sh.
It's not documented in the "Customization" page, but `$ZSH_CUSTOM/lib/*.zsh` do override the corresponding internals lib files. If a custom one is present, it is sourced instead of the one in the distribution.
So, you can: So, you can:
* Override plugins and themes on a per-plugin/theme basis (loaded instead of base) - Override plugins and themes on a per-plugin/theme basis (loaded instead of base)
* Override lib/* files on a per-file basis (loaded instead of equiv base file) - Override lib/* files on a per-file basis (loaded instead of equiv base file)
* Add arbitrary customization code that runs later and can redefine any function or variable - Add arbitrary customization code that runs later and can redefine any function or variable
`$ZSH_CUSTOM` controls where the custom override files are found; defaults to `$ZSH/custom` (under the main OMZ installation). `$ZSH_CUSTOM` controls where the custom override files are found; defaults to `$ZSH/custom` (under the main OMZ installation).
The [Customization] wiki page doesn't discuss which functions/APIs are stable. It mostly talks about overriding on a per-file basis. The [Customization](https://github.com/robbyrussell/oh-my-zsh/wiki/Customization) wiki page doesn't discuss which functions/APIs are stable. It mostly talks about overriding on a per-file basis.
## Plugins
## Plugins ##
Oh-my-zsh plugins extend the core functionality of oh-my-zsh. Oh-my-zsh plugins extend the core functionality of oh-my-zsh.
Plugins provide functionality in the following areas: Plugins provide functionality in the following areas:
* Completion definitions - Completion definitions
* Functions - Functions
* Aliases - Aliases
A "completion plugin" is the term for a plugin that has nothing but completion system definitions. They are not handled or loaded differently from other plugins. A "completion plugin" is the term for a plugin that has nothing but completion system definitions. They are not handled or loaded differently from other plugins.
@ -161,7 +152,7 @@ Plugins are optional, and selected at runtime. When oh-my-zsh is initialized, on
The plugins live in `plugins/` in the oh-my-zsh source tree. Even though their source code is in the main oh-my-zsh repository, each plugin has its own maintainer. The maintainers are listed on the [Plugins] page, or in the source code of the plugin. The plugins live in `plugins/` in the oh-my-zsh source tree. Even though their source code is in the main oh-my-zsh repository, each plugin has its own maintainer. The maintainers are listed on the [Plugins] page, or in the source code of the plugin.
## Themes ## ## Themes
Themes control the appearance of the `zsh` prompt, the appearnce of certain other programs, and some other behaviors, such as tab and window titles in terminal emulators. Themes control the appearance of the `zsh` prompt, the appearnce of certain other programs, and some other behaviors, such as tab and window titles in terminal emulators.
@ -170,56 +161,56 @@ OMZ turns on the `prompt_subst` shell option, and OMZ themes assume it is enable
Themes set a variety of variables to control the appearance of the zsh prompt. They may also install hook functions. These variables are read by core OMZ functions like `git_prompt_info()` and used to modify their behavior and style their output. Themes set a variety of variables to control the appearance of the zsh prompt. They may also install hook functions. These variables are read by core OMZ functions like `git_prompt_info()` and used to modify their behavior and style their output.
Things themes do: Things themes do:
* Set `$PROMPT`, `$RPROMPT`, and related variables - Set `$PROMPT`, `$RPROMPT`, and related variables
* Set `$LSCOLORS` and `$LS_COLORS` - Set `$LSCOLORS` and `$LS_COLORS`
* Define hook functions - Define hook functions
### Variables used by themes ### ### Variables used by themes
These variables are set by themes to control the prompt's appearance and other cosmetic behavior. These variables are set by themes to control the prompt's appearance and other cosmetic behavior.
* `PROMPT` - `PROMPT`
* `DEFAULT_USER` - `DEFAULT_USER`
`ZSH_THEME_SCM_PROMPT_PREFIX` used in `bzr_prompt_info()` from `lib/bzr.sh` - `ZSH_THEME_SCM_PROMPT_PREFIX` used in `bzr_prompt_info()` from `lib/bzr.sh`
git_prompt_info(): git_prompt_info():
* `ZSH_THEME_GIT_PROMPT_PREFIX` - `ZSH_THEME_GIT_PROMPT_PREFIX`
* `ZSH_THEME_GIT_PROMPT_SUFFIX` - `ZSH_THEME_GIT_PROMPT_SUFFIX`
* `ZSH_THEME_GIT_COMMITS_AHEAD_PREFIX` - `ZSH_THEME_GIT_COMMITS_AHEAD_PREFIX`
* `ZSH_THEME_GIT_COMMITS_AHEAD_SUFFIX` - `ZSH_THEME_GIT_COMMITS_AHEAD_SUFFIX`
* `ZSH_THEME_GIT_PROMPT_DIRTY` - `ZSH_THEME_GIT_PROMPT_DIRTY`
* `ZSH_THEME_GIT_PROMPT_CLEAN` - `ZSH_THEME_GIT_PROMPT_CLEAN`
* `ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE` - `ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE`
* `ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE` - `ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE`
* `ZSH_THEME_GIT_PROMPT_DIVERGED_REMOTE` - `ZSH_THEME_GIT_PROMPT_DIVERGED_REMOTE`
* `ZSH_THEME_GIT_PROMPT_AHEAD` - `ZSH_THEME_GIT_PROMPT_AHEAD`
* `ZSH_THEME_GIT_PROMPT_BEHIND` - `ZSH_THEME_GIT_PROMPT_BEHIND`
* `ZSH_THEME_GIT_PROMPT_SHA_BEFORE` - `ZSH_THEME_GIT_PROMPT_SHA_BEFORE`
* `ZSH_THEME_GIT_PROMPT_SHA_AFTER` - `ZSH_THEME_GIT_PROMPT_SHA_AFTER`
* `ZSH_THEME_GIT_PROMPT_ADDED` - `ZSH_THEME_GIT_PROMPT_ADDED`
* `ZSH_THEME_GIT_PROMPT_MODIFIED` - `ZSH_THEME_GIT_PROMPT_MODIFIED`
* `ZSH_THEME_GIT_PROMPT_RENAMED` - `ZSH_THEME_GIT_PROMPT_RENAMED`
* `ZSH_THEME_GIT_PROMPT_DELETED` - `ZSH_THEME_GIT_PROMPT_DELETED`
* `ZSH_THEME_GIT_PROMPT_STASHED` - `ZSH_THEME_GIT_PROMPT_STASHED`
* `ZSH_THEME_GIT_PROMPT_UNMERGED` - `ZSH_THEME_GIT_PROMPT_UNMERGED`
* `ZSH_THEME_GIT_PROMPT_DIVERGED` - `ZSH_THEME_GIT_PROMPT_DIVERGED`
* `ZSH_THEME_GIT_PROMPT_UNTRACKED` - `ZSH_THEME_GIT_PROMPT_UNTRACKED`
nvm_prompt_info(): nvm_prompt_info():
* `ZSH_THEME_NVM_PROMPT_PREFIX` - `ZSH_THEME_NVM_PROMPT_PREFIX`
* `ZSH_THEME_NVM_PROMPT_SUFFIX` - `ZSH_THEME_NVM_PROMPT_SUFFIX`
rvm_prompt_info(): rvm_prompt_info():
* `ZSH_THEME_RVM_PROMPT_PREFIX` - `ZSH_THEME_RVM_PROMPT_PREFIX`
* `ZSH_THEME_RVM_PROMPT_SUFFIX` - `ZSH_THEME_RVM_PROMPT_SUFFIX`
* `ZSH_THEME_RVM_PROMPT_OPTIONS` - `ZSH_THEME_RVM_PROMPT_OPTIONS`
lib/termsupport.zsh: lib/termsupport.zsh:
* `ZSH_THEME_TERM_TAB_TITLE_IDLE` - `ZSH_THEME_TERM_TAB_TITLE_IDLE`
* `ZSH_THEME_TERM_TITLE_IDLE` - `ZSH_THEME_TERM_TITLE_IDLE`
* `chpwd_functions` - `chpwd_functions`
* `precmd_functions` - `precmd_functions`
Not all themes use all of these variables. Most use only a subset. Not all themes use all of these variables. Most use only a subset.
@ -228,18 +219,18 @@ Other `ZSH_THEME_*` variables may be used by different themes and plugins. The p
Some per-theme custom variables: Some per-theme custom variables:
In bureau.zsh-theme: In bureau.zsh-theme:
* `ZSH_THEME_GIT_PROMPT_STAGED` - `ZSH_THEME_GIT_PROMPT_STAGED`
* `ZSH_THEME_GIT_PROMPT_UNSTAGED` - `ZSH_THEME_GIT_PROMPT_UNSTAGED`
* `ZSH_THEME_GIT_PROMPT_UNTRACKED` - `ZSH_THEME_GIT_PROMPT_UNTRACKED`
These variables are mostly used in prompt info functions. To use them to customize a theme's prompt, the theme should set the various `ZSH_THEME_*` variables to contain text that will get interpolated in at the appropriate spots. And then put one or more of these output-capturing function calls inside the `PROMPT` variable, if you are defining a custom `PROMPT`: These variables are mostly used in prompt info functions. To use them to customize a theme's prompt, the theme should set the various `ZSH_THEME_*` variables to contain text that will get interpolated in at the appropriate spots. And then put one or more of these output-capturing function calls inside the `PROMPT` variable, if you are defining a custom `PROMPT`:
```
$(git_prompt_info) - $(git_prompt_info)
$(bzr_prompt_info) - $(bzr_prompt_info)
$(nvm_prompt_info) - $(nvm_prompt_info)
$(rvm_prompt_info) - $(rvm_prompt_info)
$(ruby_prompt_info) - $(ruby_prompt_info)
```
Or use other `*_prompt_info` functions that plugns define. These `prompt_info` functions have dummy implementations (in `lib/prompt_info_functions.zsh`) so they can be used unconditionally in theme prompts and will gracefully degrade to outputting empty strings if the appropriate plugin is not actually loaded. Or use other `*_prompt_info` functions that plugns define. These `prompt_info` functions have dummy implementations (in `lib/prompt_info_functions.zsh`) so they can be used unconditionally in theme prompts and will gracefully degrade to outputting empty strings if the appropriate plugin is not actually loaded.
The oh-my-zsh prompt construction functions (found inside `lib/`) send their output to `stdout`, and are designed to be called with the `$(...)` output-capturing subshell invocation. The oh-my-zsh prompt construction functions (found inside `lib/`) send their output to `stdout`, and are designed to be called with the `$(...)` output-capturing subshell invocation.
@ -250,14 +241,12 @@ Some themes may define additional functions, and set `precmd` or `chpwd` hooks.
Although some existing themes set `$chpwd` or `$precmd`, it's probably better for themes to add functions to the `$chpwd_functions` or `$precmd_functions` lists, to avoid conflicting with other code that may also want to set hooks. Although some existing themes set `$chpwd` or `$precmd`, it's probably better for themes to add functions to the `$chpwd_functions` or `$precmd_functions` lists, to avoid conflicting with other code that may also want to set hooks.
### Loading themes ### ### Loading themes
The oh-my-zsh theme mechanism is designed to load a theme once per session, during OMZ initialization. The oh-my-zsh theme mechanism is designed to load a theme once per session, during OMZ initialization.
The theme mechanism does not provide a way to unload themes. The values for `PROMPT`, `RPROMPT`, `ZSH_THEME_*`, and hooks do not get reset. Thus, you can hack in support for switching themes during a session, but it is not clean: when you switch themes, you can get leftover settings from previously loaded themes and end up with a combination of themes. The theme mechanism does not provide a way to unload themes. The values for `PROMPT`, `RPROMPT`, `ZSH_THEME_*`, and hooks do not get reset. Thus, you can hack in support for switching themes during a session, but it is not clean: when you switch themes, you can get leftover settings from previously loaded themes and end up with a combination of themes.
## Miscellaneous Architecture Stuff ## ## Miscellaneous Architecture Information
Plugins or other files that need to locate where they're running from should use `${0:h}` instead of a path relative to `$ZSH`, so they properly find themselves when running from the `$ZSH_CUSTOM` directory or if their plugin name changes. Plugins or other files that need to locate where they're running from should use `${0:h}` instead of a path relative to `$ZSH`, so they properly find themselves when running from the `$ZSH_CUSTOM` directory or if their plugin name changes.