If you are willing to contribute, thanks!
This project is written in OCaml, so you need to be able to compile such programs. The official website ocaml.org provides explanation on getting started with OCaml.
Once you have opam, and a switch ready, install the dependencies with:
opam install . --deps-only --with-dev-setup --with-test
Then, build with
dune build
You can run the version you just built with
dune exec slipshow -- <other options>
The directory structure is the following:
docs/
for the readthedocs documentationdocs/odoc/
for the doc build byodoc
and served on ocaml.org
example/
for ... examples (to be kept up to date?! Is that going to make the repo big? TODO: add a dune rule for that)release/
for scripts used in the release processtest/
for testsvendor/
for vendored library, see the vendoring section of this documentsrc/
for the source:src/engine/
contains the code for the engine, the part translated to javascript that is run during a presentation, and that is responsible for reacting to the user's input etc.src/engine/themes/
contains the CSS themes.
src/cli/
contains the code for the CLI parsing (using cmdliner) and calling the right entry point (preview server, compiler, ...)src/static_data/
contains static data such as highlightjs code to embed in a presentation.src/server/
contains the code for the preview serversrc/server/client/
contains the code for the client-side javascript of the preview server
src/communication/
contains the types and utilities to serialize and deserialize data exchanged between server and client.src/previewer/
contains the code for the previewer panel (used by slipshow's preview mode but also sliphub, the VSCode extension, ...)
In order to release a new version, you need to:
Do that! And write the tag in the changelog! And commit and push!
First, fix #91 Then, update softprops/action-gh-release@v1 to create a draft release instead of directly a release.
- Write the binary release announcement (in the changelog)
- Call
dune-release tag --dry-run
to check - Call
dune-release tag
to do the tag - Push the tag
- Rewrite the binary release announcement if needed
- Check that readthedocs has picked up the new tag on stable
- Checkout the branch which has the tag
- Call
dune-release distrib
- Call
dune-release publish distrib --draft
// A release already has been created. I don't know if this command allows a tag to have already been pushed/a release already been created. An alternative is to add using the GUI the asset (eg_build/slipshow-0.1.0.tbz
). Use the--dry-run
flag to be sure - Call
dune-release opam pkg
It seems that there is some discrepencies between the release created by the CI (which has a leadingv
) and the one dune release expect to have been created (by itself). So, there might be a need to update the url. - Call
dune-release opam submit
- Verify that everything is right by comparing the
opam
file for the previous version, with this one!
dune install
the last release of slipshow.
Update the version on gui/slipshow-gui/src-tauri/tauri.conf.json
(and maybe gui/slipshow-gui/package.json
)
sliphub$ dune build
sliphub$ cd gui/slipshow-gui
sliphub$ npm run tauri dev # To test
Git commit and push. This will create a draft release. Finish it and undraft it.
Publish on vscode official repo
slipshow-vscode$ dune build
slipshow-vscode$ vsce package
slipshow-vscode$ vsce publish patch # (or minor, major)
Publish on open-vsx: connect to open-vsx, login and manually publish the new vsix.
TODO
Slipshow vendors a few modified dependencies. Currently it uses git-vendor.
-
To add a new dependency, use
git vendor add <name> <repo> <ref>
. For instance:git vendor add brr [email protected]:panglesd/brr.git slipshow-vendor
-
To update a dependency, use
git vendor update <name> <ref>
. For instance:git vendor update cmarkit markdown-attributes
-
To upstream local changes to a dependency, use
git vendor upstream <name> <ref>
. For instance:git vendor upstream cmarkit markdown-attributes