Skip to content

Commit

Permalink
docs: moved documentation to use 'mdbook'
Browse files Browse the repository at this point in the history
  • Loading branch information
MrHedmad committed Feb 18, 2024
1 parent f08514f commit 7491d67
Show file tree
Hide file tree
Showing 25 changed files with 801 additions and 603 deletions.
File renamed without changes.
89 changes: 20 additions & 69 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,28 +9,28 @@

</div>

> [!WARNING]
>
> Kerblam! is still unreleased. Expect some bugs, glitches or breaking changes.
> Always have a backup of your data and code!
> Report any problems in the [issues](https://github.com/MrHedmad/kerblam).
> Thank you for using Kerblam!
<div align="center">

[🚀 Read the full Kerblam Documentation 🚀](https://kerblam.dev)

</div>

Kerblam! is a tool that can help you manage data analysis projects.

A Kerblam! project has a `kerblam.toml` file in its root.
Kerblam! then allows you to:
- Manage and run multiple makefiles or shellfiles for different tasks;
- Manage containers and run code in them for you.
- Create reproducible containers to replay your work or share it with others;
- Access remote data quickly, by just specifying URLs to fetch from;
- Specify test or alternative data and quickly use it instead of real data.
- Package and export data in order to share the project with colleagues;
- Manage and run multiple makefiles or shellfiles for different tasks;
- Clean up intermediate and output files quickly;
- Manage containers and run code in them for you.
- Manage the content of your `.gitignore` for you, allowing to add files,
directories and even whole languages in one command.
- Specify test or alternative data and quickly use it instead of real data.

To transform a project to a Kerblam! project just make the kerblam.toml
file yourself. To learn how, look at the section below.
To transform a project to a Kerblam! project you can just make the `kerblam.toml`
file yourself. [Read the documentation to learn how](https://kerblam.dev/)

<div align="center">

Expand Down Expand Up @@ -86,7 +86,7 @@ Kerblam! is *not* and does not want to be:
Kerblam! projects are opinionated:
- The folder structure of your project adheres to the Kerblam! standard,
although you may configure it in `kerblam.toml`.
Read about it below.
Read more about it [here](https://kerblam.dev/quickstart.md)
- You use `make` or bash scripts as your pipeline manager.
- Kerblam! natively uses `make`, but nothing stops you writing
shell files that execute other tools, like `snakemake`.
Expand All @@ -104,74 +104,25 @@ If you don't like this setup, Kerblam! is probably not for you.
> take a look at [the kerblam! philosophy](docs/philosophy.md).
### Folder structure
Kerblam!, by default, requires the following folder structure (relative to the
location of the `kerblam.toml` file):
- `./kerblam.toml`: This file contains the options for Kerblam!. It is often empty.
- `./data/`: This is a directory for the data. Intermediate data files are saved here.
- `./data/in/`: Input data files are saved and should be looked for here.
- `./data/out/`: Output data files are saved and should be looked for here.
- `./src/`: Code you want to be executed should be saved here.
- `./src/pipes/`: Makefiles and bash build scripts should be saved here.
They have to be written as if they were saved in `./`.
- `./src/dockerfiles/`: Container build scripts should be saved here.

You can configure almost all of these paths in `kerblam.toml`, if you so desire.
This is mostly done for compatibility reasons with non-kerblam! projects.
New projects that wish to use Kerblam! are strongly encouraged to follow the
standard folder structure, however.

## Documentation
The full Kerblam! documentation is in the [`/docs` folder](docs/README.md).
The full Kerblam! documentation is online at [kerblam.dev](https://kerblam.dev).
Please take a look there for more information on what Kerblam! can do.
For example, you might find [the tutorial](docs/tutorial.md) interesting.
For example, you might find [the tutorial](https://kerblam.dev/quickstart.html) interesting.

## Installation
Currently, Kerblam! only supports mac OS (both intel and apple chips) and GNU linux.
Other unix/linux versions may work. Install them from source with the commands below.

### Requirements
Kerblam! requires a Linux (or generally unix-like) OS.
It also uses binaries that it assumes are already installed:
- GNU `make`: https://www.gnu.org/software/make/
- `git`: https://git-scm.com/
- Docker (as `docker`) and/or Podman (as `podman`): https://www.docker.com/ and https://podman.io/
- `tar`.

If you can use `git`, `make`, `tar` and `docker` or `podman` from your CLI, you should be good.

### Pre-compiled binary (recommended)
You can find and download a Kerblam! binary for your operating system in
[the releases tab](https://github.com/mrhedmad/kerblam/releases).

There are also helpful scripts that automatically download the correct version
for your specific operating system thanks to [`cargo-dist`](https://github.com/axodotdev/cargo-dist).
You can always install or update to the latest version with:

[✨ Read the full installation guide in the docs ✨](https://kerblam.dev/install.html)

In short, either:
```bash
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/MrHedmad/kerblam/releases/latest/download/kerblam-installer.sh | sh
```
You can [click here](https://github.com/MrHedmad/kerblam/releases/latest/download/kerblam-installer.sh)
to download the same installer script and inspect it before you run it, if you'd like.

### Install from source
If you want to install the latest version from source, install Rust and `cargo`, then run:
or, alternatively
```bash
cargo install kerblam
```
If you wish to instead use the latest development version, run:
```bash
cargo install --git https://github.com/MrHedmad/kerblam.git
```
The `main` branch should always compile on supported platforms with the above command.
If it does not, please [open an issue](https://github.com/mrhedmad/kerblam/issues/new).

## Adding the Kerblam! badge
You can add a Kerblam! badge in the README of your project to show that you use Kerblam!
Just copy the following code and add it to the README:
```markdown
![Kerblam!](https://img.shields.io/badge/Kerblam!-v0.4.0-blue?logo=&link=https%3A%2F%2Fgithub.com%2FMrHedmad%2Fkerblam)
```
> [!WARNING]
> The code is very long - this is because the Kerblam! logo is baked in as a `base64` image.
You will need `git`, `make`, `tar` and `docker` or `podman` installed.

## Contributing
To contribute, please take a look at [the contributing guide](docs/CONTRIBUTING.md).
Expand Down
1 change: 1 addition & 0 deletions docs/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
book
6 changes: 6 additions & 0 deletions docs/book.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[book]
authors = ["Luca Visentin"]
language = "en"
multilingual = false
src = "src"
title = "Kerblam Docs"
28 changes: 28 additions & 0 deletions docs/src/SUMMARY.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# Summary

[Introduction](introduction.md)

- [Installation](install.md)

# Tutorial
- [Quickstart](quickstart.md)
- [Creating new projects](tutorial/new.md)
- [Pipelines](tutorial/pipelines.md)
- [Running pipelines](tutorial/run.md)
- [Containerized Execution of Pipelines](tutorial/run_containers.md)
- [Describing pipelines](tutorial/pipe_docstrings.md)
- [Packaging pipelines for later](tutorial/package_pipes.md)
- [Managing Data](tutorial/intro_data.md)
- [Fetching remote data](tutorial/fetch_data.md)
- [Package and distribute data](tutorial/package_data.md)
- [Cleanup data](tutorial/data_clean.md)
- [Other utilities](tutorial/utils.md)
- [Getting help](tutorial/get_help.md)
- [Usage examples](tutorial/examples.md)

# Reference
- [The `kerblam.toml` file](kerblam.toml.md)

# For Developers
- [Contributing to Kerblam!](dev/contributing.md)
- [The Kerblam! philosophy](philosophy.md)
6 changes: 6 additions & 0 deletions docs/src/dev/contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Contributing to Kerblam!

Thank you for wanting to contribute!

The developer guide changes more often than this book, so you can
[read it directly on Github](https://github.com/MrHedmad/kerblam/blob/main/CONTRIBUTING.md).
57 changes: 57 additions & 0 deletions docs/src/install.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
# Installation

You have a few options when installing Kerblam!

Currently, Kerblam! only supports mac OS (both intel and apple chips) and GNU linux.
Other unix/linux versions may work. Install them from source with the commands below.

### Requirements
Kerblam! requires a Linux (or generally unix-like) OS.
It also uses binaries that it assumes are already installed:
- GNU `make`: [gnu.org/software/make](https://gnu.org/software/make);
- `git`: [git-scm.com](https://git-scm.com/)
- Docker (as `docker`) and/or Podman (as `podman`):
[docker.com](https://docker.com/) and/or [podman.io](https://podman.io);
- `tar`: [gnu.org/software/tar](https://www.gnu.org/software/tar/).

If you can use `git`, `make`, `tar` and `docker` or `podman` from your CLI,
you're good to go!

Most if not all of these tools come pre-packaged in most linux distros.
Check your repositories for them.

### Pre-compiled binary (recommended)
You can find and download a Kerblam! binary for your operating system in
[the releases tab](https://github.com/mrhedmad/kerblam/releases).

There are also helpful scripts that automatically download the correct version
for your specific operating system thanks to [`cargo-dist`](https://github.com/axodotdev/cargo-dist).
You can always install or update to the latest version with:
```bash
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/MrHedmad/kerblam/releases/latest/download/kerblam-installer.sh | sh
```
You can [click here](https://github.com/MrHedmad/kerblam/releases/latest/download/kerblam-installer.sh)
to download the same installer script and inspect it before you run it, if you'd like.

### Install from source
If you want to install the latest version from source, install Rust and `cargo`, then run:
```bash
cargo install kerblam
```
If you wish to instead use the latest development version, run:
```bash
cargo install --git https://github.com/MrHedmad/kerblam.git
```
The `main` branch should always compile on supported platforms with the above command.
If it does not, please [open an issue](https://github.com/mrhedmad/kerblam/issues/new).

## Adding the Kerblam! badge
You can add a Kerblam! badge in the README of your project to show that you use Kerblam!
Just copy the following code and add it to the README:
```markdown
![Kerblam!](https://img.shields.io/badge/Kerblam!-v0.5.1-blue?logo=&link=https%3A%2F%2Fgithub.com%2FMrHedmad%2Fkerblam)
```

The above link is very long - this is because the Kerblam! logo is baked in as a `base64` image.
You can update the badge's version by directly editing the link (e.g. change
`v0.5.1` to `v0.4.0`) manually.
45 changes: 45 additions & 0 deletions docs/src/introduction.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@

![If you want it, Kerblam it!](https://raw.githubusercontent.com/MrHedmad/kerblam/main/docs/images/logo.png)

Welcome to the documentation for Kerblam!

Kerblam is a Rust command line tool to manage the execution of data analysis
projects, make them easy to understand and reproducible.

Kerblam! is a Free and Open Source Software, hosted on Github at
[MrHedmad/kerblam](https://github.com/MrHedmad/kerblam).
The code is licensed with the [MIT License](https://github.com/MrHedmad/kerblam/blob/main/LICENSE).

If you want to cite Kerblam!, provide a link to the Github repository or use
the following Zenodo DOI: [doi.org/10.5281/zenodo.10664806](https://zenodo.org/doi/10.5281/zenodo.10664806)

Use the sidebar to jump to a specific section.
If you have never used Kerblam! before, you can read the documentation from start
to finish to learn all there is to know about Kerblam! by clicking on the arrows
on the side of the page.

Note that all `kerblam` commands support a `--help` flag to print usage
information.

## Naming
This project is named after the fictitious online shop/delivery company in
[S11E07](https://en.wikipedia.org/wiki/Kerblam!) of Doctor Who.
Kerblam! might be referred to as Kerblam!, Kerblam or Kerb!am, interchangeably,
although Kerblam! is preferred.
The Kerblam! logo is written in the [Kwark Font](https://www.1001fonts.com/kwark-font.html) by [tup wanders](https://www.1001fonts.com/users/tup/).

## About this book

This book is rendered by [`mdbook`](https://github.com/rust-lang/mdBook), and
is written as a series of markdown files.
Its source code is available in [the Kerblam! repo](https://github.com/MrHedmad/kerblam).

The book hosted online always refers to the
[latest Kerblam! release](https://github.com/MrHedmad/kerblam/releases).

If you are looking for older or newer versions of this book, you should
read the markdown files directly [on Github](https://github.com/MrHedmad/kerblam/tree/main/docs),
where you can select which tag to view from the top bar, or clone the repository
locally, checkout to the commit you like, and rebuiding from source.
If you're interested, read [the development guide](dev/contributing.html) to
learn more.
15 changes: 8 additions & 7 deletions docs/kerblam.toml.md → docs/src/kerblam.toml.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ The `kerblam.toml` file is the control center of kerblam!
All of its configuration is found there.
Here is what fields are available, and what they do.

> [!IMPORTANT]
> Extra fields not found here are silently ignored.
> This means that you must be careful of typos!
Expand All @@ -16,12 +15,11 @@ version = "0.4.0"
# if you are not running the same executable.
# To save you headaches!

##### --- #####
[data] # Data paths, profiles, etc...
# The [data] section has options regarding... well, data.
[data.paths]
input: "./data/in"
output: "./data/out"
intermediate: "./data"
input = "./data/in"
output = "./data/out"
intermediate = "./data"

[data.profiles] # Specify profiles here
profile_name = {
Expand All @@ -33,11 +31,13 @@ profile_name = {
[data.profiles.profile_name]
"original_name" = "profile_name"
"other_name" = "other_profile_name"
# Any number of profiles can be specified.
# Any number of profiles can be specified, but stick to just one of these
# two methods of defining them.

[data.remote] # Specify how to fetch remote data
"url_to_fetch" = "file_to_save_to"
# there can be any number of "url" = "file" entries here.
# Files are saved inside `[data.paths.input]`

##### --- #####
[code] # Where to look for containers and pipes
Expand All @@ -50,3 +50,4 @@ workdir = "/" # The working directory inside all built containers
```

Note that this does not want to be a valid TOML, just a reference.
Don't expect to copy-paste it and obtain a valid Kerblam! configuration.
Loading

0 comments on commit 7491d67

Please sign in to comment.