Greetings is a friendly Lua filter that adds a welcoming message to the document.
This repository serves as a template intended to make publishing of pandoc Lua filters easy and convenient. Just click “use this template” and then make modifications in your new repository. See also the GitHub documentation on creating a repository from a template.
This section describes how to use the template.
A few things should be updated in the repository after cloning this template. You can use the checklist below to ensure that you get the most out of it. We recommend that you perform at least the first two steps, everything else is up to you.
make setup
This will update the README, remove the template-specific documentation, and rename the filter; the repository name is used to determine the new filter name.
make quarto-extension
to generate the necessary files and directories. You should commit
the generated files to source control. See also the quarto-extension
documentation
below.
The repository comes with a Makefile
intended to make
developing a filter a pleasant experience. You may want to adjust some
of the targets while keeping the general structure.
Use the Makefile with make ...
, where ...
denotes one of the targets listed in this section.
generate
(Re)generate test output files. This target runs your filter on the
file test/input.md
and generates one or more output files
test/expected.<FORMAT>
(native
by
default).
Change desired output formats by replacing the Makefile’s
FORMAT=...
line with e.g. FORMAT=html docx
.
These must be possible values of Pandoc’s --to
option.
You can also set FORMAT
on the command line to
regenerate files in specific output formats:
make regenerate FORMAT=docx
Files are generated using the Pandoc default options given in
test/test.yaml
. This file is provided by default but you
may want to check it into source control and modify it as needed.
test
Tests the filter. This target runs your filter on the file
test/input.md
using Pandoc options
test/test.yaml
and compares the result with one or more
test/expected.<FORMAT>
files (native
by
default).
See the regenerate
target on how to change default
FORMAT
values or passing it on the command lines.
quarto-extension
This target sets the repository up to be used as a Quarto extension. The target will create
the directory structure expected by quarto. It will also generate a
_extension.yml
metadata file. Invoking this target will
move the main .lua
file below the _extensions
directory; the the original file will be replaced with a symlink.
release
Creates a new release for the given version. The version must be passed as a variable:
make release VERSION=1.0.0
The release
target depends on
quarto-extension
.
update-name
Run this target after renaming the filter file. It will update the name in all other files.
website
Generates a website for this filter. The website will contain the
contents of this README, an example generated from the test input, as
well as the full filter code. The page components are combined with the
.tools/docs.lua
filter.
The repository template comes with a GitHub Action to publish a website via GitHub pages. It expects the new “GitHub Actions” source to be used for Pages.
Remove the file .github/workflows/website.yml
to disable
this feature.
The filter modifies the internal document representation; it can be used with many publishing systems that are based on pandoc.
Pass the filter to pandoc via the --lua-filter
(or
-L
) command line option.
pandoc --lua-filter greetings.lua ...
Users of Quarto can install this filter as an extension with
quarto install extension tarleb/greetings
and use it by adding greetings
to the
filters
entry in their YAML header.
---
filters:
- greetings
---
Use pandoc_args
to invoke the filter. See the R
Markdown Cookbook for details.
---
output:
word_document:
pandoc_args: ['--lua-filter=greetings.lua']
---
This pandoc Lua filter is published under the MIT license, see file
LICENSE
for details.
---
title: Lorem ipsum
author: Nullus
---
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Donec
hendrerit tempor tellus. Donec pretium posuere tellus. Proin quam nisl, tincidunt et, mattis eget, convallis nec, purus.
---
author: Nullus
subtitle: Lorem ipsum
title: Greetings!
---
Hello from the Lua filter!
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Donec
hendrerit tempor tellus. Donec pretium posuere tellus. Proin quam nisl, tincidunt et, mattis eget, convallis nec, purus.
--- greetings.lua – turns any document into a friendly greeting
---
--- Copyright: © 2021–2022 Contributors
--- License: MIT – see LICENSE for details
-- Makes sure users know if their pandoc version is too old for this
-- filter.
PANDOC_VERSION:must_be_at_least '2.17'
--- Amends the contents of a document with a simple greeting.
local function say_hello (doc)
doc.meta.subtitle = doc.meta.title -- demote title to subtitle
doc.meta.title = pandoc.Inlines 'Greetings!' -- set new title
doc.blocks:insert(1, pandoc.Para 'Hello from the Lua filter!')
return doc
end
return {
-- Apply the `say_hello` function to the main Pandoc document.
{ Pandoc = say_hello }
}