dmdoc is a documentation generator for DreamMaker, the scripting language of the BYOND game engine. It produces simple static HTML files based on documented files, macros, types, procs, and vars.
If dmdoc is run in a Git repository, web links to source code are placed next to item headings in the generated output; otherwise, file and line numbers are shown but are not linked.
dmdoc can be obtained with cargo build -p dmdoc
or from the releases page.
dmdoc should be run from within the DM project directory. It will
automatically detect the .dme
file, parse it, and generate documentation.
Documentation and resource files will be saved into the dmdoc
directory. The
resulting documentation will be suitable for uploading to any web server. It
may be desirable to delete this directory if it exists before running dmdoc, to
remove old files.
Types, macros, vars, and procs can be documented using any of four different doc comment styles. Both block and line comments are supported. Documentation blocks may target their enclosing item or the following item.
/// This comment applies to the following macro.
#define BLUE rgb(0, 255, 0)
/** Block comments work too. */
/obj
var/affinity = BLUE //! Enclosing comments follow their item.
/proc/chemical_reaction()
/*! Block comments work too. */
Types with only a one-line note and no documented procs or vars do not get
their own .html
page.
Enclosing-item comments which are not inside any element are applied to the current file. Files which have such comments, or which contain any documented macros, are added to the modules tree. If a file is in the modules tree, any documented types in that file will appear in its entry.
The summary sections of module pages are sorted in line number order, with file-level documentation interspersed with the summary lines of documented items.
Markdown files inside the code
directory will also be rendered and added to
the modules tree.
The contents of code/README.md
will be used in the main page of the generated
documentation.