mirror-zola/CONTRIBUTING.md

3.1 KiB

Contributing

As the documentation site is automatically built on commits to master, all development happens on the next branch, unless it is fixing the current documentation.

However, if you notice an error or typo in the documentation, feel free to directly submit a PR without opening an issue.

Feature requests

If you want a feature added or modified, please open a thread on the forum to discuss it before doing a PR.

Requested features will not be all added: an ever-increasing features set makes for a hard to use and explain softwares. Having something simple and easy to use for 90% of the usecases is more interesting than covering 100% usecases after sacrificing simplicity.

Issues tagging

As the development happens on the next branch, issues are kept open until a release containing the fix is out. During that time, issues already resolved will have a done tag.

If you want to work on an issue, please mention it in a comment to avoid potential duplication of work. If you have any questions on how to approach it do not hesitate to ping me (@keats). Easy issues are tagged with help wanted and/or good first issue

Adding syntax highlighting languages and themes

Adding a syntax

Syntax highlighting depends on submodules so ensure you load them first:

$ git submodule update --init

Zola only works with syntaxes in the .sublime-syntax format. If your syntax is in .tmLanguage format, open it in Sublime Text and convert it to sublime-syntax by clicking on Tools > Developer > New Syntax from ... and put it in the sublime/syntaxes directory.

You can also add a submodule to the repository of the wanted syntax:

$ cd sublime/syntaxes/extra
$ git submodule add https://github.com/elm-community/SublimeElmLanguageSupport

Note that you can also only copy manually the updated syntax definition file but this means Zola won't be able to automatically update it.

You can check for any updates to the current packages by running:

$ git submodule update --remote --merge

And finally from the root of the components/config crate run the following command:

$ cargo run --example generate_sublime synpack ../../sublime/syntaxes ../../sublime/syntaxes/newlines.packdump

Adding a theme

A gallery containing lots of themes is located at https://tmtheme-editor.glitch.me/#!/editor/theme/Solarized%20(light). More themes can be easily added to Zola, just make a PR with the wanted theme added in the sublime/themes directory.

If you want to test Zola with a new theme, it needs to be built into the syntect file all.themedump.

First build the tool to generate the syntect file:

$ git clone https://github.com/getzola/zola.git && cd zola/components/config
$ cargo build --example generate_sublime

copy your theme in sublime/themes/, then regenerate the syntect file:

$ ./target/debug/examples/generate_sublime themepack sublime/themes/ sublime/themes/all.themedump

You should see the list of themes being added.

To test your new theme, rebuild Zola with cargo build.