Merge pull request #331 from alerque/lint-and-test

This commit is contained in:
Caleb Maclennan 2020-10-02 01:15:27 +03:00 committed by GitHub
commit 380c7db50c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
22 changed files with 695 additions and 668 deletions

23
.github/workflows/luacheck.yml vendored Normal file
View File

@ -0,0 +1,23 @@
name: Luacheck
on: [push, pull_request]
jobs:
luacheck:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup Lua
uses: leafo/gh-actions-lua@v6
with:
luaVersion: 5.4
- name: Setup Lua Rocks
uses: leafo/gh-actions-luarocks@v2
- name: Setup dependencies
run: luarocks install luacheck
- name: Run Code Linter
run: |
luacheck .
luarocks lint *.rockspec

21
.luacheckrc Normal file
View File

@ -0,0 +1,21 @@
unused_args = false
redefined = false
max_line_length = false
include_files = {
"**/*.lua",
"*.rockspec",
".luacheckrc",
}
exclude_files = {
-- Tests are too messy to lint
"tests",
-- Travis Lua environment
"here/*.lua",
"here/**/*.lua",
-- GH Actions Lua Environment
".lua",
".luarocks",
".install",
}

View File

@ -3,6 +3,8 @@ LUA_BINDIR= $(shell echo `dirname $(LUA)`)
LUA_PREFIX= $(shell echo `dirname $(LUA_BINDIR)`) LUA_PREFIX= $(shell echo `dirname $(LUA_BINDIR)`)
LUA_SHAREDIR=$(LUA_PREFIX)/share/lua/5.1 LUA_SHAREDIR=$(LUA_PREFIX)/share/lua/5.1
_REPODIR != cd "$(shell dirname $(firstword $(MAKEFILE_LIST)))/" && pwd
ldoc: ldoc:
install: install_parts install: install_parts
@ -28,23 +30,26 @@ uninstall:
test: test-basic test-example test-md test-tables test: test-basic test-example test-md test-tables
RUN=&& ldoc . && diff -r docs cdocs && echo ok RUN=&& lua $(_REPODIR)/ldoc.lua . && diff -r doc cdocs && echo ok
test-prep:
find -type d -name doc -execdir rsync -av --del {}/ cdocs/ \;
test-basic: test-basic:
cd tests $(RUN) cd tests $(RUN)
test-example: test-example:
cd tests && cd example $(RUN) cd tests/example $(RUN)
test-md: test-md:
cd tests && cd md-test $(RUN) cd tests/md-test $(RUN)
test-tables: test-tables:
cd tests && cd simple $(RUN) cd tests/simple $(RUN)
test-clean: clean-basic clean-example clean-md clean-tables test-clean: clean-basic clean-example clean-md clean-tables
CLEAN=&& ldoc . && rd /S /Q cdocs && cp -rf docs cdocs CLEAN=&& lua $(_REPODIR)/ldoc.lua . && rd /S /Q cdocs && cp -rf doc cdocs
clean-basic: clean-basic:
cd tests $(CLEAN) cd tests $(CLEAN)

View File

