Concepts

Things you should know before beginning

This guide assumes some familiarity with Lua! Consider skimming chapters 1 through 5 of Programming in Lua if you're new to the language.

Markdown

Moontale's main language is a variant of Markdown that allows mixing Lua code with regular text. We'll call this language 'Moontale-flavoured-Markdown' - MFM for short. The Syntax section has more details on the differences.

Stories and Passages

In Twine, a Story is a collection of Passages that are (typically) joined together by Links.

A Passage is simply a block of code that gets transformed into text and formatting that the end user can see. The type of code that a Passage contains depends on the 'story format' selected - in the case of Moontale, that would be MFM.

A Story has a 'Start Passage' which the editor can change. When a story is 'run' or 'played', the host will display this passage as its entry point into the story.

Render functions

The content of a passage (as well as any inner Content Blocks) is realised as a 'render function' - a function that, when called with no arguments, writes its content to the screen. Render functions, just like normal Lua functions, can be passed around, saved and copied like any other value.

The following definitions are equivalent:
1. $Name.foo[Some text **with markup**]
2. {$ function foo() Text('Some text ') Style.em('with markup') end $}

Overriding

Many of Moontale's standard functions can be overridden by simply replacing their definitions. This is especially useful because Moontale's markdown syntax will refer to Lua expressions instead of a hard-coded style. For example:

function Link()
    Show('Instead of a link, have some text!')
end

If a function is defined in a table, like Style, you can override it by overwriting it:

Style.em = Color.blue -- *Text* will be blue instead of italicised
Style.em = nil -- Revert to the default behaviour

You can use the 'base' definitions as well:

Style.em = Combine(Style.em, Color.blue) -- *Text* will be blue as well as italicised

For 'free' functions, if you want to access the 'base' definition you'll need to save it first:

local _link = Link
function Link(target)
    -- Make all links red (while keeping their normal behaviour)
    return Combine(Color.red, _link(target)
end

🚧 When defining overrides, you should put them in a startup-tagged passage if they're common to your story. If they're specific to a passage, you should use the With changer; if you put them in a code block, the overrides will be permanent!

Last updated