vim-tools - Python scripts to publish Vim plug-ins

I’m a programmer which naturally means I hate performing repetitive tasks… Publishing my Vim plug-ins quickly turned out to fall in this category; I’d keep making the same mistakes and having users e-mail me because I screwed up again and uploaded a broken release to After a while this got embarrassing so I decided to solve this annoying problem once and for all.

Things started out small but as my existing Vim plug-ins mature and I publish more Vim plug-ins to the world, the vim-tools repository grows with me. It now contains several Python modules which can be useful to other people (mostly Vim plug-in developers) which is why I’m sharing it with the world.

# html2vimdoc

The Python module converts Markdown and HTML documents to Vim help files.

# Features

# Usage

It has a command line interface but can also be used as a plain Python module.

# Dependencies

The module has several dependencies, the easiest way to install them is in a Python virtual environment:

# Clone the repository
git clone
cd vim-tools
# Create the virtual environment.
virtualenv html2vimdoc
# Install the dependencies.
html2vimdoc/bin/pip install beautifulsoup coloredlogs markdown
# Run the program.
html2vimdoc/bin/python ./ --help

# How I use it

I use this module to convert my Vim plug-in files and the Lua, LPeg and Lua/APR manuals to Vim’s help file format. Here’s my workflow involving the documentation of my Vim plug-ins:

# vimdoctool

The Python module extracts the public functions and related comments (assumed to contain text in Markdown format) from the Vim scripts in and/or below the current working directory. The extracted documentation is combined into one chunk of text and then this chunk of text is embedded in the Markdown document given on the command line.

I use this module to publish the documentation of my vim-misc scripts.

# Dependencies

This module has a dependency on my coloredlogs module which is available on PyPi (the Python package index).

# vim-plugin-manager

This program (written in Python) makes it easier for me to publish my Vim plug-ins on GitHub and Vim Online. It automates most of my release management, here’s a short summary:

It might be a bit specific to my workflow but you never know, someone might find it useful :-)

# Contact

If you have questions, bug reports, suggestions, etc. the author can be contacted at The latest version is available at and

# License

This software is licensed under the MIT license.
© 2013 Peter Odding <>.

The module bundles by Simon Willison. The soupselect module is also licensed under the MIT license. You can find the soupselect module on GitHub and Google Code.

Last updated Wed Apr 01 21:09:12 UTC 2015.