Custom Themes
Defining a Theme
A theme should be contained in one file with a .theme
file suffix. There
should be no “top level” code in the file, or in other words, all code should be
contained in functions. Sourcing the file should run no code, as a user sourcing
the theme file might not want to activate it yet.
Prompt Function
Every theme must have a prompt function that is called for every prompt to
generate the prompt. It must be set to _lp_<theme_id>_theme_prompt()
.
This function could do anything, but generally it should generate a prompt and
store it in PS1
.
Directory Function
Optionally, a theme can have a directory function. It must be set to
_lp_<theme_id>_theme_directory()
.
This function is called every time the user changes directories. This allows the theme to only run generating code that depends on the current directory when it is needed.
Activate Function
Optionally, a theme can have an activate function. It must be set to
_lp_<theme_id>_theme_activate()
.
This function is called when the theme is first activated, and every time the
user runs lp_activate()
. Prompt pieces that never change (such as hostname
and username) should be generated here. This is also where the theme’s default
values should be set. This function will always be called after the user config
is already loaded.
Version Check Function
Optionally, a theme can have a Liquid Prompt version check function. It must be
set to _lp_<theme_id>_theme_version_check()
.
This function is called when the theme is first activated. It is used to
validate that the version of Liquid Prompt is equal to or greater than what the
theme requires. Liquid Prompt handles the checking and error handling. Simply
set the array variable lp_version_check
with the version your theme
requires:
_lp_custom_theme_version_check() {
lp_version_check=(2 2 0 rc 3)
}
The format of the lp_version_check
variable matches the inputs of the
_lp_version_greatereq()
function.
A theme can support more than one version of Liquid Prompt by only enabling parts of the theme if the Liquid Prompt version is high enough. For example:
if _lp_version_greatereq 2 2 0 ; then
if _lp_disk ; then
PS1+="my disk status: $lp_disk"
fi
fi
Other Functions
If a theme is moderately complicated, it will need other functions defined to help generate a prompt. These should be named following the Functions guidelines concerning underscore prefixes.
The prefix of a function should always be either _<theme_id>_
or
_lp_<theme_id>_
to prevent overwriting functions already defined by the
user.
Getting Data
A theme must call Data Functions to be able to display useful information to the user. A theme might also need to use Utility Functions to process that data.
Examples
The Alternate VCS Details Theme is a good example of creating a theme based on the default theme.
The Powerline Theme is a good example of creating a detailed theme.