Skip to content

Latest commit

 

History

History
130 lines (112 loc) · 5.58 KB

tlconfig.md

File metadata and controls

130 lines (112 loc) · 5.58 KB

tlconfig.lua

This file describes the layout of your project by returning a table with the following fields:

Name CLI Flag Type Description
build_dir string Where to put generated files
disable_warnings --wdisable {tl.WarningKind} Disable the provided warnings
exclude {string} A list of patterns describing what files to exclude
externals {any:any} Entry for external tooling to use, unused by cyan itself
gen_compat --gen-compat tl.CompatMode Generate compatability code for different Lua versions
gen_target --gen-target tl.TargetMode Minimum Lua version for generated code. One of 5.1 or 5.3
include_dir -I --include-dir {string} Add each path provided to package.path and package.cpath
include {string} A list of patterns describing what files to include
preload_modules -l --preload {string} Execute the equivalent of require(<module>) for each provided name
global_env_def --global-env-def string Load this file before type checking
scripts `{string : {string : string {string}}}`
--no-script Disables scripts, see scripts
source_dir string Where to find source files
warning_error --werror {tl.WarningKind} Promote the provided warnings to errors
-q --quiet Do not print info to stdout. Errors may still be printed to stderr
-v --verbosity one of quiet, normal, extra, debug Determines how much logging is done
dont_prune {string} Don't prune the given list of file patterns when running build --prune and don't warn when just running build

Patterns

The include and exclude fields can have glob-like patterns in them:

  • *: Matches any number of characters (excluding directory separators)
  • **/: Matches any number subdirectories

In addition

  • '/' is the path separator no matter what os you are on.
  • setting the source_dir has the effect of prepending source_dir to all patterns.
  • currently, include will only include .tl files even if the extension isn't specified.

For example: If our project was laid out as such:

tlconfig.lua
src/
| foo/
| | bar.tl
| | baz.tl
| bar/
| | a/
| | | foo.tl
| | b/
| | | foo.tl

and our tlconfig.lua contained the following:

return {
   source_dir = "src",
   build_dir = "build",
   include = {
      "foo/*",
      "bar/**/*"
   },
   exclude = {
      "foo/bar.tl"
   }
}

Running tl build will produce the following files.

tlconfig.lua
src/
| foo/
| | bar.tl
| | baz.tl
| bar/
| | a/
| | | foo.tl
| | b/
| | | foo.tl
build/
| foo/
| | baz.lua
| bar/
| | a/
| | | foo.lua
| | b/
| | | foo.lua

Additionally, complex patterns can be used for whatever convoluted file structure we need.

return {
   include = {
      "foo/**/bar/**/baz/**/*"
   }
}

This will compile any .tl file with a sequential foo, bar, and baz directory in its path.

Scripts

Scripts let you run arbitrary Lua/Teal code in the middle of commands. This is intended for things like autogenerating types/documentation/etc. Similar to tlconfig.lua, a script is any ordinary Lua or Teal file, that tlconfig.lua tells cyan when to run it.

scripts is a bunch of nested maps (specifically {string : {string : string | {string}}) that tell cyan on what commands to run the scripts and when. The type is quite daunting to look at so an example is more elucidating:

return {
   scripts = {
      -- {string : ...
      build = {
         -- ... {string :
         pre = "generate_types.tl", -- ... string
         post = { "cleanup.tl", "generate_rockspec.tl" }, -- ... | {string} }
      }
      -- }
   }
}

The first key is the command run on. The second key is the hook to run on. Hooks are defined by commands themselves and these are the current ones that exist:

  • build
    • pre: Runs before scanning the source directory to find updated files. Passes no arguments to the script.
    • file_updated: Emitted when cyan detects that a source file is newer than it's compilation target, but before it attempts to compile anything. Passes a cyan.fs.Path object describing the source file that was updated.
    • post: Runs after compiling source files. Does not run when nothing was compiled.

Hooks may pass arbitrary data to scripts, which can be accessed through .... The first one will be the name of the hook that triggered it. The first argument of exec is the hook that was emitted by the command, along with any arbitrary data that the command chooses to call the hook with.

If you would not like cyan to run any scripts, you can pass the --no-script flag to emit no hooks during the command. There is currently no way to disable individual scripts.

For some more concrete examples, take a look at the scripts/docgen.tl and scripts/gen_rockspec.tl here in the cyan repo.