Module luarocks.type_check

Type-checking functions.

Functions and definitions for doing a basic lint check on files loaded by LuaRocks.

Functions

type_check_table (tbl, types, context) Type check the contents of a table.
type_check_rockspec (rockspec) Type check a rockspec table.
type_check_manifest (manifest) Type check a manifest table.


Functions

type_check_table (tbl, types, context)
Type check the contents of a table. The table's contents are compared against a reference table, which contains the recognized fields, with archetypical values matching the expected types -- the actual values of items in the reference table don't matter, only their types (ie, for field x in tbl that is correctly typed, type(tbl.x) == type(types.x)). If the reference table contains a field called MORE, then unknown fields in the checked table are accepted. If it contains a field called ANY, then its type will be used to check any unknown fields. If a field is prefixed with MUST_, it is mandatory; its absence from the table is a type error. Tables are type checked recursively.

Parameters:

  • tbl: table: The table to be type checked.
  • types: table: The reference table, containing values for recognized fields in the checked table.
  • context:

Returns:

    boolean or (nil, string): true if type checking succeeded, or nil and an error message if it failed.
type_check_rockspec (rockspec)
Type check a rockspec table. Verify the correctness of elements from a rockspec table, reporting on unknown fields and type mismatches.

Parameters:

  • rockspec:

Returns:

    boolean or (nil, string): true if type checking succeeded, or nil and an error message if it failed.
type_check_manifest (manifest)
Type check a manifest table. Verify the correctness of elements from a manifest table, reporting on unknown fields and type mismatches.

Parameters:

  • manifest:

Returns:

    boolean or (nil, string): true if type checking succeeded, or nil and an error message if it failed.
generated by LDoc 0.5