@ -1,5 +1,7 @@
# LDoc - A Lua Documentation Tool # LDoc - A Lua Documentation Tool
[![Luacheck](https://github.com/lunarmodules/LDoc/workflows/Luacheck/badge.svg)](https://github.com/lunarmodules/LDoc/actions)
Copyright (C) 2011-2012 Steve Donovan. Copyright (C) 2011-2012 Steve Donovan.
## Rationale ## Rationale

View File

@ -27,7 +27,6 @@ local tablex = require 'pl.tablex'
-- Penlight compatibility -- Penlight compatibility
utils.unpack = utils.unpack or unpack or table.unpack utils.unpack = utils.unpack or unpack or table.unpack
local append = table.insert
local lapp = require 'pl.lapp' local lapp = require 'pl.lapp'
local version = '1.4.6' local version = '1.4.6'
@ -91,7 +90,7 @@ local global = require 'ldoc.builtin.globals'
local markup = require 'ldoc.markup' local markup = require 'ldoc.markup'
local parse = require 'ldoc.parse' local parse = require 'ldoc.parse'
local KindMap = tools.KindMap local KindMap = tools.KindMap
local Item,File,Module = doc.Item,doc.File,doc.Module local Item,File = doc.Item,doc.File
local quit = utils.quit local quit = utils.quit
if args.version then if args.version then
@ -176,7 +175,6 @@ local function setup_kinds ()
end end
local add_language_extension
-- hacky way for doc module to be passed options... -- hacky way for doc module to be passed options...
doc.ldoc = ldoc doc.ldoc = ldoc
@ -258,14 +256,15 @@ ldoc_contents = tablex.makeset(ldoc_contents)
local function loadstr (ldoc,txt) local function loadstr (ldoc,txt)
local chunk, err local chunk, err
local load
-- Penlight's Lua 5.2 compatibility has wobbled over the years... -- Penlight's Lua 5.2 compatibility has wobbled over the years...
if not rawget(_G,'loadin') then -- Penlight 0.9.5 if not rawget(_G,'loadin') then -- Penlight 0.9.5
-- Penlight 0.9.7; no more global load() override -- Penlight 0.9.7; no more global load() override
load = load or utils.load local load = load or utils.load
chunk,err = load(txt,'config',nil,ldoc) chunk,err = load(txt,'config',nil,ldoc)
else else
-- luacheck: push ignore 113
chunk,err = loadin(ldoc,txt) chunk,err = loadin(ldoc,txt)
-- luacheck: pop
end end
return chunk, err return chunk, err
end end
@ -277,7 +276,7 @@ local function read_ldoc_config (fname)
if directory == '' then if directory == '' then
directory = '.' directory = '.'
end end
local chunk, err, ok local chunk, err, _
if args.filter == 'none' then if args.filter == 'none' then
print('reading configuration from '..fname) print('reading configuration from '..fname)
end end
@ -286,7 +285,7 @@ local function read_ldoc_config (fname)
chunk, err = loadstr(ldoc,txt) chunk, err = loadstr(ldoc,txt)
if chunk then if chunk then
if args.define ~= 'none' then ldoc[args.define] = true end if args.define ~= 'none' then ldoc[args.define] = true end
ok,err = pcall(chunk) _,err = pcall(chunk)
end end
end end
if err then quit('error loading config file '..fname..': '..err) end if err then quit('error loading config file '..fname..': '..err) end
@ -301,7 +300,6 @@ end
local quote = tools.quote local quote = tools.quote
--- processing command line and preparing for output --- --- processing command line and preparing for output ---
local F
local file_list = List() local file_list = List()
File.list = file_list File.list = file_list
local config_dir local config_dir
@ -316,7 +314,7 @@ if args.module then
if args.file:match '^%a+$' and global.functions[args.file] then if args.file:match '^%a+$' and global.functions[args.file] then
args.file = 'global.'..args.file args.file = 'global.'..args.file
end end
local fullpath,mod,on_docpath = tools.lookup_existing_module_or_function (args.file, doc_path) local fullpath,mod,_ = tools.lookup_existing_module_or_function (args.file, doc_path)
if not fullpath then if not fullpath then
quit(mod) quit(mod)
else else
@ -337,7 +335,6 @@ if args.file == '.' then
print('changing to directory',config_path) print('changing to directory',config_path)
lfs.chdir(config_path) lfs.chdir(config_path)
end end
config_is_read = true
args.file = ldoc.file or '.' args.file = ldoc.file or '.'
if args.file == '.' then if args.file == '.' then
args.file = lfs.currentdir() args.file = lfs.currentdir()

View File

@ -1,124 +1,124 @@
--- getting runtime debug information. --- getting runtime debug information.
-- @module debug -- @module debug
local debug = {} local debug = {}
--- ---
-- Enters an interactive mode with the user, running each string that -- Enters an interactive mode with the user, running each string that
-- the user enters. Using simple commands and other debug facilities, -- the user enters. Using simple commands and other debug facilities,
-- the user can inspect global and local variables, change their values, -- the user can inspect global and local variables, change their values,
-- evaluate expressions, and so on. A line containing only the word `cont` -- evaluate expressions, and so on. A line containing only the word `cont`
-- finishes this function, so that the caller continues its execution. -- finishes this function, so that the caller continues its execution.
-- Note that commands for `debug.debug` are not lexically nested within any -- Note that commands for `debug.debug` are not lexically nested within any
-- function, and so have no direct access to local variables. -- function, and so have no direct access to local variables.
function debug.debug() end function debug.debug() end
--- ---
-- Returns the environment of object `o`. -- Returns the environment of object `o`.
function debug.getfenv(o) end function debug.getfenv(o) end
--- ---
-- Returns the current hook settings of the thread, as three values: the -- Returns the current hook settings of the thread, as three values: the
-- current hook function, the current hook mask, and the current hook count -- current hook function, the current hook mask, and the current hook count
-- (as set by the `debug.sethook` function). -- (as set by the `debug.sethook` function).
function debug.gethook(thread) end function debug.gethook(thread) end
--- ---
-- Returns a table with information about a function. You can give the -- Returns a table with information about a function. You can give the
-- function directly, or you can give a number as the value of `function`, -- function directly, or you can give a number as the value of `function`,
-- which means the function running at level `function` of the call stack -- which means the function running at level `function` of the call stack
-- of the given thread: level 0 is the current function (`getinfo` itself); -- of the given thread: level 0 is the current function (`getinfo` itself);
-- level 1 is the function that called `getinfo`; and so on. If `function` -- level 1 is the function that called `getinfo`; and so on. If `function`
-- is a number larger than the number of active functions, then `getinfo` -- is a number larger than the number of active functions, then `getinfo`
-- returns nil. -- returns nil.
-- --
-- `thread` and `what` are optional. -- `thread` and `what` are optional.
-- --
-- The returned table can contain all the fields returned by `lua_getinfo`, -- The returned table can contain all the fields returned by `lua_getinfo`,
-- with the string `what` describing which fields to fill in. The default for -- with the string `what` describing which fields to fill in. The default for
-- `what` is to get all information available, except the table of valid -- `what` is to get all information available, except the table of valid
-- lines. If present, the option '`f`' adds a field named `func` with -- lines. If present, the option '`f`' adds a field named `func` with
-- the function itself. If present, the option '`L`' adds a field named -- the function itself. If present, the option '`L`' adds a field named
-- `activelines` with the table of valid lines. -- `activelines` with the table of valid lines.
-- For instance, the expression `debug.getinfo(1,"n").name` returns a table -- For instance, the expression `debug.getinfo(1,"n").name` returns a table
-- with a name for the current function, if a reasonable name can be found, -- with a name for the current function, if a reasonable name can be found,
-- and the expression `debug.getinfo(print)` returns a table with all available -- and the expression `debug.getinfo(print)` returns a table with all available
-- information about the `print` function. -- information about the `print` function.
function debug.getinfo(thread, function , what) end function debug.getinfo(thread, func , what) end
--- ---
-- This function returns the name and the value of the local variable with -- This function returns the name and the value of the local variable with
-- index `local` of the function at level `level` of the stack. (The first -- index `loc` of the function at level `level` of the stack. (The first
-- parameter or local variable has index 1, and so on, until the last active -- parameter or local variable has index 1, and so on, until the last active
-- local variable.) The function returns nil if there is no local variable -- local variable.) The function returns nil if there is no local variable
-- with the given index, and raises an error when called with a `level` out -- with the given index, and raises an error when called with a `level` out
-- of range. (You can call `debug.getinfo` to check whether the level is valid.) -- of range. (You can call `debug.getinfo` to check whether the level is valid.)
-- Variable names starting with '`(`' (open parentheses) represent internal -- Variable names starting with '`(`' (open parentheses) represent internal
-- variables (loop control variables, temporaries, and C function locals). -- variables (loop control variables, temporaries, and C function locals).
function debug.getlocal(thread, level, local) end function debug.getlocal(thread, level, loc) end
--- ---
-- Returns the metatable of the given `object` or nil if it does not have -- Returns the metatable of the given `object` or nil if it does not have
-- a metatable. -- a metatable.
function debug.getmetatable(object) end function debug.getmetatable(object) end
--- ---
-- Returns the registry table (see §3.5). -- Returns the registry table (see §3.5).
function debug.getregistry() end function debug.getregistry() end
--- ---
-- This function returns the name and the value of the upvalue with index -- This function returns the name and the value of the upvalue with index
-- `up` of the function `func`. The function returns nil if there is no -- `up` of the function `func`. The function returns nil if there is no
-- upvalue with the given index. -- upvalue with the given index.
function debug.getupvalue(func, up) end function debug.getupvalue(func, up) end
--- ---
-- Sets the environment of the given `object` to the given `table`. Returns -- Sets the environment of the given `object` to the given `table`. Returns
-- `object`. -- `object`.
function debug.setfenv(object, table) end function debug.setfenv(object, table) end
--- ---
-- Sets the given function as a hook. The string `mask` and the number -- Sets the given function as a hook. The string `mask` and the number
-- `count` describe when the hook will be called. The string mask may have -- `count` describe when the hook will be called. The string mask may have
-- the following characters, with the given meaning: -- the following characters, with the given meaning:
-- --
-- * `"c"`: the hook is called every time Lua calls a function; -- * `"c"`: the hook is called every time Lua calls a function;
-- * `"r"`: the hook is called every time Lua returns from a function; -- * `"r"`: the hook is called every time Lua returns from a function;
-- * `"l"`: the hook is called every time Lua enters a new line of code. -- * `"l"`: the hook is called every time Lua enters a new line of code.
-- --
-- With a `count` different from zero, the hook is called after every `count` -- With a `count` different from zero, the hook is called after every `count`
-- instructions. -- instructions.
-- --
-- When called without arguments, `debug.sethook` turns off the hook. -- When called without arguments, `debug.sethook` turns off the hook.
-- --
-- When the hook is called, its first parameter is a string describing -- When the hook is called, its first parameter is a string describing
-- the event that has triggered its call: `"call"`, `"return"` (or `"tail -- the event that has triggered its call: `"call"`, `"return"` (or `"tail
-- return"`, when simulating a return from a tail call), `"line"`, and -- return"`, when simulating a return from a tail call), `"line"`, and
-- `"count"`. For line events, the hook also gets the new line number as its -- `"count"`. For line events, the hook also gets the new line number as its
-- second parameter. Inside a hook, you can call `getinfo` with level 2 to -- second parameter. Inside a hook, you can call `getinfo` with level 2 to
-- get more information about the running function (level 0 is the `getinfo` -- get more information about the running function (level 0 is the `getinfo`
-- function, and level 1 is the hook function), unless the event is `"tail -- function, and level 1 is the hook function), unless the event is `"tail
-- return"`. In this case, Lua is only simulating the return, and a call to -- return"`. In this case, Lua is only simulating the return, and a call to
-- `getinfo` will return invalid data. -- `getinfo` will return invalid data.
function debug.sethook(thread, hook, mask , count) end function debug.sethook(thread, hook, mask , count) end
--- ---
-- This function assigns the value `value` to the local variable with -- This function assigns the value `value` to the local variable with
-- index `local` of the function at level `level` of the stack. The function -- index `loc` of the function at level `level` of the stack. The function
-- returns nil if there is no local variable with the given index, and raises -- returns nil if there is no local variable with the given index, and raises
-- an error when called with a `level` out of range. (You can call `getinfo` -- an error when called with a `level` out of range. (You can call `getinfo`
-- to check whether the level is valid.) Otherwise, it returns the name of -- to check whether the level is valid.) Otherwise, it returns the name of
-- the local variable. -- the local variable.
function debug.setlocal(thread, level, local, value) end function debug.setlocal(thread, level, loc, value) end
--- ---
-- Sets the metatable for the given `object` to the given `table` (which -- Sets the metatable for the given `object` to the given `table` (which
-- can be nil). -- can be nil).
function debug.setmetatable(object, table) end function debug.setmetatable(object, table) end
--- ---
-- This function assigns the value `value` to the upvalue with index `up` -- This function assigns the value `value` to the upvalue with index `up`
-- of the function `func`. The function returns nil if there is no upvalue -- of the function `func`. The function returns nil if there is no upvalue
-- with the given index. Otherwise, it returns the name of the upvalue. -- with the given index. Otherwise, it returns the name of the upvalue.
function debug.setupvalue(func, up, value) end function debug.setupvalue(func, up, value) end
return debug return debug

View File

@ -2,9 +2,11 @@
module 'global' module 'global'
-- luacheck: ignore 121
--- ---
-- Issues an error when its argument `v` is false. -- Issues an error when its argument `v` is false.
-- That is, nil or false. otherwise, returns all its arguments. -- That is, nil or false. otherwise, returns all its arguments.
-- `message` is an error when absent, it defaults to "assertion failed!" -- `message` is an error when absent, it defaults to "assertion failed!"
function assert(v , message) end function assert(v , message) end
@ -69,26 +71,26 @@ function getmetatable(object) end
function ipairs(t) end function ipairs(t) end
--- ---
-- Loads a chunk. -- Loads a chunk.
-- If `ld` is a string, the chunk is this string. -- If `ld` is a string, the chunk is this string.
-- If `ld` is a function, load calls it repeatedly to get the chunk pieces. Each call to `ld` must return a -- If `ld` is a function, load calls it repeatedly to get the chunk pieces. Each call to `ld` must return a
-- string that concatenates with previous results. A return of an empty string, nil, or no value -- string that concatenates with previous results. A return of an empty string, nil, or no value
-- signals the end of the chunk. -- signals the end of the chunk.
-- If there are no syntactic errors, returns the compiled chunk as a function; -- If there are no syntactic errors, returns the compiled chunk as a function;
-- otherwise, returns nil plus the error message. -- otherwise, returns nil plus the error message.
-- If the resulting function has upvalues, the first upvalue is set to the value of the global environment or to `env`, -- If the resulting function has upvalues, the first upvalue is set to the value of the global environment or to `env`,
-- if that parameter is given. When loading main chunks, the first upvalue will be the`_ENV` variable (see 2.2). -- if that parameter is given. When loading main chunks, the first upvalue will be the`_ENV` variable (see 2.2).
-- `source` is used as the source of the chunk for error messages and debug information (see 4.9). -- `source` is used as the source of the chunk for error messages and debug information (see 4.9).
-- When absent, it defaults to `ld`, if `ld` is a string, or to "=(load)" otherwise. -- When absent, it defaults to `ld`, if `ld` is a string, or to "=(load)" otherwise.
-- The string `mode` controls whether the chunk can be text or binary (that is, a precompiled chunk). -- The string `mode` controls whether the chunk can be text or binary (that is, a precompiled chunk).
-- It may be the string "b" (only binary chunks), "t" (only text chunks), or "bt" (both binary and text). -- It may be the string "b" (only binary chunks), "t" (only text chunks), or "bt" (both binary and text).
-- The default is "bt" -- The default is "bt"
function load (ld [, source [, mode [, env]]]) end function load (ld , source , mode , env) end
--- ---
-- Similar to `load`, but gets the chunk from file `filename`. Or from the -- Similar to `load`, but gets the chunk from file `filename`. Or from the
-- standard input, if no file name is given. -- standard input, if no file name is given.
function loadfile (filename [, mode [, env]]]) end function loadfile (filename , mode , env) end
--- ---
-- Allows a program to traverse all fields of a table. Its first argument is -- Allows a program to traverse all fields of a table. Its first argument is
@ -178,7 +180,7 @@ function setmetatable(table, metatable) end
-- 11, and so forth, with '`Z`' representing 35. In base 10 (the default), -- 11, and so forth, with '`Z`' representing 35. In base 10 (the default),
-- the number can have a decimal part, as well as an optional exponent part -- the number can have a decimal part, as well as an optional exponent part
-- (see 2.1). In other bases, only unsigned integers are accepted. -- (see 2.1). In other bases, only unsigned integers are accepted.
function tonumber(e [, base]) end function tonumber(e , base) end
--- ---
-- Converts any value to a string in a reasonable format. -- Converts any value to a string in a reasonable format.

View File

@ -1,159 +1,162 @@
--- Reading and Writing Files. --- Reading and Writing Files.
-- @module io -- @module io
local io = {} local io = {}
--- -- luacheck: ignore 241
-- Equivalent to `file:close()`. Without a `file`, closes the default local file = {}
-- output file.
function io.close(file) end ---
-- Equivalent to `file:close()`. Without a `file`, closes the default
--- -- output file.
-- Equivalent to `file:flush` over the default output file. function io.close(file) end
function io.flush() end
---
--- -- Equivalent to `file:flush` over the default output file.
-- When called with a file name, it opens the named file (in text mode), function io.flush() end
-- and sets its handle as the default input file. When called with a file
-- handle, it simply sets this file handle as the default input file. When ---
-- called without parameters, it returns the current default input file. -- When called with a file name, it opens the named file (in text mode),
-- In case of errors this function raises the error, instead of returning an -- and sets its handle as the default input file. When called with a file
-- error code. -- handle, it simply sets this file handle as the default input file. When
function io.input(file) end -- called without parameters, it returns the current default input file.
-- In case of errors this function raises the error, instead of returning an
--- -- error code.
-- Opens the given file name in read mode and returns an iterator function function io.input(file) end
-- that, each time it is called, returns a new line from the file. Therefore,
-- the construction ---
-- for line in io.lines(filename) do *body* end -- Opens the given file name in read mode and returns an iterator function
-- will iterate over all lines of the file. When the iterator function detects -- that, each time it is called, returns a new line from the file. Therefore,
-- the end of file, it returns nil (to finish the loop) and automatically -- the construction
-- closes the file. -- for line in io.lines(filename) do *body* end
-- The call `io.lines()` (with no file name) is equivalent to -- will iterate over all lines of the file. When the iterator function detects
-- `io.input():lines()`; that is, it iterates over the lines of the default -- the end of file, it returns nil (to finish the loop) and automatically
-- input file. In this case it does not close the file when the loop ends. -- closes the file.
function io.lines(filename) end -- The call `io.lines()` (with no file name) is equivalent to
-- `io.input():lines()`; that is, it iterates over the lines of the default
--- -- input file. In this case it does not close the file when the loop ends.
-- This function opens a file, in the mode specified in the string `mode`. It function io.lines(filename) end
-- returns a new file handle, or, in case of errors, nil plus an error message.
-- The `mode` string can be any of the following: ---
-- "r": read mode (the default); -- This function opens a file, in the mode specified in the string `mode`. It
-- "w": write mode; -- returns a new file handle, or, in case of errors, nil plus an error message.
-- "a": append mode; -- The `mode` string can be any of the following:
-- "r+": update mode, all previous data is preserved; -- "r": read mode (the default);
-- "w+": update mode, all previous data is erased; -- "w": write mode;
-- "a+": append update mode, previous data is preserved, writing is only -- "a": append mode;
-- allowed at the end of file. -- "r+": update mode, all previous data is preserved;
-- The `mode` string can also have a '`b`' at the end, which is needed in -- "w+": update mode, all previous data is erased;
-- some systems to open the file in binary mode. This string is exactly what -- "a+": append update mode, previous data is preserved, writing is only
-- is used in the standard C function `fopen`. -- allowed at the end of file.
function io.open(filename , mode) end -- The `mode` string can also have a '`b`' at the end, which is needed in
-- some systems to open the file in binary mode. This string is exactly what
--- -- is used in the standard C function `fopen`.
-- Similar to `io.input`, but operates over the default output file. function io.open(filename , mode) end
function io.output(file) end
---
--- -- Similar to `io.input`, but operates over the default output file.
-- Starts program `prog` in a separated process and returns a file handle function io.output(file) end
-- that you can use to read data from this program (if `mode` is `"r"`,
-- the default) or to write data to this program (if `mode` is `"w"`). ---
-- This function is system dependent and is not available on all platforms. -- Starts program `prog` in a separated process and returns a file handle
function io.popen(prog , mode) end -- that you can use to read data from this program (if `mode` is `"r"`,
-- the default) or to write data to this program (if `mode` is `"w"`).
--- -- This function is system dependent and is not available on all platforms.
-- Equivalent to `io.input():read`. function io.popen(prog , mode) end
function io.read(...) end
---
-- * `io.stderr`: Standard error. -- Equivalent to `io.input():read`.
-- * `io.stdin`: Standard in. function io.read(...) end
-- * `io.stdout`: Standard out.
-- * `io.stderr`: Standard error.
--- -- * `io.stdin`: Standard in.
-- Returns a handle for a temporary file. This file is opened in update -- * `io.stdout`: Standard out.
-- mode and it is automatically removed when the program ends.
function io.tmpfile() end ---
-- Returns a handle for a temporary file. This file is opened in update
--- -- mode and it is automatically removed when the program ends.
-- Checks whether `obj` is a valid file handle. Returns the string `"file"` function io.tmpfile() end
-- if `obj` is an open file handle, `"closed file"` if `obj` is a closed file
-- handle, or nil if `obj` is not a file handle. ---
function io.type(obj) end -- Checks whether `obj` is a valid file handle. Returns the string `"file"`
-- if `obj` is an open file handle, `"closed file"` if `obj` is a closed file
--- -- handle, or nil if `obj` is not a file handle.
-- Equivalent to `io.output():write`. function io.type(obj) end
function io.write(...) end
---
--- -- Equivalent to `io.output():write`.
-- Closes `file`. Note that files are automatically closed when their function io.write(...) end
-- handles are garbage collected, but that takes an unpredictable amount of
-- time to happen. ---
function file:close() end -- Closes `file`. Note that files are automatically closed when their
-- handles are garbage collected, but that takes an unpredictable amount of
--- -- time to happen.
-- Saves any written data to `file`. function file:close() end
function file:flush() end
---
--- -- Saves any written data to `file`.
-- Returns an iterator function that, each time it is called, returns a function file:flush() end
-- new line from the file. Therefore, the construction
-- for line in file:lines() do *body* end ---
-- will iterate over all lines of the file. (Unlike `io.lines`, this function -- Returns an iterator function that, each time it is called, returns a
-- does not close the file when the loop ends.) -- new line from the file. Therefore, the construction
function file:lines() end -- for line in file:lines() do *body* end
-- will iterate over all lines of the file. (Unlike `io.lines`, this function
--- -- does not close the file when the loop ends.)
-- Reads the file `file`, according to the given formats, which specify function file:lines() end
-- what to read. For each format, the function returns a string (or a number)
-- with the characters read, or nil if it cannot read data with the specified ---
-- format. When called without formats, it uses a default format that reads -- Reads the file `file`, according to the given formats, which specify
-- the entire next line (see below). -- what to read. For each format, the function returns a string (or a number)
-- The available formats are -- with the characters read, or nil if it cannot read data with the specified
-- "*n": reads a number; this is the only format that returns a number -- format. When called without formats, it uses a default format that reads
-- instead of a string. -- the entire next line (see below).
-- "*a": reads the whole file, starting at the current position. On end of -- The available formats are
-- file, it returns the empty string. -- "*n": reads a number; this is the only format that returns a number
-- "*l": reads the next line (skipping the end of line), returning nil on -- instead of a string.
-- end of file. This is the default format. -- "*a": reads the whole file, starting at the current position. On end of
-- *number*: reads a string with up to this number of characters, returning -- file, it returns the empty string.
-- nil on end of file. If number is zero, it reads nothing and returns an -- "*l": reads the next line (skipping the end of line), returning nil on
-- empty string, or nil on end of file. -- end of file. This is the default format.
function file:read(...) end -- *number*: reads a string with up to this number of characters, returning
-- nil on end of file. If number is zero, it reads nothing and returns an
--- -- empty string, or nil on end of file.
-- Sets and gets the file position, measured from the beginning of the function file:read(...) end
-- file, to the position given by `offset` plus a base specified by the string
-- `whence`, as follows: ---
-- "set": base is position 0 (beginning of the file); -- Sets and gets the file position, measured from the beginning of the
-- "cur": base is current position; -- file, to the position given by `offset` plus a base specified by the string
-- "end": base is end of file; -- `whence`, as follows:
-- In case of success, function `seek` returns the final file position, -- "set": base is position 0 (beginning of the file);
-- measured in bytes from the beginning of the file. If this function fails, -- "cur": base is current position;
-- it returns nil, plus a string describing the error. -- "end": base is end of file;
-- The default value for `whence` is `"cur"`, and for `offset` is 0. Therefore, -- In case of success, function `seek` returns the final file position,
-- the call `file:seek()` returns the current file position, without changing -- measured in bytes from the beginning of the file. If this function fails,
-- it; the call `file:seek("set")` sets the position to the beginning of the -- it returns nil, plus a string describing the error.
-- file (and returns 0); and the call `file:seek("end")` sets the position -- The default value for `whence` is `"cur"`, and for `offset` is 0. Therefore,
-- to the end of the file, and returns its size. -- the call `file:seek()` returns the current file position, without changing
function file:seek(whence , offset) end -- it; the call `file:seek("set")` sets the position to the beginning of the
-- file (and returns 0); and the call `file:seek("end")` sets the position
--- -- to the end of the file, and returns its size.
-- Sets the buffering mode for an output file. There are three available function file:seek(whence , offset) end
-- modes:
-- ---
-- * "no": no buffering; the result of any output operation appears immediately. -- Sets the buffering mode for an output file. There are three available
-- * "full": full buffering; output operation is performed only when the -- modes:
-- buffer is full (or when you explicitly `flush` the file (see `io.flush`)). --
-- * "line": line buffering; output is buffered until a newline is output or -- * "no": no buffering; the result of any output operation appears immediately.
-- there is any input from some special files (such as a terminal device). -- * "full": full buffering; output operation is performed only when the
-- For the last two cases, `size` specifies the size of the buffer, in -- buffer is full (or when you explicitly `flush` the file (see `io.flush`)).
-- bytes. The default is an appropriate size. -- * "line": line buffering; output is buffered until a newline is output or
function file:setvbuf(mode , size) end -- there is any input from some special files (such as a terminal device).
-- For the last two cases, `size` specifies the size of the buffer, in
--- -- bytes. The default is an appropriate size.
-- Writes the value of each of its arguments to the `file`. The arguments function file:setvbuf(mode , size) end
-- must be strings or numbers. To write other values, use `tostring` or
-- `string.format` before `write`. ---
function file:write(...) end -- Writes the value of each of its arguments to the `file`. The arguments
-- must be strings or numbers. To write other values, use `tostring` or
return io -- `string.format` before `write`.
function file:write(...) end
return io

View File

@ -1,191 +1,191 @@
--- string operations like searching and matching. --- string operations like searching and matching.
-- @module string -- @module string
local string = {} local string = {}
--- ---
-- Returns the internal numerical codes of the characters `s[i]`, `s[i+1]`, -- Returns the internal numerical codes of the characters `s[i]`, `s[i+1]`,
-- ..., `s[j]`. The default value for `i` is 1; the default value for `j` -- ..., `s[j]`. The default value for `i` is 1; the default value for `j`
-- is `i`. -- is `i`.
-- Note that numerical codes are not necessarily portable across platforms. -- Note that numerical codes are not necessarily portable across platforms.
function string.byte(s , i , j) end function string.byte(s , i , j) end
--- ---
-- Receives zero or more integers. Returns a string with length equal to -- Receives zero or more integers. Returns a string with length equal to
-- the number of arguments, in which each character has the internal numerical -- the number of arguments, in which each character has the internal numerical
-- code equal to its corresponding argument. -- code equal to its corresponding argument.
-- Note that numerical codes are not necessarily portable across platforms. -- Note that numerical codes are not necessarily portable across platforms.
function string.char(...) end function string.char(...) end
--- ---
-- Returns a string containing a binary representation of the given -- Returns a string containing a binary representation of the given
-- function, so that a later `loadstring` on this string returns a copy of -- function, so that a later `loadstring` on this string returns a copy of
-- the function. `function` must be a Lua function without upvalues. -- the function. `function` must be a Lua function without upvalues.
function string.dump(function) end function string.dump(func) end
--- ---
-- Looks for the first match of `pattern` in the string `s`. If it finds a -- Looks for the first match of `pattern` in the string `s`. If it finds a
-- match, then `find` returns the indices of `s` where this occurrence starts -- match, then `find` returns the indices of `s` where this occurrence starts
-- and ends; otherwise, it returns nil. A third, optional numerical argument -- and ends; otherwise, it returns nil. A third, optional numerical argument
-- `init` specifies where to start the search; its default value is 1 and -- `init` specifies where to start the search; its default value is 1 and
-- can be negative. A value of true as a fourth, optional argument `plain` -- can be negative. A value of true as a fourth, optional argument `plain`
-- turns off the pattern matching facilities, so the function does a plain -- turns off the pattern matching facilities, so the function does a plain
-- "find substring" operation, with no characters in `pattern` being considered -- "find substring" operation, with no characters in `pattern` being considered
-- "magic". Note that if `plain` is given, then `init` must be given as well. -- "magic". Note that if `plain` is given, then `init` must be given as well.
-- If the pattern has captures, then in a successful match the captured values -- If the pattern has captures, then in a successful match the captured values
-- are also returned, after the two indices. -- are also returned, after the two indices.
function string.find(s, pattern , init , plain) end function string.find(s, pattern , init , plain) end
--- ---
-- Returns a formatted version of its variable number of arguments following -- Returns a formatted version of its variable number of arguments following
-- the description given in its first argument (which must be a string). The -- the description given in its first argument (which must be a string). The
-- format string follows the same rules as the `printf` family of standard C -- format string follows the same rules as the `printf` family of standard C
-- functions. The only differences are that the options/modifiers `*`, `l`, -- functions. The only differences are that the options/modifiers `*`, `l`,
-- `L`, `n`, `p`, and `h` are not supported and that there is an extra option, -- `L`, `n`, `p`, and `h` are not supported and that there is an extra option,
-- `q`. The `q` option formats a string in a form suitable to be safely read -- `q`. The `q` option formats a string in a form suitable to be safely read
-- back by the Lua interpreter: the string is written between double quotes, -- back by the Lua interpreter: the string is written between double quotes,
-- and all double quotes, newlines, embedded zeros, and backslashes in the -- and all double quotes, newlines, embedded zeros, and backslashes in the
-- string are correctly escaped when written. For instance, the call -- string are correctly escaped when written. For instance, the call
-- --
-- string.format('%q', 'a string with "quotes" and \n new line') -- string.format('%q', 'a string with "quotes" and \n new line')
-- --
-- will produce the string: -- will produce the string:
-- --
-- "a string with \"quotes\" and \ -- "a string with \"quotes\" and \
-- new line" -- new line"
-- --
-- The options `c`, `d`, `E`, `e`, `f`, `g`, `G`, `i`, `o`, `u`, `X`, and -- The options `c`, `d`, `E`, `e`, `f`, `g`, `G`, `i`, `o`, `u`, `X`, and
-- `x` all expect a number as argument, whereas `q` and `s` expect a string. -- `x` all expect a number as argument, whereas `q` and `s` expect a string.
-- This function does not accept string values containing embedded zeros, -- This function does not accept string values containing embedded zeros,
-- except as arguments to the `q` option. -- except as arguments to the `q` option.
function string.format(formatstring, ...) end function string.format(formatstring, ...) end
--- ---
-- Returns an iterator function that, each time it is called, returns the -- Returns an iterator function that, each time it is called, returns the
-- next captures from `pattern` over string `s`. If `pattern` specifies no -- next captures from `pattern` over string `s`. If `pattern` specifies no
-- captures, then the whole match is produced in each call. -- captures, then the whole match is produced in each call.
-- As an example, the following loop -- As an example, the following loop
-- --
-- s = "hello world from Lua" -- s = "hello world from Lua"
-- for w in string.gmatch(s, "%a+") do -- for w in string.gmatch(s, "%a+") do
-- print(w) -- print(w)
-- end -- end
-- --
-- will iterate over all the words from string `s`, printing one per line. The -- will iterate over all the words from string `s`, printing one per line. The
-- next example collects all pairs `key=value` from the given string into -- next example collects all pairs `key=value` from the given string into
-- a table: -- a table:
-- --
-- t = {} -- t = {}
-- s = "from=world, to=Lua" -- s = "from=world, to=Lua"
-- for k, v in string.gmatch(s, "(%w+)=(%w+)") do -- for k, v in string.gmatch(s, "(%w+)=(%w+)") do
-- t[k] = v -- t[k] = v
-- end -- end
-- --
-- For this function, a '`^`' at the start of a pattern does not work as an -- For this function, a '`^`' at the start of a pattern does not work as an
-- anchor, as this would prevent the iteration. -- anchor, as this would prevent the iteration.
function string.gmatch(s, pattern) end function string.gmatch(s, pattern) end
--- ---
-- Returns a copy of `s` in which all (or the first `n`, if given) -- Returns a copy of `s` in which all (or the first `n`, if given)
-- occurrences of the `pattern` have been replaced by a replacement string -- occurrences of the `pattern` have been replaced by a replacement string
-- specified by `repl`, which can be a string, a table, or a function. `gsub` -- specified by `repl`, which can be a string, a table, or a function. `gsub`
-- also returns, as its second value, the total number of matches that occurred. -- also returns, as its second value, the total number of matches that occurred.
-- --
-- If `repl` is a string, then its value is used for replacement. The character -- If `repl` is a string, then its value is used for replacement. The character
-- `%` works as an escape character: any sequence in `repl` of the form `%n`, -- `%` works as an escape character: any sequence in `repl` of the form `%n`,
-- with *n* between 1 and 9, stands for the value of the *n*-th captured -- with *n* between 1 and 9, stands for the value of the *n*-th captured
-- substring (see below). The sequence `%0` stands for the whole match. The -- substring (see below). The sequence `%0` stands for the whole match. The
-- sequence `%%` stands for a single `%`. -- sequence `%%` stands for a single `%`.
-- --
-- If `repl` is a table, then the table is queried for every match, using -- If `repl` is a table, then the table is queried for every match, using
-- the first capture as the key; if the pattern specifies no captures, then -- the first capture as the key; if the pattern specifies no captures, then
-- the whole match is used as the key. -- the whole match is used as the key.
-- --
-- If `repl` is a function, then this function is called every time a match -- If `repl` is a function, then this function is called every time a match
-- occurs, with all captured substrings passed as arguments, in order; if -- occurs, with all captured substrings passed as arguments, in order; if
-- the pattern specifies no captures, then the whole match is passed as a -- the pattern specifies no captures, then the whole match is passed as a
-- sole argument. -- sole argument.
-- --
-- If the value returned by the table query or by the function call is a -- If the value returned by the table query or by the function call is a
-- string or a number, then it is used as the replacement string; otherwise, -- string or a number, then it is used as the replacement string; otherwise,
-- if it is false or nil, then there is no replacement (that is, the original -- if it is false or nil, then there is no replacement (that is, the original
-- match is kept in the string). -- match is kept in the string).
-- --
-- Here are some examples: -- Here are some examples:
-- x = string.gsub("hello world", "(%w+)", "%1 %1") -- x = string.gsub("hello world", "(%w+)", "%1 %1")
-- --> x="hello hello world world" -- --> x="hello hello world world"
-- x = string.gsub("hello world", "%w+", "%0 %0", 1) -- x = string.gsub("hello world", "%w+", "%0 %0", 1)
-- --> x="hello hello world" -- --> x="hello hello world"
-- x = string.gsub("hello world from Lua", "(%w+)%s*(%w+)", "%2 %1") -- x = string.gsub("hello world from Lua", "(%w+)%s*(%w+)", "%2 %1")
-- --> x="world hello Lua from" -- --> x="world hello Lua from"
-- x = string.gsub("home = $HOME, user = $USER", "%$(%w+)", os.getenv) -- x = string.gsub("home = $HOME, user = $USER", "%$(%w+)", os.getenv)
-- --> x="home = /home/roberto, user = roberto" -- --> x="home = /home/roberto, user = roberto"
-- x = string.gsub("4+5 = $return 4+5$", "%$(.-)%$", function (s) -- x = string.gsub("4+5 = $return 4+5$", "%$(.-)%$", function (s)
-- return loadstring(s)() -- return loadstring(s)()
-- end) -- end)
-- --> x="4+5 = 9" -- --> x="4+5 = 9"
-- local t = {name="lua", version="5.1"} -- local t = {name="lua", version="5.1"}
-- x = string.gsub("$name-$version.tar.gz", "%$(%w+)", t) -- x = string.gsub("$name-$version.tar.gz", "%$(%w+)", t)
-- --> x="lua-5.1.tar.gz" -- --> x="lua-5.1.tar.gz"
function string.gsub(s, pattern, repl , n) end function string.gsub(s, pattern, repl , n) end
--- ---
-- Receives a string and returns its length. The empty string `""` has -- Receives a string and returns its length. The empty string `""` has
-- length 0. Embedded zeros are counted, so `"a\000bc\000"` has length 5. -- length 0. Embedded zeros are counted, so `"a\000bc\000"` has length 5.
function string.len(s) end function string.len(s) end
--- ---
-- Receives a string and returns a copy of this string with all uppercase -- Receives a string and returns a copy of this string with all uppercase
-- letters changed to lowercase. All other characters are left unchanged. The -- letters changed to lowercase. All other characters are left unchanged. The
-- definition of what an uppercase letter is depends on the current locale. -- definition of what an uppercase letter is depends on the current locale.
function string.lower(s) end function string.lower(s) end
--- ---
-- Looks for the first *match* of `pattern` in the string `s`. If it -- Looks for the first *match* of `pattern` in the string `s`. If it
-- finds one, then `match` returns the captures from the pattern; otherwise -- finds one, then `match` returns the captures from the pattern; otherwise
-- it returns nil. If `pattern` specifies no captures, then the whole match -- it returns nil. If `pattern` specifies no captures, then the whole match
-- is returned. A third, optional numerical argument `init` specifies where -- is returned. A third, optional numerical argument `init` specifies where
-- to start the search; its default value is 1 and can be negative. -- to start the search; its default value is 1 and can be negative.
function string.match(s, pattern , init) end function string.match(s, pattern , init) end
--- ---
-- Returns a string that is the concatenation of `n` copies of the string -- Returns a string that is the concatenation of `n` copies of the string
-- `s`. -- `s`.
function string.rep(s, n) end function string.rep(s, n) end
--- ---
-- Returns a string that is the string `s` reversed. -- Returns a string that is the string `s` reversed.
function string.reverse(s) end function string.reverse(s) end
--- ---
-- Returns the substring of `s` that starts at `i` and continues until -- Returns the substring of `s` that starts at `i` and continues until
-- `j`; `i` and `j` can be negative. If `j` is absent, then it is assumed to -- `j`; `i` and `j` can be negative. If `j` is absent, then it is assumed to
-- be equal to -1 (which is the same as the string length). In particular, -- be equal to -1 (which is the same as the string length). In particular,
-- the call `string.sub(s,1,j)` returns a prefix of `s` with length `j`, and -- the call `string.sub(s,1,j)` returns a prefix of `s` with length `j`, and
-- `string.sub(s, -i)` returns a suffix of `s` with length `i`. -- `string.sub(s, -i)` returns a suffix of `s` with length `i`.
function string.sub(s, i , j) end function string.sub(s, i , j) end
--- ---
-- Receives a string and returns a copy of this string with all lowercase -- Receives a string and returns a copy of this string with all lowercase
-- letters changed to uppercase. All other characters are left unchanged. The -- letters changed to uppercase. All other characters are left unchanged. The
-- definition of what a lowercase letter is depends on the current locale. -- definition of what a lowercase letter is depends on the current locale.
function string.upper(s) end function string.upper(s) end
--- ---
-- (5.3) Returns a binary string containing the values v1, v2, etc. packed (that is, serialized in binary form) -- (5.3) Returns a binary string containing the values v1, v2, etc. packed (that is, serialized in binary form)
--- according to the format string fmt (see 6.4.2). --- according to the format string fmt (see 6.4.2).
function string.pack (fmt, v1, v2, ···) end function string.pack (fmt, v1, v2, ...) end
--- ---
-- (5.3) Returns the size of a string resulting from string.pack with the given format. -- (5.3) Returns the size of a string resulting from string.pack with the given format.
-- The format string cannot have the variable-length options 's' or 'z' (see 6.4.2). -- The format string cannot have the variable-length options 's' or 'z' (see 6.4.2).
function string.packsize (fmt) end function string.packsize (fmt) end
--- ---
-- (5.3) Returns the values packed in string s (see string.pack) according to the format string fmt (see 6.4.2). -- (5.3) Returns the values packed in string s (see string.pack) according to the format string fmt (see 6.4.2).
-- An optional pos marks where to start reading in s (default is 1) -- An optional pos marks where to start reading in s (default is 1)
-- After the read values, this function also returns the index of the first unread byte in s. -- After the read values, this function also returns the index of the first unread byte in s.
function string.unpack (fmt, s [, pos]) end function string.unpack (fmt, s , pos) end
return string return string

View File

@ -1,44 +1,46 @@
--- manipulating Lua tables. --- manipulating Lua tables.
-- @module table -- @module table
local table = {} local table = {}
--- ---
-- Given an array where all elements are strings or numbers, returns -- Given an array where all elements are strings or numbers, returns
-- `table[i]..sep..table[i+1] ... sep..table[j]`. The default value for -- `table[i]..sep..table[i+1] ... sep..table[j]`. The default value for
-- `sep` is the empty string, the default for `i` is 1, and the default for -- `sep` is the empty string, the default for `i` is 1, and the default for
-- `j` is the length of the table. If `i` is greater than `j`, returns the -- `j` is the length of the table. If `i` is greater than `j`, returns the
-- empty string. -- empty string.
function table.concat(table , sep , i , j) end function table.concat(table , sep , i , j) end
--- ---
-- Inserts element `value` at position `pos` in `table`, shifting up -- Inserts element `value` at position `pos` in `table`, shifting up
-- other elements to open space, if necessary. The default value for `pos` is -- other elements to open space, if necessary. The default value for `pos` is
-- `n+1`, where `n` is the length of the table (see §2.5.5), so that a call -- `n+1`, where `n` is the length of the table (see §2.5.5), so that a call
-- `table.insert(t,x)` inserts `x` at the end of table `t`. -- `table.insert(t,x)` inserts `x` at the end of table `t`.
function table.insert(table, pos, value) end function table.insert(table, pos, value) end
--- ---
-- Removes from `table` the element at position `pos`, shifting down other -- Removes from `table` the element at position `pos`, shifting down other
-- elements to close the space, if necessary. Returns the value of the removed -- elements to close the space, if necessary. Returns the value of the removed
-- element. The default value for `pos` is `n`, where `n` is the length of the -- element. The default value for `pos` is `n`, where `n` is the length of the
-- table, so that a call `table.remove(t)` removes the last element of table -- table, so that a call `table.remove(t)` removes the last element of table
-- `t`. -- `t`.
function table.remove(table , pos) end function table.remove(table , pos) end
--- ---
-- Returns a new table with all parameters stored into keys 1, 2, etc. and with a field "n" with -- Returns a new table with all parameters stored into keys 1, 2, etc. and with a field "n" with
-- the total number of parameters. Note that the resulting table may not be a sequence. -- the total number of parameters. Note that the resulting table may not be a sequence.
function table.pack (···) end function table.pack (...) end
--- ---
-- Sorts table elements in a given order, -- Sorts table elements in a given order,
-- *in-place*, from `table[1]` to `table[n]`, where `n` is the length of the -- *in-place*, from `table[1]` to `table[n]`, where `n` is the length of the
-- table. If `comp` is given, then it must be a function that receives two -- table. If `comp` is given, then it must be a function that receives two
-- table elements, and returns true when the first is less than the second -- table elements, and returns true when the first is less than the second
-- (so that `not comp(a[i+1],a[i])` will be true after the sort). If `comp` -- (so that `not comp(a[i+1],a[i])` will be true after the sort). If `comp`
-- is not given, then the '<' operator will be used. -- is not given, then the '<' operator will be used.
function table.sort(table , comp) end function table.sort(table , comp) end
-- luacheck: ignore 121
--- ---
-- Returns the elements from the given table. This function is equivalent to -- Returns the elements from the given table. This function is equivalent to
-- return list[i], list[i+1], ..., list[j] -- return list[i], list[i+1], ..., list[j]
@ -46,5 +48,5 @@ function table.sort(table , comp) end
-- elements. By default, `i` is 1 and `j` is the length of the list, as -- elements. By default, `i` is 1 and `j` is the length of the list, as
-- defined by the length operator (see §2.5.5). -- defined by the length operator (see §2.5.5).
function unpack(list , i , j) end function unpack(list , i , j) end
return table return table

View File

@ -1,48 +1,48 @@
--- This library provides basic support for UTF-8 encoding. --- This library provides basic support for UTF-8 encoding.
-- @module utf8 -- @module utf8
local utf8 = {} local utf8 = {}
--- ---
-- Receives zero or more integers, converts each one to its corresponding UTF-8 byte sequence and returns -- Receives zero or more integers, converts each one to its corresponding UTF-8 byte sequence and returns
-- a string with the concatenation of all these sequences. -- a string with the concatenation of all these sequences.
function utf8.char (...) end function utf8.char (...) end
--- ---
-- The pattern "[\0-\x7F\xC2-\xF4][\x80-\xBF]*" , which matches exactly one -- The pattern "[\0-\x7F\xC2-\xF4][\x80-\xBF]*" , which matches exactly one
-- UTF-8 byte sequence, assuming that the subject is a valid UTF-8 string. -- UTF-8 byte sequence, assuming that the subject is a valid UTF-8 string.
-- @field charpattern -- @field charpattern
--- ---
-- Iterate over all characters in string. -- Iterate over all characters in string.
-- --
-- for p, c in utf8.codes(s) do body end -- for p, c in utf8.codes(s) do body end
-- --
-- will iterate over all characters in string s, with p being the position (in bytes) and c the code point -- will iterate over all characters in string s, with p being the position (in bytes) and c the code point
-- of each character. It raises an error if it meets any invalid byte sequence. -- of each character. It raises an error if it meets any invalid byte sequence.
function utf8.codes (s) end function utf8.codes (s) end
---
-- Returns the codepoints (as integers) from all characters in s that start between byte position i and j (both included).
-- The default for i is 1 and for j is i. It raises an error if it meets any invalid byte sequence.
function utf8.codepoint (s [, i [, j]]) end
--- ---
-- Returns the number of UTF-8 characters in string s that start between positions i and j (both inclusive). -- Returns the codepoints (as integers) from all characters in s that start between byte position i and j (both included).
-- The default for i is 1 and for j is i. It raises an error if it meets any invalid byte sequence.
function utf8.codepoint (s , i , j) end
---
-- Returns the number of UTF-8 characters in string s that start between positions i and j (both inclusive).
-- The default for i is 1 and for j is -1. If it finds any invalid byte sequence, returns a false value plus -- The default for i is 1 and for j is -1. If it finds any invalid byte sequence, returns a false value plus
-- the position of the first invalid byte. -- the position of the first invalid byte.
function utf8.len (s [, i [, j]]) end function utf8.len (s , i , j) end
--- ---
-- Returns the position (in bytes) where the encoding of the n-th character of s (counting from position i) starts. -- Returns the position (in bytes) where the encoding of the n-th character of s (counting from position i) starts.
-- A negative n gets characters before position i. The default for i is 1 when n is non-negative -- A negative n gets characters before position i. The default for i is 1 when n is non-negative
-- and #s + 1 otherwise, so that utf8.offset(s, -n) gets the offset of the n-th character from the end -- and #s + 1 otherwise, so that utf8.offset(s, -n) gets the offset of the n-th character from the end
-- of the string. -- of the string.
-- If the specified character is neither in the subject nor right after its end, the function returns nil. -- If the specified character is neither in the subject nor right after its end, the function returns nil.
-- --
-- As a special case, when n is 0 the function returns the start of the encoding of the character that contains the i-th byte of s. -- As a special case, when n is 0 the function returns the start of the encoding of the character that contains the i-th byte of s.
-- --
-- This function assumes that s is a valid UTF-8 string. -- This function assumes that s is a valid UTF-8 string.
function utf8.offset (s, n [, i]) end function utf8.offset (s, n , i) end
return utf8

View File

@ -192,12 +192,6 @@ function File:export_item (name)
self:warning('no docs '..tools.quote(name)) self:warning('no docs '..tools.quote(name))
end end
local function has_prefix (name,prefix)
local i1,i2 = name:find(prefix)
return i1 == 1 and i2 == #prefix
end
local function mod_section_type (this_mod) local function mod_section_type (this_mod)
return this_mod and this_mod.section and this_mod.section.type return this_mod and this_mod.section and this_mod.section.type
end end
@ -236,6 +230,7 @@ function File:finish()
end end
item:finish() item:finish()
-- the default is not to show local functions in the documentation. -- the default is not to show local functions in the documentation.
-- luacheck: push ignore 542
if not self.args.all and (item.type=='lfunction' or (item.tags and item.tags['local'])) then if not self.args.all and (item.type=='lfunction' or (item.tags and item.tags['local'])) then
-- don't add to the module -- -- don't add to the module --
elseif doc.project_level(item.type) then elseif doc.project_level(item.type) then
@ -257,9 +252,9 @@ function File:finish()
end end
end end
elseif item.type == 'submodule' then elseif item.type == 'submodule' then
local mf local _
submodule = true submodule = true
this_mod,mf = self:find_module_in_files(item.name) this_mod,_ = self:find_module_in_files(item.name)
if this_mod == nil then if this_mod == nil then
self:error("'"..item.name.."' not found for submodule") self:error("'"..item.name.."' not found for submodule")
end end
@ -409,6 +404,7 @@ function File:finish()
-- must be a free-standing function (sometimes a problem...) -- must be a free-standing function (sometimes a problem...)
end end
end end
-- luacheck: pop
item.names_hierarchy = require('pl.utils').split( item.names_hierarchy = require('pl.utils').split(
item.name, item.name,
'[.:]' '[.:]'
@ -495,7 +491,6 @@ function Item:set_tag (tag,value)
end end
self.tags[tag] = value self.tags[tag] = value
elseif ttype == TAG_ID then elseif ttype == TAG_ID then
local modifiers
if type(value) == 'table' then if type(value) == 'table' then
if value.append then -- it was a List! if value.append then -- it was a List!
-- such tags are _not_ multiple, e.g. name -- such tags are _not_ multiple, e.g. name
@ -506,7 +501,6 @@ function Item:set_tag (tag,value)
end end
end end
value = value[1] value = value[1]
modifiers = value.modifiers
end end
if value == nil then self:error("Tag without value: "..tag) end if value == nil then self:error("Tag without value: "..tag) end
local id, rest = tools.extract_identifier(value) local id, rest = tools.extract_identifier(value)
@ -543,17 +537,13 @@ function Item.check_tag(tags,tag, value, modifiers)
if avalue then value = avalue..' '..value end if avalue then value = avalue..' '..value end
if amod then if amod then
modifiers = modifiers or {} modifiers = modifiers or {}
local value_tokens = utils.split(value)
for m,v in pairs(amod) do for m,v in pairs(amod) do
local idx = tonumber(v:match('^%$(%d+)')) local idx = tonumber(v:match('^%$(%d+)'))
if idx then if idx then
v, value = value:match('(%S+)(.*)') v, value = value:match('(%S+)(.*)')
-- v = value_tokens[idx]
-- value_tokens[idx] = ''
end end
modifiers[m] = v modifiers[m] = v
end end
-- value = table.concat(value_tokens, ' ')
end end
else -- has to be a function that at least returns tag, value else -- has to be a function that at least returns tag, value
return alias(tags,value,modifiers) return alias(tags,value,modifiers)
@ -927,8 +917,6 @@ function Item:return_type(r)
return r.type, r.ctypes return r.type, r.ctypes
end end
local struct_return_type = '*'
function Item:build_return_groups() function Item:build_return_groups()
local quote = tools.quote local quote = tools.quote
local modifiers = self.modifiers local modifiers = self.modifiers
@ -1062,8 +1050,6 @@ function Module:hunt_for_reference (packmod, modules)
return mod_ref return mod_ref
end end
local err = io.stderr
local function custom_see_references (s) local function custom_see_references (s)
for pat, action in pairs(see_reference_handlers) do for pat, action in pairs(see_reference_handlers) do
if s:match(pat) then if s:match(pat) then
@ -1099,7 +1085,7 @@ end
function Module:process_see_reference (s,modules,istype) function Module:process_see_reference (s,modules,istype)
if s == nil then return nil end if s == nil then return nil end
local mod_ref,fun_ref,name,packmod local fun_ref
local ref = custom_see_references(s) local ref = custom_see_references(s)
if ref then return ref end if ref then return ref end
if not s:match '^[%w_%.\\%:%-]+$' or not s:match '[%w_]$' then if not s:match '^[%w_%.\\%:%-]+$' or not s:match '[%w_]$' then
@ -1301,7 +1287,6 @@ function File:dump(verbose)
end end
function Item:dump(verbose) function Item:dump(verbose)
local tags = self.tags
local name = self.name local name = self.name
if self.type == 'function' then if self.type == 'function' then
name = name .. self.args name = name .. self.args

View File

@ -152,9 +152,9 @@ function html.generate_output(ldoc, args, project)
end end
return base..name..'.html' return base..name..'.html'
end end
function ldoc.include_file (file) function ldoc.include_file (file)
local text,e = utils.readfile(file) local text,_ = utils.readfile(file)
if not text then quit("unable to include "..file) if not text then quit("unable to include "..file)
else else
return text return text
@ -212,7 +212,7 @@ function ldoc.source_ref (fun)
function ldoc.is_list (t) function ldoc.is_list (t)
return type(t) == 'table' and t.append return type(t) == 'table' and t.append
end end
function ldoc.strip_header (s) function ldoc.strip_header (s)
if not s then return s end if not s then return s end
return s:gsub('^%s*#+%s+','') return s:gsub('^%s*#+%s+','')
@ -234,7 +234,7 @@ function ldoc.source_ref (fun)
local types = {} local types = {}
for name in tp:gmatch("[^|]+") do for name in tp:gmatch("[^|]+") do
local sym = name:match '([%w%.%:]+)' local sym = name:match '([%w%.%:]+)'
local ref,err = markup.process_reference(sym,true) local ref,_ = markup.process_reference(sym,true)
if ref then if ref then
if ref.label and sym == name then if ref.label and sym == name then
name = ref.label name = ref.label
@ -273,7 +273,7 @@ function ldoc.source_ref (fun)
ldoc.doc_charset = (m and m.tags.charset) or ldoc.charset ldoc.doc_charset = (m and m.tags.charset) or ldoc.charset
end end
local module_template,err = utils.readfile (path.join(args.template,ldoc.templ)) local module_template,_ = utils.readfile (path.join(args.template,ldoc.templ))
if not module_template then if not module_template then
quit("template not found at '"..args.template.."' Use -l to specify directory containing ldoc.ltp") quit("template not found at '"..args.template.."' Use -l to specify directory containing ldoc.ltp")
end end

View File

@ -1,5 +1,5 @@
return [[ return [[
body { body {
color: #47555c; color: #47555c;
font-size: 16px; font-size: 16px;
font-family: "Open Sans", sans-serif; font-family: "Open Sans", sans-serif;

View File

@ -93,6 +93,7 @@ function Lua:grab_block_comment(v,tok)
end end
-- luacheck: push ignore 312
function Lua:parse_module_call(tok,t,v) function Lua:parse_module_call(tok,t,v)
t,v = tnext(tok) t,v = tnext(tok)
if t == '(' then t,v = tnext(tok) end if t == '(' then t,v = tnext(tok) end
@ -102,6 +103,7 @@ function Lua:parse_module_call(tok,t,v)
return '...',t,v return '...',t,v
end end
end end
-- luacheck: pop
-- If a module name was not provided, then we look for an explicit module() -- If a module name was not provided, then we look for an explicit module()
-- call. However, we should not try too hard; if we hit a doc comment then -- call. However, we should not try too hard; if we hit a doc comment then
@ -150,7 +152,7 @@ function Lua:item_follows(t,v,tok)
case = 1 case = 1
parser = parse_lua_function_header parser = parse_lua_function_header
elseif t == 'iden' then elseif t == 'iden' then
local name,t,v = tools.get_fun_name(tok,v) local name,t,_ = tools.get_fun_name(tok,v)
if t ~= '=' then return nil,"not 'name = function,table or value'" end if t ~= '=' then return nil,"not 'name = function,table or value'" end
t,v = tnext(tok) t,v = tnext(tok)
if t == 'keyword' and v == 'function' then -- case [2] if t == 'keyword' and v == 'function' then -- case [2]
@ -229,7 +231,7 @@ function Lua:parse_module_modifier (tags, tok, F)
if tags.class ~= 'field' then return nil,"cannot deduce @usage" end if tags.class ~= 'field' then return nil,"cannot deduce @usage" end
local t1= tnext(tok) local t1= tnext(tok)
if t1 ~= '[' then return nil, t1..' '..': not a long string' end if t1 ~= '[' then return nil, t1..' '..': not a long string' end
local t, v = tools.grab_block_comment('',tok,'%]%]') local _, v = tools.grab_block_comment('',tok,'%]%]')
return true, v, 'usage' return true, v, 'usage'
elseif tags.export then elseif tags.export then
if tags.class ~= 'table' then return nil, "cannot deduce @export" end if tags.class ~= 'table' then return nil, "cannot deduce @export" end
@ -285,12 +287,13 @@ function CC:item_follows (t,v,tok)
return false return false
end end
if t == 'iden' or t == 'keyword' then -- if t == 'iden' or t == 'keyword' then --
local _
if v == self.extra.export then -- this is not part of the return type! if v == self.extra.export then -- this is not part of the return type!
t,v = tnext(tok) _,v = tnext(tok)
end end
-- types may have multiple tokens: example, const char *bonzo(...) -- types may have multiple tokens: example, const char *bonzo(...)
local return_type, name = v local return_type, name = v
t,v = tnext(tok) _,v = tnext(tok)
name = v name = v
t,v = tnext(tok) t,v = tnext(tok)
while t ~= '(' do while t ~= '(' do
@ -305,7 +308,7 @@ function CC:item_follows (t,v,tok)
end end
tags:add('class','function') tags:add('class','function')
if t == '(' then if t == '(' then
tags.formal_args,t,v = tools.get_parameters(tok,')',',',self) tags.formal_args,t,_ = tools.get_parameters(tok,')',',',self)
if return_type ~= 'void' then if return_type ~= 'void' then
tags.formal_args.return_type = return_type tags.formal_args.return_type = return_type
end end
@ -342,30 +345,28 @@ function Moon:item_follows (t,v,tok)
if t == 'iden' then if t == 'iden' then
local name,t,v = tools.get_fun_name(tok,v,'') local name,t,v = tools.get_fun_name(tok,v,'')
if name == 'class' then if name == 'class' then
name,t,v = tools.get_fun_name(tok,v,'') local _
name,_,_ = tools.get_fun_name(tok,v,'')
-- class! -- class!
return function(tags,tok) return function(tags,tok)
tags:add('class','type') tags:add('class','type')
tags:add('name',name) tags:add('name',name)
end end
elseif t == '=' or t == ':' then -- function/method elseif t == '=' or t == ':' then -- function/method
local fat = false local _
t,v = tnext(tok) t,_ = tnext(tok)
return function(tags,tok) return function(tags,tok)
if not tags.name then if not tags.name then
tags:add('name',name) tags:add('name',name)
end end
if t == '(' then if t == '(' then
tags.formal_args,t,v = tools.get_parameters(tok,')',',',self) tags.formal_args,t,_ = tools.get_parameters(tok,')',',',self)
else else
tags.formal_args = List() tags.formal_args = List()
end end
t,v = tnext(tok) t,_ = tnext(tok)
tags:add('class','function') tags:add('class','function')
if t == '>' then if t ~= '>' then
--~ tags.formal_args:insert(1,'self')
--~ tags.formal_args.comments = {self=''}
else
tags.static = true tags.static = true
end end
end end

View File

@ -171,7 +171,7 @@ function lexer.scan (s,matches,filter,options)
end end
matches = plain_matches matches = plain_matches
end end
local i1,i2,idx,res1,res2,tok,pat,fun,capt local i1,i2,tok,pat,fun
local line = 1 local line = 1
if file then if file then
s = file:read() s = file:read()

View File

@ -149,9 +149,6 @@ local function map(t, f)
return out return out
end end
-- The identity function, useful as a placeholder.
local function identity(text) return text end
-- Functional style if statement. (NOTE: no short circuit evaluation) -- Functional style if statement. (NOTE: no short circuit evaluation)
local function iff(t, a, b) if t then return a else return b end end local function iff(t, a, b) if t then return a else return b end end
@ -252,7 +249,7 @@ local function tokenize_html(html)
end end
if not stop then if not stop then
-- error("Could not match html tag " .. html:sub(start,start+30)) -- error("Could not match html tag " .. html:sub(start,start+30))
table.insert(tokens, {type="text", text=html:sub(start, start)}) table.insert(tokens, {type="text", text=html:sub(start, start)})
pos = start + 1 pos = start + 1
else else
table.insert(tokens, {type="tag", text=html:sub(start, stop)}) table.insert(tokens, {type="tag", text=html:sub(start, stop)})
@ -641,12 +638,14 @@ local function blockquotes(lines)
local stop = #lines local stop = #lines
for i = start+1, #lines do for i = start+1, #lines do
-- luacheck: push ignore 542
if lines[i].type == "blank" or lines[i].type == "blockquote" then if lines[i].type == "blank" or lines[i].type == "blockquote" then
elseif lines[i].type == "normal" then elseif lines[i].type == "normal" then
if lines[i-1].type == "blank" then stop = i-1 break end if lines[i-1].type == "blank" then stop = i-1 break end
else else
stop = i-1 break stop = i-1 break
end end
-- luacheck: pop
end end
while lines[stop].type == "blank" do stop = stop - 1 end while lines[stop].type == "blank" do stop = stop - 1 end
return start, stop return start, stop
@ -766,14 +765,6 @@ function block_transform(text, sublist)
return text return text
end end
-- Debug function for printing a line array to see the result
-- of partial transforms.
local function print_lines(lines)
for i, line in ipairs(lines) do
print(i, line.type, line.text or line.line)
end
end
---------------------------------------------------------------------- ----------------------------------------------------------------------
-- Span transform -- Span transform
---------------------------------------------------------------------- ----------------------------------------------------------------------
@ -880,7 +871,6 @@ local function code_spans(s)
pos = stop + 1 pos = stop + 1
end end
end end
return s
end end
-- Encode alt text... enodes &, and ". -- Encode alt text... enodes &, and ".
@ -1177,10 +1167,12 @@ function OptionParser:run(args)
while pos <= #args do while pos <= #args do
local arg = args[pos] local arg = args[pos]
if arg == "--" then if arg == "--" then
-- luacheck: push ignore 512
for i=pos+1,#args do for i=pos+1,#args do
if self.arg then self.arg(args[i]) end if self.arg then self.arg(args[i]) end
return true return true
end end
-- luacheck: pop
end end
if arg:match("^%-%-") then if arg:match("^%-%-") then
local info = self.long[arg:sub(3)] local info = self.long[arg:sub(3)]
@ -1229,7 +1221,7 @@ local function run_command_line(arg)
local function run(s, options) local function run(s, options)
s = markdown(s) s = markdown(s)
if not options.wrap_header then return s end if not options.wrap_header then return s end
local header = "" local header
if options.header then if options.header then
local f = io.open(options.header) or error("Could not open file: " .. options.header) local f = io.open(options.header) or error("Could not open file: " .. options.header)
header = f:read("*a") header = f:read("*a")

View File

@ -7,7 +7,7 @@ local doc = require 'ldoc.doc'
local utils = require 'pl.utils' local utils = require 'pl.utils'
local stringx = require 'pl.stringx' local stringx = require 'pl.stringx'
local prettify = require 'ldoc.prettify' local prettify = require 'ldoc.prettify'
local quit, concat, lstrip = utils.quit, table.concat, stringx.lstrip local concat = table.concat
local markup = {} local markup = {}
local backtick_references local backtick_references
@ -53,7 +53,7 @@ local function resolve_inline_references (ldoc, txt, item, plain)
end)) end))
if backtick_references then if backtick_references then
res = res:gsub('`([^`]+)`',function(name) res = res:gsub('`([^`]+)`',function(name)
local ref,err = markup.process_reference(name) local ref,_ = markup.process_reference(name)
local label = name local label = name
if name and do_escape then if name and do_escape then
label = name:gsub('_', '\\_') label = name:gsub('_', '\\_')
@ -135,10 +135,10 @@ local function process_multiline_markdown(ldoc, txt, F, filename, deflang)
local function pretty_code (code, lang) local function pretty_code (code, lang)
code = concat(code,'\n') code = concat(code,'\n')
if code ~= '' then if code ~= '' then
local err local _
-- If we omit the following '\n', a '--' (or '//') comment on the -- If we omit the following '\n', a '--' (or '//') comment on the
-- last line won't be recognized. -- last line won't be recognized.
code, err = prettify.code(lang,filename,code..'\n',L,false) code, _ = prettify.code(lang,filename,code..'\n',L,false)
code = resolve_inline_references(ldoc, code, err_item,true) code = resolve_inline_references(ldoc, code, err_item,true)
append(res,'<pre>') append(res,'<pre>')
append(res, code) append(res, code)
@ -237,6 +237,7 @@ local formatters =
discount = function(format) discount = function(format)
local ok, markdown = pcall(require, 'discount') local ok, markdown = pcall(require, 'discount')
if ok then if ok then
-- luacheck: push ignore 542
if 'function' == type(markdown) then if 'function' == type(markdown) then
-- lua-discount by A.S. Bradbury, https://luarocks.org/modules/luarocks/lua-discount -- lua-discount by A.S. Bradbury, https://luarocks.org/modules/luarocks/lua-discount
elseif 'table' == type(markdown) and ('function' == type(markdown.compile) or 'function' == type(markdown.to_html)) then elseif 'table' == type(markdown) and ('function' == type(markdown.compile) or 'function' == type(markdown.to_html)) then
@ -254,12 +255,13 @@ local formatters =
end end
else else
io.stderr:write('LDoc discount failed with error ',errmsg) io.stderr:write('LDoc discount failed with error ',errmsg)
io.exit(1) os.exit(1)
end end
end end
else else
ok = false ok = false
end end
-- luacheck: pop
end end
if not ok then if not ok then
print('format: using built-in markdown') print('format: using built-in markdown')

View File

@ -2,7 +2,7 @@
local utils = require 'pl.utils' local utils = require 'pl.utils'
local List = require 'pl.List' local List = require 'pl.List'
local Map = require 'pl.Map' -- local Map = require 'pl.Map'
local stringio = require 'pl.stringio' local stringio = require 'pl.stringio'
local lexer = require 'ldoc.lexer' local lexer = require 'ldoc.lexer'
local tools = require 'ldoc.tools' local tools = require 'ldoc.tools'
@ -161,12 +161,6 @@ local function extract_tags (s,args)
return tags --Map(tags) return tags --Map(tags)
end end
local _xpcall = xpcall
if true then
_xpcall = function(f) return true, f() end
end
-- parses a Lua or C file, looking for ldoc comments. These are like LuaDoc comments; -- parses a Lua or C file, looking for ldoc comments. These are like LuaDoc comments;
-- they start with multiple '-'. (Block commments are allowed) -- they start with multiple '-'. (Block commments are allowed)
@ -176,7 +170,6 @@ end
-- module if there isn't an explicit module name specified. -- module if there isn't an explicit module name specified.
local function parse_file(fname, lang, package, args) local function parse_file(fname, lang, package, args)
local line,f = 1
local F = File(fname) local F = File(fname)
local module_found, first_comment = false,true local module_found, first_comment = false,true
local current_item, module_item local current_item, module_item
@ -192,10 +185,7 @@ local function parse_file(fname, lang, package, args)
return tok:lineno() return tok:lineno()
end end
local function filename () return fname end
function F:warning (msg,kind,line) function F:warning (msg,kind,line)
kind = kind or 'warning'
line = line or lineno() line = line or lineno()
Item.had_warning = true Item.had_warning = true
io.stderr:write(fname..':'..line..': '..msg,'\n') io.stderr:write(fname..':'..line..': '..msg,'\n')
@ -307,7 +297,7 @@ local function parse_file(fname, lang, package, args)
module_found = tags.name module_found = tags.name
-- might be a module returning a single function! -- might be a module returning a single function!
if tags.param or tags['return'] then if tags.param or tags['return'] then
local parms, ret, summ = tags.param, tags['return'],tags.summary local parms, ret = tags.param, tags['return']
local name = tags.name local name = tags.name
tags.param = nil tags.param = nil
tags['return'] = nil tags['return'] = nil

View File

@ -30,8 +30,8 @@ local spans = {keyword=true,number=true,string=true,comment=true,global=true,bac
local cpp_lang = {C = true, c = true, cpp = true, cxx = true, h = true} local cpp_lang = {C = true, c = true, cpp = true, cxx = true, h = true}
function prettify.lua (lang, fname, code, initial_lineno, pre, linenos) function prettify.lua (lang, fname, code, initial_lineno, pre, linenos)
local res, lexer, tokenizer = List(), require 'ldoc.lexer' local res, lexer = List(), require 'ldoc.lexer'
local tnext = lexer.skipws local tokenizer
local ik = 1 local ik = 1
if not cpp_lang[lang] then if not cpp_lang[lang] then
tokenizer = lexer.lua tokenizer = lexer.lua

View File

@ -79,7 +79,7 @@ end
function KindMap:put_kind_first (kind) function KindMap:put_kind_first (kind)
-- find this kind in our kind list -- find this kind in our kind list
local kinds = self.klass.kinds,kind local kinds = self.klass.kinds
local idx = tablex.find(kinds,kind) local idx = tablex.find(kinds,kind)
-- and swop with the start! -- and swop with the start!
if idx then if idx then
@ -232,8 +232,9 @@ end
function M.check_file (f,original) function M.check_file (f,original)
if not path.exists(f) or path.getmtime(original) > path.getmtime(f) then if not path.exists(f) or path.getmtime(original) > path.getmtime(f) then
local text,err = utils.readfile(original) local text,err = utils.readfile(original)
local _
if text then if text then
text,err = utils.writefile(f,text) _,err = utils.writefile(f,text)
end end
if err then if err then
quit("Could not copy "..original.." to "..f) quit("Could not copy "..original.." to "..f)
@ -250,13 +251,12 @@ function M.writefile(name,text)
end end
function M.name_of (lpath) function M.name_of (lpath)
local ext local _
lpath,ext = path.splitext(lpath) lpath,_ = path.splitext(lpath)
return lpath return lpath
end end
function M.this_module_name (basename,fname) function M.this_module_name (basename,fname)
local ext
if basename == '' then if basename == '' then
return M.name_of(fname) return M.name_of(fname)
end end
@ -429,7 +429,7 @@ end
-- Set `colon` to be the secondary separator, '' for none. -- Set `colon` to be the secondary separator, '' for none.
function M.get_fun_name (tok,first,colon) function M.get_fun_name (tok,first,colon)
local res = {} local res = {}
local t,name,sep local t,name,sep,_
colon = colon or ':' colon = colon or ':'
if not first then if not first then
t,name = tnext(tok) t,name = tnext(tok)
@ -441,7 +441,7 @@ function M.get_fun_name (tok,first,colon)
while sep == '.' or sep == colon do while sep == '.' or sep == colon do
append(res,name) append(res,name)
append(res,sep) append(res,sep)
t,name = tnext(tok) _,name = tnext(tok)
t,sep = tnext(tok) t,sep = tnext(tok)
end end
append(res,name) append(res,name)

View File

@ -1,18 +1,20 @@
local run local PWD = os.getenv("PWD")
if not arg[1] then
run = function (dir) local run
local cmd = 'cd '..dir..' && ldoc --testing . && diff -r doc cdocs' if not arg[1] then
print(cmd) run = function (dir)
os.execute(cmd) local cmd = 'cd '..dir..' && lua '..PWD..'/ldoc.lua --testing . && diff -r doc cdocs'
end print(cmd)
elseif arg[1] == 'update' then os.execute(cmd)
run = function (dir) end
local cmd = 'cd '..dir..' && ldoc --dir cdocs --testing .' elseif arg[1] == 'update' then
print(cmd) run = function (dir)
os.execute(cmd) local cmd = 'cd '..dir..' && lua '..PWD..'/ldoc.lua --dir cdocs --testing .'
end print(cmd)
end os.execute(cmd)
end
for _,d in ipairs{'tests','tests/example','tests/md-test'} do end
run(d)
end for _,d in ipairs{'tests','tests/example','tests/md-test'} do
run(d)
end