mold_lib 2.3.1 (#1497)

This commit is contained in:
Francesc Rocher
2025-05-30 12:01:48 +02:00
committed by GitHub
parent 788a339fb6
commit 058796a060
+88
View File
@@ -0,0 +1,88 @@
name = "mold_lib"
version = "2.3.1"
tags = ["template", "template-engine", "template-repo"]
description = "Meta-variable Operations for Lean Development (lib)"
long-description = '''
[![Alire](https://img.shields.io/endpoint?url=https://alire.ada.dev/badges/mold_lib.json)](https://alire.ada.dev/crates/mold_lib.html)
[![Alire CI/CD](https://img.shields.io/endpoint?url=https://alire-crate-ci.ada.dev/badges/mold_lib.json)](https://alire-crate-ci.ada.dev/crates/mold_lib.html)
![unit-test](https://github.com/rocher/mold_lib/actions/workflows/unit-test.yml/badge.svg)
[![codecov](https://codecov.io/gh/rocher/mold_lib/graph/badge.svg?token=LB83SI4I0Y)](https://codecov.io/gh/rocher/mold_lib)
[![GitHub release](https://img.shields.io/github/release/rocher/mold_lib.svg)](https://github.com/rocher/mold_lib/releases/latest)
[![License](https://img.shields.io/github/license/rocher/mold_lib.svg?color=blue)](https://github.com/rocher/mold_lib/blob/master/LICENSE)
## Welcome to **Mold (lib)**
> **MOLD**: *Meta-variable Operations for Lean Development*
Mold is a Template Processor, or Template Engine, to work with repository
templates. The main motivation of Mold is to have repositories in GitHub used
as template repositories to create new, customized repositories for other
users.
Main features supported in Mold include
* variable replacement in mold files (*.mold)
* for a given directory, variable replacement recursively for all mold files
in all subdirectories
* variable replacement in file names
* inclusion of other templates
* definition of variables with a simple TOML file
* predefined and custom text filters to easy text transformations
* predefined variables to use in templates
* support for optional and mandatory variables
* support for custom filters and variables
Variable replacement can be specified as *normal*, *optional* or *mandatory*.
For example, the variable `foo = "bar"` can be specified with `{{foo}}`,
`{{?foo}}` (optional) or `{{#foo}}` (mandatory). The difference is the handling
of errors when an undefined variable is encountered.
All mold files must end with the extension `.mold`, for example
`README.md.mold`. Destination files (with variables replaced) have the same
name without the mold extension: `README.md`. This simplifies the work done in
large subdirectories with few templates.
This crate contains the Ada library and unit tests. For a CLI tool, please
take a look at the crate `mold`.
## Reference Guide
Please visit [Mold documentation](https://rocher.github.io/mold) for more
information.
---
## License
MIT (c) 2023-2025 Francesc Rocher
'''
authors = ["Francesc Rocher"]
website = "https://rocher.github.io/mold"
maintainers = ["Francesc Rocher <francesc.rocher@gmail.com>"]
maintainers-logins = ["rocher"]
licenses = "MIT"
[build-switches."release"]
optimization = ["-O1", "-gnatn"]
[build-switches."*"]
ada_version = ["-gnat2022", "-gnatW8", "-gnatX"]
[[depends-on]]
ada_toml = "~0.3.0"
gnat = ">=2021 | (>=12 & <2000)"
simple_logging = "^1.2.0"
[origin]
commit = "4102d93fefbb39e6b454be79bb35a61835d46a99"
url = "git+https://github.com/rocher/mold_lib.git"