aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/guide/asciidoc.asciidoc
blob: cc8336bfe8e559c5ff6612a5c9f96e272db602f7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
[[asciidoc]]
== AsciiDoc documentation

Erlang.mk provides rules for generating documentation from
AsciiDoc files. It can automatically build a user guide PDF,
chunked HTML documentation and Unix manual pages.

=== Requirements

It is necessary to have http://asciidoc.org/[AsciiDoc], 
http://xmlsoft.org/XSLT/xsltproc2.html[xsltproc] and
http://dblatex.sourceforge.net/[dblatex] installed on your
system for Erlang.mk to generate documentation from AsciiDoc sources.

=== Writing AsciiDoc documentation

http://asciidoc.org/[AsciiDoc] is a text document format for
writing notes, documentation, articles, books, ebooks, slideshows,
web pages, man pages and blogs. AsciiDoc files can be translated
to many formats including HTML, PDF, EPUB, man page.

The http://asciidoc.org/userguide.html[AsciiDoc user guide]
describes the AsciiDoc syntax.

The https://github.com/ninenines/erlang.mk/tree/master/doc/src/guide[Erlang.mk user guide]
is written in AsciiDoc and can be used as an example. The entry
file is https://github.com/ninenines/erlang.mk/blob/master/doc/src/guide/book.asciidoc[book.asciidoc].

Erlang.mk expects you to put your documentation in a specific
location. This is 'doc/src/guide/' for the user guide, and
'doc/src/manual/' for the function reference. In the case of
the user guide, the entry point is always 'doc/src/guide/book.asciidoc'.

For manual pages, it is good practice to use section 3 for
modules, and section 7 for the application itself.

=== Configuration

All of the AsciiDoc related configuration can be done directly
inside the files themselves.

=== Usage

To build all documentation:

[source,bash]
$ make docs

To build only the AsciiDoc documentation:

[source,bash]
$ make asciidoc

To build only the user guide:

[source,bash]
$ make asciidoc-guide

To build only the manual:

[source,bash]
$ make asciidoc-manual

To install man pages on Unix:

[source,bash]
$ make install-docs

Erlang.mk allows customizing the installation path and sections
of the man pages to be installed. The `MAN_INSTALL_PATH` variable
defines where man pages will be installed. It defaults to
'/usr/local/share/man'. The `MAN_SECTIONS` variable defines
which manual sections are to be installed. It defaults to `3 7`.

To install man pages to a custom location:

[source,bash]
$ make install-docs MAN_INSTALL_PATH=/opt/share/man

Note that you may need to run the install commands using
`sudo` or equivalent if the location is not writeable by
your user.