mirror of https://github.com/ohmyzsh/ohmyzsh.git
Consistency in design and formatting update.
parent
4108a7c747
commit
d79aecedec
293
Design.md
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.
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue