doc updates

This commit is contained in:
steve donovan 2011-04-17 19:12:08 +02:00
parent de1a2b11ba
commit 9541e0274c
1 changed files with 68 additions and 4 deletions

View File

@ -10,7 +10,7 @@ LDoc is intended to be compatible with [LuaDoc](http://luadoc.luaforge.net/manua
Various tags such as `see` and `usage` are supported, and generally the names of functions and modules can be inferred from the code. The project grew out of the documentation needs of Penlight (and not always getting satisfaction with LuaDoc) and depends on Penlight itself. This allowed me to _not_ write a lot of code. Various tags such as `see` and `usage` are supported, and generally the names of functions and modules can be inferred from the code. The project grew out of the documentation needs of Penlight (and not always getting satisfaction with LuaDoc) and depends on Penlight itself. This allowed me to _not_ write a lot of code.
LDoc tries to be faithful to LuaDoc, but provides some extensions LDoc tries to be faithful to LuaDoc, but provides some extensions. Here an alias for 'param' has been defined, and '@function zero_fun' is short for '@class function \ @name zero_fun'.
--- zero function. Two new ldoc features here; item types --- zero function. Two new ldoc features here; item types
-- can be used directly as tags, and aliases for tags -- can be used directly as tags, and aliases for tags
@ -36,6 +36,40 @@ And then used as any other tag:
-- @macro first_macro -- @macro first_macro
-- @see second_function -- @see second_function
LDoc tries to make it more convenient to organize documentation comments. Instead of:
--- first table
-- @table one
-- @field A alpha
-- @field B beta
M.one = {
A = 1,
B = 2;
}
you can write:
--- first table
-- @table one
M.one = {
A = 1, -- alpha
B = 2; -- beta
}
Simularly, function parameter comments can be directly used:
------------
-- third function. Can also provide parameter comments inline,
-- provided they follow this pattern.
function mod1.third_function(
alpha, -- correction A
beta, -- correction B
gamma -- factor C
)
...
end
LDoc can process C/C++ files: LDoc can process C/C++ files:
/*** /***
@ -52,9 +86,8 @@ Both `/**` and `///` are recognized as starting a comment block.
The command-line options are: The command-line options are:
ldoc, a Lua documentation generator, vs 0.1 Beta ldoc, a Lua documentation generator, vs 0.1 Beta
-d,--dir (default .) output directory -d,--dir (default docs) output directory
-o (default 'index') output name -o (default 'index') output name
-v,--verbose verbose -v,--verbose verbose
-q,--quiet suppress output -q,--quiet suppress output
@ -63,6 +96,37 @@ The command-line options are:
-p,--project (default ldoc) project name -p,--project (default ldoc) project name
-t,--title (default Reference) page title -t,--title (default Reference) page title
-f,--format (default plain) formatting - can be markdown -f,--format (default plain) formatting - can be markdown
-b,--package (default '') top-level package basename (needed for module(...)) -b,--package (default .) top-level package basename (needed for module(...))
<file> (string) source file or directory containing source <file> (string) source file or directory containing source
For example, to process all files in the current directory:
$ ldoc .
output written to docs/
Thereafter the `docs` directory will contain `index.html` which points to individual modules in the `modules` subdirectory. The `--dir` flag can specify where the output is generated, and ensures that the directory exists.
If your modules use `module(...)` then the module name has to be deduced. If `ldoc` is run from the root of the package, then this deduction does not need any help - e.g. if your package was `foo` then `ldoc foo` will work as expected. If we were actually in the `foo` directory then `ldoc -b .. .` will correctly deduce the module names.
For new-style modules, that don't use `module()`, it is recommended that the module comment has an explicit `@module PACKAGE.NAME`. If it does not, then `ldoc` will still attempt to deduce the module name, but may need help with `--package` as above.
It is common to use an alias for the package name with new-style modules. Here an alias is explicitly specified, so that `ldoc` knows that functions qualified with `M` are part of the module:
------------
-- A new-style module.
-- @alias M
local simple_alias = {}
local M = simple_alias
--- return the answer. And complete the description
function M.answer()
return 42
end
return simple_alias
(Here the actual module name is deduced from the file name, just like with `module(...)`)