vitepressify, a green rectangle behind a black rectangle that has the markdown logo on top in white

vitepressify

Convert Crystal docs into VitePress


Code Of Conduct BSD-2-Clause ci action status

What is vitepressify?

Crystal docs are awesome, but sometimes you need more control over them.

vitepressify generates a VitePress project with paegs from your local or remote Crystal docs.

Screenshot of VitePress docs of Crystal-lang api docs. Screenshot is split diagonally showcasing both dark and light themes.

Installation

Pre-built

You can download one of the statically-linked pre-built binaries from the releases page.

They are built & published by our lovely actions.

Building

Dependencies

Manually

$ shards build --production --no-debug --release

Usage

Vitepressify v1.0.0
Usage:
    vitepressify [arguments]
Examples:
    vitepressify -i ./docs/index.json
    vitepressify -i https://crystal-lang.org/api/1.5.0/ -t 1.5.0
    vitepressify -i https://geopjr.github.io/gettext.cr/index.json -u ./vitepressify-docs

Arguments:
    -i INDEX, --index=INDEX          index.json location. Can be either a local path or a url (e.g. https://libadwaita.geopjr.dev/docs/). Default: ./docs/index.json
    -t TAG, --tag=TAG                Current release/tag (e.g. 1.0.0). Default: main
    -u FOLDER, --update=FOLDER       Instead of generating a new project, it attempts to update the one at FOLDER.
    -l, --license                    Show the LICENSE
    -h, --help                       Show this help

Example

If you wanted for example to build a VitePress project using the Crystal API docs from 1.4.0 to 1.5.1, all you have to do is:

$ vitepressify -i https://crystal-lang.org/api/1.5.1/ -t 1.5.1

This will generate the project in a random named folder, for example vitepress-ujqywe.

$ vitepressify -i https://crystal-lang.org/api/1.5.0/ -t 1.5.0 -u ./vitepress-ujqywe/

$ vitepressify -i https://crystal-lang.org/api/1.4.1/ -t 1.4.1 -u ./vitepress-ujqywe/

$ vitepressify -i https://crystal-lang.org/api/1.4.0/ -t 1.4.0 -u ./vitepress-ujqywe/

Contributing

  1. Read the Code of Conduct
  2. Fork it (https://github.com/GeopJr/vitepressify/fork)
  3. Create your feature branch (git checkout -b my-new-feature)
  4. Commit your changes (git commit -am 'Add some feature')
  5. Push to the branch (git push origin my-new-feature)
  6. Create a new Pull Request

Sponsors

GeopJr Sponsors