A revised version of the Game Boy Programming Tutorial series by David Pello. The framework for the tutorial was forked from gb-asm-tutorial, because I really liked it was put together. Many thanks for all the work put into that tutorial series!
Contributing is really easy, fork this repo and edit the files in the src directory. Then, you can send your PR.
To deploy pello-tutorial-revised locally:
- Install Rust and mdBook. mdBook powers the book itself, Rust is used for some custom plugins.
- Within a terminal pointed at the directory
book.toml
is in, run mdBook (mdbook build
/mdbook watch
/mdbook serve
). - The HTML files are in
book/custom/
.
book/html/
contains only partially processed files.
This folder is what gets served when running mdbook serve
, so you may see some custom markup missing if using that.
As a workaround, you can manually open the files in the book/custom/
folder in your browser, they just won't auto-refresh on changes.
Syntax highlighting is provided within the browser, courtesy of highlight.js
.
RGBASM syntax is highlighted via a plugin, but this requires a custom build of highlight.js
.
Steps:
-
Clone
highlight.js
anywhere, and go into that directory.You will probably want to target a specific version by checking out its tag.
-
Run
npm install
to install its dependencies. -
Within the
extras/
directory, clonehighlightjs-rgbasm
; ensure the directory is calledrgbasm
, otherwise the build tool won't pick it up. -
You can work on and make modifications to
highlightjs-rgbasm
! -
To make the custom build of
highlight.js
, within thehighlight.js
directory, runnode tools/build.js -t browser <languages>...
, with<languages>...
being the list of languages to enable support for. The languages identifiers are the same that you would use for highlighting (```rgbasm
, for example). -
Copy
build/highlight.min.js
astheme/highlight.js
in Pan Docs' source. Alternatively, for debugging, you can usebuild/highlight.js
for a non-minified version, but please don't commit that.
mdbook watch
and mdbook serve
do not watch for changes to files in the theme/
directory, you must trigger the build by either restarting the command, or manually changing one of the watched files.
Example:
$ git clone git@github.com:highlightjs/highlight.js.git
$ cd highlight.js
$ git checkout 10.7.2
$ npm install
$ git clone git@github.com:gbdev/highlightjs-rgbasm.git extras/rgbasm
$ node tools/build.js -t browser rgbasm shell makefile
$ cp build/highlight.min.js ../gb-asm-tutorial/theme/highlight.js
Different parts of pello-tutorial-revised are subject to different licenses:
- The contents (code, prose, images, etc.) of this tutorial are licensed under a Creative Commons Attribution-ShareAlike 4.0 International License, as the original tutorial series was licensed under that license.
- Code used to display and format the site is licensed under the MIT License unless otherwise specified.