123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- *pi_health.txt* Healthcheck framework
- Author: TJ DeVries <devries.timothyj@gmail.com>
- Type |gO| to see the table of contents.
- ==============================================================================
- Introduction *health*
- health.vim is a minimal framework to help with troubleshooting user
- configuration. Nvim ships with healthchecks for configuration, performance,
- python support, ruby support, clipboard support, and more.
- To run the healthchecks, use this command: >
- :checkhealth
- <
- Plugin authors are encouraged to write new healthchecks. |health-dev|
- ==============================================================================
- Commands *health-commands*
- *:checkhealth* *:CheckHealth*
- :checkhealth Run all healthchecks.
- *E5009*
- Nvim depends on |$VIMRUNTIME| and 'runtimepath' to find
- the standard "runtime files" for syntax highlighting,
- filetype-specific behavior, and standard plugins
- (including :checkhealth). If the runtime files cannot
- be found then those features will not work.
- :checkhealth {plugins}
- Run healthcheck(s) for one or more plugins. E.g. to run
- only the standard Nvim healthcheck: >
- :checkhealth nvim
- < To run the healthchecks for the "foo" and "bar" plugins
- (assuming these plugins are on your 'runtimepath' and
- they have implemented health#foo#check() and
- health#bar#check(), respectively): >
- :checkhealth foo bar
- <
- ==============================================================================
- Functions *health-functions*
- health.vim functions are for creating new healthchecks. They mostly just do
- some layout and formatting, to give users a consistent presentation.
- health#report_start({name}) *health#report_start*
- Starts a new report. Most plugins should call this only once, but if
- you want different sections to appear in your report, call this once
- per section.
- health#report_info({msg}) *health#report_info*
- Reports an informational message.
- health#report_ok({msg}) *health#report_ok*
- Reports a "success" message.
- health#report_warn({msg}, [{advice}]) *health#report_warn*
- Reports a warning. {advice} is an optional List of suggestions.
- health#report_error({msg}, [{advice}]) *health#report_error*
- Reports an error. {advice} is an optional List of suggestions.
- health#{plugin}#check() *health.user_checker*
- Healthcheck function for {plugin}. Called by |:checkhealth|
- automatically. Example: >
- function! health#my_plug#check() abort
- silent call s:check_environment_vars()
- silent call s:check_python_configuration()
- endfunction
- <
- All output will be captured from the healthcheck. Use the
- health#report_* functions so that your healthcheck has a format
- consistent with the standard healthchecks.
- ==============================================================================
- Create a healthcheck *health-dev*
- Healthchecks are functions that check the user environment, configuration,
- etc. Nvim has built-in healthchecks in $VIMRUNTIME/autoload/health/.
- To add a new healthcheck for your own plugin, simply define a
- health#{plugin}#check() function in autoload/health/{plugin}.vim.
- |:checkhealth| automatically finds and invokes such functions.
- If your plugin is named "foo", then its healthcheck function must be >
- health#foo#check()
- defined in this file on 'runtimepath': >
- autoload/health/foo.vim
- Copy this sample code into autoload/health/foo.vim and replace "foo" with your
- plugin name: >
- function! health#foo#check() abort
- call health#report_start('sanity checks')
- " perform arbitrary checks
- " ...
- if looks_good
- call health#report_ok('found required dependencies')
- else
- call health#report_error('cannot find foo',
- \ ['npm install --save foo'])
- endif
- endfunction
- ==============================================================================
- vim:tw=78:ts=8:ft=help:fdm=marker
|