Skip to content

Latest commit

 

History

History
204 lines (164 loc) · 6.78 KB

README.md

File metadata and controls

204 lines (164 loc) · 6.78 KB

Subdoc

Subdoc is a documentation generator from inline C++ documentation in the spirit of Rustdoc.

To see it live, the Subspace docs are generated with Subdoc here: https://suslib.cc. The tool is still under development with lots to do. Want to help?

Subdoc collects and parses doc comments in source code and generates a set of HTML pages from it. Doc comments are typically denoted by /// (or /** */ inside macros). The text within the doc comments is parsed as markdown with support for:

There are many examples throughout the Subspace C++ library.

Code links

Subdoc uses an extension to links in markdown. If the link URL starts with a $ then the text is parsed as a C++ symbol. If it can be found in the source code that Subdoc is generating docs for, a link to the correct HTML page will be inserted. Otherwise, an error is generated.

For example the markdown link [Option]($sus::option::Option) will generate a link to the page about the Option type found in the sus::option namespace. And [Option::unwrap]($sus::option::Option::unwrap) will link to the unwrap method for that same type.

Grouping overloads

By default all overloads of a function/method are grouped together and get a single doc comment applied to them all. If more than one comment is found, Subdoc will generate an error stating that the comments have collided.

To generate different documentation for overloads, use the #[doc.overloads=group] doc-attribute. All overloads that have the same group name will be grouped together and get the same documentation applied to them. This can be used to group overloads in arbitrary ways and into an arbitrary number of groups.

For example:

/// This function receives no arguments.
/// #[doc.overloads=void]
void my_function();

/// This function receives an i32 argument.
/// #[doc.overloads=i32]
void my_function(i32);

To link to a specific overload group, place the group name in the link after a ! character.

/// A simple example function.
///
/// Calls [`my_function`](#my_function!i32), passing an i32.
void with_i32() { my_function(2); }

Hiding symbols

To document a symbol in the source code but hide it from the generated documentation, use the #[doc.hidden] attribute.

For example:

/// This function is omitted from the generated docs.
/// #[doc.hidden]
void secret() {}

Running Subdoc

subdoc --project-name NAME [--include-file-pattern PATH] [--exclude-file-pattern PATH]
    [--include-macro-prefix PREFIX] [--css PATH] [--copy-file PATH] [--project-md PATH]
    FILES...
--project-name NAME

The NAME will be inserted into the title and overview section of the generated HTML pages.

Include/exclude symbols

Subdoc uses Clang to parse C++ code, so it sees every symbol that your code sees, including the standard library, C library, etc. To avoid generating docs for everything, Subdoc has command line flags that control what is included or excluded.

--include-file-pattern PATH

Symbols defined in files whose path contains the PATH as a substring are included.

--exclude-file-pattern PATH

Symbols defined in files whose path contains the PATH as a substring are excluded. This overrides symbols that would have been included by --include-file-pattern.

--include-macro-prefix PREFIX

Macros are only included in the generated docs if they match a prefix specified by this flag. It can be given more than once to name multiple prefixes to match against.

By default Subdoc also excludes symbols in a namespace named __private or test, or any namespace nested within one. TODO: Make this a command line flag.

Subdoc also excludes symbols in an anonymous namespace, or that are marked protected or private. TODO: Make this a command line flag.

FILES...

Subdoc can only see the symbols from the source files that you ask it to read. Typically it is ideal to point Subdoc at your unit test files, for two reasons:

  • Subdoc requires build rules in the compile database to know what flags to use when running Clang. The unit test files are part of the compile database.
  • Subdoc (TODO: make this happen) reads static_assert() statements to determine if a type satisfies a concept. Those can be placed in your unit test files and Subdoc can pick them up from there.

The FILES... is a list of patterns, and every source file in the compile database that has one of the patterns as a substring will be included in the generation.

Additional files

A number of other flags allow including or using files with the generated output.

--css WEB_PATH

The WEB_PATH is used as a path to a css file on the server, and an HTML reference is added to it within every page. This can be the name of a file included in the output with --copy-file.

--copy-file PATH

Copies the file named by PATH into the output directory when generating docs. Useful for images, css stylesheets, or anything else linked to from a doc comment.

--project-md PATH

Inserts the markdown text in the file named by PATH as the description of the global namespace. This provides a good place to write a project overview that links to various parts of the project's documentation.

--project-logo WEB_PATH

Points the logo image to the given WEB_PATH in the generated HTML pages. This can be the name of a file included in the output with --copy-file.

--favicon WEB_PATH

The WEB_PATH is a path on the server to an icon to act as the favicon and its mime type, separated by a semicolon. May be specified multiple times for multiple files in which case the first is used as the primary and the others as alternates. This can be the name of a file included in the output with --copy-file.

When rendering the HTML, a <link>`` tag will be added with each path to an icon file that is specified. For example: --favicon favicon.png;image/png --favicon favicon-vec.svg;image/svg+xml`.

Example execution

See the subdoc.yml file for an example of how the Subspace C++ Library documentation is generated.

There are scripts in tools to quickly run Subdoc over a few Subspace files, which you can use to try it out as well, for Mac/Linux and Windows.