Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coatless-quarto/options
A Quarto developer extension that introduces option checking
https://github.com/coatless-quarto/options
defaults options quarto quarto-extension
Last synced: about 1 month ago
JSON representation
A Quarto developer extension that introduces option checking
- Host: GitHub
- URL: https://github.com/coatless-quarto/options
- Owner: coatless-quarto
- Created: 2024-04-28T19:29:47.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-04-28T19:56:15.000Z (9 months ago)
- Last Synced: 2024-07-30T20:10:17.754Z (6 months ago)
- Topics: defaults, options, quarto, quarto-extension
- Language: Lua
- Homepage: http://quarto.thecoatlessprofessor.com/options/
- Size: 354 KB
- Stars: 2
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# options: A Quarto Developer Extension for Working With Option Data
The `options` Quarto extension allows developers to craft options that incorporate default parameters.
## Usage
The `options` extension does not introduce significant enhancements to your document's content. Instead, it serves as a way for authors to quickly bootstrap working with option tables through an [extension embedding](https://quarto.org/docs/journals/formats.html#extension-embedding).
## Installation
To install the `options` extension inside of your own extension, follow these steps:
1. Open your terminal.
2. Navigate to where your own extension's development location is.
3. Execute the following command:
```sh
quarto add coatless-quarto/options --embed
```This command will download and install the extension under the `_extensions` subdirectory of your Quarto extension project. If you are using version control, ensure that you include this directory in your repository.
### File structure
When embedding the extension inside of your own extension, you should see the following folder structure:
```sh
.
└── _extensions
└──
└── _extensions
└── coatless-quarto
└── options```
### Registering the extension
Inside of the `_extension.yml`, please include the nested extension under `filters` as the first extension to run:
```yml
title: My Extension
author: My Name
version: 0.1.1
quarto-required: ">=1.4.549"
contributes:
format:
common:
filters:
- coatless-quarto/options
- .lua
```## Retrieving Options
Inside of the Lua filter, this extension can be used to setup:
```lua
-- Store function calls in a table value
local options = require("_extensions.coatless-quarto.options.options")-- Attempt to retrieve option
-- If it fails, we default to return `nil`.
local my_option_attempt = options.tryOption(options, key)-- Retrieve option if present, otherwise use default
local my_option = options.getOption(options, key, default)
```