Go to file
2020-08-18 23:38:19 +01:00
_data Add language changing button 2020-08-18 23:38:19 +01:00
_en Update inventories.md 2020-08-08 22:56:50 +00:00
_includes Formspecs: Rewrite chapter 2019-08-14 14:39:42 +01:00
_it Fix various issues with translated nav bar 2020-08-18 21:57:46 +01:00
_layouts Add language changing button 2020-08-18 23:38:19 +01:00
_sass Add language changing button 2020-08-18 23:38:19 +01:00
.vscode Biomes and Decorations: Improve and fix errors 2020-03-28 20:22:29 +00:00
static Add language changing button 2020-08-18 23:38:19 +01:00
utils Add word counter 2018-10-05 16:09:26 +01:00
_conf_wc.yml Add word counter 2018-10-05 16:09:26 +01:00
_config.yml Italian language support added in _config.yml 2020-08-18 21:36:24 +01:00
.gitignore Commit dictionary 2020-03-28 20:00:12 +00:00
.gitlab-ci.yml Add Gitlab Pages support 2019-11-30 20:47:28 +00:00
cat.html Add word counter 2018-10-05 16:09:26 +01:00
Gemfile Add Gitlab Pages support 2019-11-30 20:47:28 +00:00
Gemfile.lock Fix various issues with translated nav bar 2020-08-18 21:57:46 +01:00
index.html Make locale redirector when Javascript is disabled 2017-08-27 19:16:10 +01:00
languages.html Add language changing button 2020-08-18 23:38:19 +01:00
lua_api.html Add warnings to various book chapters 2018-07-20 20:51:38 +01:00
README.md Add build status badge on README.md 2020-05-04 21:56:57 +00:00
sitemap.json sitemap.json: Fix chapter_number 2018-09-24 15:59:56 +01:00

Minetest Modding Book

Build status
Read Online

Book written by rubenwardy.
License: CC-BY-SA 3.0

Finding your way around

  • _data/ - Contains list of languages
  • _layouts/ - Layouts to wrap around each page.
  • static/ - CSS, images, scripts.
  • _<lang>/
    • <section>/ - Markdown files for each chapter.

Contributing chapters

  • Create a pull request with a new chapter in markdown.
  • Write a new chapter in the text editor of your choice and send them to me.

I'm happy to fix the formatting of any chapters. It is the writing which is the hard bit, not the formatting.

Chapter Guidelines

  • Prefer pronounless text, but you if you must. Never we nor I.
  • Do not rely on anything that isn't printable to a physical book.
  • Any links must be invisible - ie: if they're removed, then the chapter must still make sense.
  • Table of contents for each chapter with anchor links.
  • Add your turns to the end of a chapter when relevant.
  • Titles and subheadings should be in Title Case.

Making a Chapter

To create a new chapter, make a new file in _en/section/. Name it something that explains what the chapter is about. Replace spaces with underscores ( _ )

---
title: Chapter Name
layout: default
root: ..
idx: 4.5
long_notice:
  level: tip
  title: This is a long tip!
  message: This is a very long tip, so it would be unreadable if
           placed in the main body of the chapter. Therefore,
           it is a good idea to put it in the frontmatter instead.
---

## Chapter Name

Write a paragraph or so explaining what will be covered in this chapter.
Explain why/how these concepts are useful in modding

* [List the](#list-the)
* [Parts in](#parts-in)
* [This Chapter](#this-chapter)

## List the

{% include notice.html notice=page.long_notice %}

Paragraphs

\```lua
code
\```

## Parts in

## This Chapter

Commits

If you are editing or creating a particular chapter, then use commit messages like this:

Getting Started - corrected typos
Entities - created chapter

Just use a normal style commit message otherwise.

Adding a new language

  1. Copy _en/ to your language code
  2. Add entry to _data/languages.yml
  3. Add entry to collections in _config.yml
  4. Add your language to the if else in layouts/default.html
  5. Translate your language code folder (that you made in step 1) You can translate the file paths, just make sure you keep any ids the same.

Using Jeykll

I use Jekyll 3.8.0

# For Debian/Ubuntu based:
sudo apt install ruby-dev
gem install jekyll github-pages

Building as a website

You can build it as a website using Jekyll

$ jekyll build

Goes to _site/

Webserver for Development

You can start a webserver on localhost which will automatically rebuild pages when you modify their markdown source.

$ jekyll serve

This serves at http://localhost:4000 on my computer, but the port may be different. Check the console for the "server address"