4.0 KiB
Bash-it Development
This page summarizes a couple of rules to keep in mind when developing features or making changes in Bash-it.
Debugging and Logging
General Logging
While developing feature or making changes in general, you can log error/warning/debug
using _log_error _log_warning and _log_debug. This will help you solve problems quicker
and also propagate important notes to other users of Bash-it.
You can see the logs by using bash-it doctor command to reload and see the logs.
Alternatively, you can set BASH_IT_LOG_LEVEL to BASH_IT_LOG_LEVEL_ERROR, BASH_IT_LOG_LEVEL_WARNING or BASH_IT_LOG_LEVEL_ALL.
Log Prefix/Context
You can define BASH_IT_LOG_PREFIX in your files in order to a have a constant prefix before your logs.
Note that we prefer to uses "tags" based logging, i.e plugins: git: DEBUG: Loading git plugin.
Load Order
General Load Order
The main bash_it.sh script loads the frameworks individual components in the following order:
lib/composure.bash- Files in
libwith the exception ofappearance.bash- this means thatcomposure.bashis loaded again here (possible improvement?) - Enabled
aliases - Enabled
plugins - Enabled
completions themes/colors.theme.bashthemes/base.theme.bashlib/appearance.bash, which loads the selected theme- Custom
aliases - Custom
plugins - Custom
completions - Additional custom files from either
$BASH_IT/customor$BASH_IT_CUSTOM
This order is subject to change.
Individual Component Load Order
For aliases, plugins and completions, the following rules are applied that influence the load order:
-
There is a global
enableddirectory, which the enabled components are linked into. Enabled plugins are symlinked from$BASH_IT/plugins/availableto$BASH_IT/enabledfor example. All component types are linked into the same common$BASH_IT/enableddirectory. -
Within the common
enableddirectories, the files are loaded in alphabetical order, which is based on the item's load priority (see next item). -
When enabling a component, a load priority is assigned to the file. The following default priorities are used:
- Aliases: 150
- Plugins: 250
- Completions: 350
-
When symlinking a component into the
enableddirectory, the load priority is used as a prefix for the linked name, separated with three dashes from the name of the component. Thenode.plugin.bashwould be symlinked to250---node.plugin.bashfor example. -
Each file can override the default load priority by specifying a new value. To do this, the file needs to include a comment in the following form. This example would cause the
node.plugin.bash(if included in that file) to be linked to225---node.plugin.bash:# BASH_IT_LOAD_PRIORITY: 225
Having the order based on a numeric priority in a common directory allows for more flexibility. While in general, aliases are loaded first (since their default priority is 150), it's possible to load some aliases after the plugins, or some plugins after completions by setting the items' load priority. This is more flexible than a fixed type-based order or a strict alphabetical order based on name.
These items are subject to change. When making changes to the internal functionality, this page needs to be updated as well.
Plugin Disable Callbacks
Plugins can define a function that will be called when the plugin is being disabled.
The callback name should be {PLUGIN_NAME}_on_disable, you can see gitstatus for usage example.
Using the pre-commit hook
Note the file .pre-commit-config.yaml at the top of the repo.
This file configures the behavior of the a pre-commit hook based on the Pre-Commit framework. Please see the site about
installing it (with pip, brew or other tools) then run pre-commit install in the repo's root to activate the hook.
For the full use of the tool, you may need to install also other third-party tools, such as
shellcheck and shfmt.