Source: dockerfiles/intmain_docmd
Introduction
A tool for generating documentation in Markdown format.
Usage
where type can be:
bashc++coffeeconfgrdbmakefilenginxpythonrubyscsssystemdvimyaml
If no argument is provided, the program prints the help message and exits.
Details
if ARGV.empty?
puts """
Markdown documentation generator
intmain_docmd type source_file markdown_file
type: vim, bash, python, ruby, coffee, makefile, grdb, nginx, scss, conf, c++, systemd, yaml
To change the tool's behavior, use the following environment variables:
INTMAIN_DOCMD_DETAILS=false disables the details tag
INTMAIN_DOCMD_TOC=false disables table-of-contents generation
INTMAIN_DOCMD_SHOW_SOURCE=false disables the source file name
"""
exit
end
Real example
This project's documentation is maintained with intmain_docmd:
intmain_docmd ruby bin/intmain_docmd doc/10_Gerador_de_documentação_intmain_docmd.md
intmain_docmd bash bin/intmain_resize_screenshots doc/20_Redimensionador_de_screenshots.md
intmain_docmd bash scripts/Common/intmain.bash doc/20_Biblioteca_de_scripts_intmain.md
intmain_docmd bash scripts/Common/taoker.bash doc/21_Biblioteca_de_scripts_taoker.md
intmain_docmd bash scripts/Common/common.bash doc/30_Biblioteca_de_funções_bash.md
intmain_docmd makefile scripts/Common/Makefile.include doc/40_Biblioteca_de_alvos_make.md
Control variables
INTMAIN_DOCMD_DETAILS: enables/disables code block wrappingINTMAIN_DOCMD_TOC: enables/disables table-of-contents generationINTMAIN_DOCMD_SHOW_SOURCE: shows the source file name
Details
Callout numbers
To reference commands, use numbered items, e.g. ❶, to point to a line in the middle of the code.
Details
def expand_shortcuts(text)
callout_numbers = { "❶" => "❶", "❷" => "❷", "❸" => "❸",
"❹" => "❹", "❺" => "❺", "❻" => "❻",
"❼" => "❼", "❽" => "❽", "❾" => "❾",
"❿" => "❿", "⓫" => "⓫", "⓬" => "⓬",
"⓭" => "⓭", "⓮" => "⓮", "⓯" => "⓯",
"⓰" => "⓰", "⓱" => "⓱", "⓲" => "⓲",
"⓳" => "⓳", "⓴" => "⓴" }
callout_numbers.each{ |k,v| text = text.gsub( k, v ) }
text
end
Including diagrams with PlantUML
The plantuml blocks below will be replaced by the diagram image.


