This repository contains the raw documentation for Marlin 3D printer firmware which is automatically deployed to marlinfw.org. This documentation is open and available on GitHub so anyone may contribute by completing, correcting, or creating articles.
The Marlin Documentation Project is built using the following technologies:
To work with the documentation, first fork this repository to your GitHub account, then clone your MarlinDocumentation fork locally. You should do all work within your own fork before submitting it as a Pull Request to the master
branch. You can download the GitHub Desktop app and use GitHub's "Open in Desktop" option, or from your own desktop, open a terminal/cmd window and do:
For example, change into the root of C:\:
cd C:\
Clone Marlin Documentation repository:
git clone https://github.com/MarlinFirmware/MarlinDocumentation.git
This will create a local C:\MarlinDocumentation
folder linked to your fork.
To add new documentation or edit existing documentation, start by creating a new branch as a copy of the master
branch. You can do this using the GitHub web interface, from within GitHub Desktop, or from the command line.
If your new document is about "mashed potatoes" then name the new branch accordingly:
git checkout master -b doc-mashed_potatoes
Inside the _docs
folder, add the new file mashed-potatoes.md
and let flow all your creativity into it. When you feel your masterpiece is ready to be shared with the world, commit the changes and push them up to your Marlin Documentation fork. This is done most easily from within the GitHub Desktop app, but here are the command line commands for reference:
git add mashed-potatoes.md
git commit -m "Added a new document about potatoes"
git push
Next, start a new Pull Request to the upstream repository (MarlinFirmware/MarlinDocumentation).
[!TIP] Check out GitHub's documentation on creating a new branch, managing branches, and creating Pull Requests if you're new to contributing with git.
This Jekyll-based site is based on the Markdown language in delicious YAML wrapper. Be careful with this format because even small typos can cause Jekyll to reject the page. If you've installed Jekyll as described below, you can use it to build and preview the documentation and this will tell you where your errors are.
Try to be neutral, concise, and straightforward. Avoid use of personal pronouns, unless avoiding them proves awkward. Provide images and give examples where needed. Check your spelling, grammar, and punctuation.
You can use the _tmp
folder for work-in-progress, and they will not be included in the site deployment.
If you'd like to be able to preview your contributions before submitting them, you'll need to install Jekyll on your system. Instructions for Windows and macOS are given below:
Download and install a Ruby+Devkit 3.3.4
from RubyInstaller Download Archives. Use default options for installation.
Run the ridk install
step on the last stage of the installation wizard. Choose option 3
for MSYS2 and MINGW development tool chain
. This is needed for installing gems with native extensions. You can find additional information regarding this in the RubyInstaller Documentation.
[!TIP] Once the
MSYS2 and MINGW development toolchain
install is complete, the installation wizard will reprompt which components should be installed. If you see a "Install MSYS2 and MINGW development toolchain succeeded" message above it, you can close the Command Prompt window and continue below.
Open a new Command Prompt so that changes to the PATH
environment variable become effective, then check that everything is working:
ruby -v
If ruby 3.3.4 (2024-07-09 revision be1089c8ec)
is reported, then proceed to Set up the Marlin Documentation project.
[!NOTE] Ruby may come preinstalled, but macOS' "system Ruby" is outdated, unmaintained, and not recommended for general use.
There are many popular package managers for macOS, but we'll cover installation with Homebrew & MacPorts.
Install a package manager. You do not need to install both:
Install Homebrew by launching Terminal and running the following command:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
Install MacPorts by downloading & installing the correct package for your version of macOS from the Installing MacPorts page.
Install chruby
and ruby-install
:
Homebrew:
brew install chruby ruby-install
MacPorts:
sudo port install chruby ruby-install
Install Ruby 3.3.4
:
ruby-install ruby 3.3.4
The configure, build, and install process will take a few minutes.
Configure your shell to automatically use chruby
:
Homebrew:
echo "" >> ~/.zshrc
echo "# Ruby Configuration" >> ~/.zshrc
echo "source $(brew --prefix)/opt/chruby/share/chruby/chruby.sh" >> ~/.zshrc
echo "source $(brew --prefix)/opt/chruby/share/chruby/auto.sh" >> ~/.zshrc
echo "chruby ruby-3.3.4" >> ~/.zshrc
MacPorts:
echo "" >> ~/.zshrc
echo "# Ruby Configuration" >> ~/.zshrc
echo "source ${prefix}/opt/local/share/chruby/chruby.sh" >> ~/.zshrc
echo "source ${prefix}/opt/local/share/chruby/auto.sh" >> ~/.zshrc
echo "chruby ruby-3.3.4" >> ~/.zshrc
Quit and relaunch Terminal, then check that everything is working:
ruby -v
It should report ruby 3.3.4 (2024-07-09 revision be1089c8ec)
. If not, repeat the above steps.
[!NOTE] When using
ruby-install
you'll find your Ruby installations in~/.rubies/
and you can switch between them withchruby
. New instances ofzsh
in Terminal will default to 3.3.4 due to the changes made to~/.zshrc
.
bundler
is already included.)Ensure APT is up to date:
sudo apt update
Install prerequisites:
sudo apt install git curl libssl-dev libreadline-dev zlib1g-dev autoconf bison build-essential libyaml-dev libreadline-dev libncurses5-dev libffi-dev libgdbm-dev
Install rbenv:
curl -fsSL https://github.com/rbenv/rbenv-installer/raw/HEAD/bin/rbenv-installer | bash
echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bashrc
echo 'eval "$(rbenv init -)"' >> ~/.bashrc
source ~/.bashrc
Install Ruby 3.3.4:
rbenv install 3.3.4
rbenv global 3.3.4
[!NOTE] When using
rbenv
you'll find your Ruby installations in~/.rbenv/versions/
and you can switch between them withrbenv global <version>
.
Check Ruby version:
ruby -v
It should report ruby 3.3.4 (2024-07-09 revision be1089c8ec)
. If not, repeat the above steps.
Add environment variables to your ~/.bashrc
file to configure the gem installation path:
echo '# Install Ruby Gems to ~/gems' >> ~/.bashrc
echo 'export GEM_HOME="$HOME/gems"' >> ~/.bashrc
echo 'export PATH="$HOME/gems/bin:$PATH"' >> ~/.bashrc
source ~/.bashrc
Install Bundler Gem:
gem install bundler
Proceed to Set up Marlin Documentation project.
Once Ruby is installed, set up the Marlin Documentation project with Bundler. Open Command Prompt or Terminal and cd
to the working path of your Marlin Documentation fork. Execute the following commands:
rm -f Gemfile.lock
bundle config set path 'vendor/bundle'
bundle install
[!NOTE] You only need to execute the above commands once to complete the install. If you see errors at this stage you may need to update your Ruby installation, fix your Ruby environment, or resolve dependencies between the Ruby gems.
Jekyll uses a combination of YAML, Markdown, Liquid, and HTML to define the site content and layout. A _config.yml
file defines a site structure with "collections" corresponding to sub-folders. The website is "compiled" to produce static HTML and Javascript. The most important folders in the site are:
_layouts
contains the general layouts (aka page templates)._includes
has partial layouts included by others._meta
is where we keep top-level page descriptions._basics
, _configuration
, _development
, _features
, _gcode
, _hardware
….To start a mini web server and preview your changes, run the following command:
bundle exec jekyll serve --watch --incremental
With the serve --watch --incremental
parameters, Jekyll watches local files for changes and triggers an automatic incremental build of the site on every save. It also starts a mini-web server so documentation can be previewed in a browser at http://localhost:4000/.
[!TIP] The main Marlin repository comes with the
mfdoc
script containing the commands above as a shortcut to preview the documentation.
This documentation is licensed under the GPLv3 license.