Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/edadma/squiggly
Scala based template engine
https://github.com/edadma/squiggly
scala template-engine
Last synced: 2 months ago
JSON representation
Scala based template engine
- Host: GitHub
- URL: https://github.com/edadma/squiggly
- Owner: edadma
- License: isc
- Created: 2021-09-22T00:06:11.000Z (over 3 years ago)
- Default Branch: stable
- Last Pushed: 2023-06-22T14:46:55.000Z (over 1 year ago)
- Last Synced: 2024-04-22T13:33:06.652Z (9 months ago)
- Topics: scala, template-engine
- Language: Scala
- Homepage:
- Size: 21.4 MB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-scala-native - squiggly - Cross-platform template language for Scala, inspired by Liquid and Hugo templates. (File Formats and Parsers)
README
squiggly
========![GitHub release (latest by date including pre-releases)](https://img.shields.io/github/v/release/edadma/squiggly?include_prereleases) ![GitHub (Pre-)Release Date](https://img.shields.io/github/release-date-pre/edadma/squiggly) ![GitHub last commit](https://img.shields.io/github/last-commit/edadma/squiggly) ![GitHub](https://img.shields.io/github/license/edadma/squiggly)
*squiggly* is a Scala based string templating engine.
## Overview
*squiggly* is a language, a Scala library, and a Linux command line application for doing string templating. *squiggly*
can be compared to [Mustache](https://mustache.github.io/) or [Go templates](https://pkg.go.dev/text/template) or
[Liquid](https://shopify.github.io/liquid/), which are all great template languages. Basically, a string template that
is composed of text and *tags* which are instructions in *squiggly*, is applied to context data producing a textual
output.Unlike Mustache, *squiggly* is not logic-less, but allows some basic logic to be used in templates.
Curly braces or brackets are sometimes referred to as squiggly brackets, which is where the name "squiggly" comes from.
## Installation
### Library
To use the library in your application, include the following in your `project/plugins.sbt`:
```sbt
addSbtPlugin("com.codecommit" % "sbt-github-packages" % "0.5.2")```
Include the following in your `build.sbt`:
```sbt
resolvers += Resolver.githubPackages("edadma")libraryDependencies += "io.github.edadma" %%% "squiggly" % "0.1.14"
```
Use the following `import` statement in your code:
```scala
import io.github.edadma.squiggly._```
### Command line
To use the command line executable, download the file `squiggly` from the root folder of the repository. Make it
executable by typing```shell
chmod a+x path/to/squiggly
```then copy it to your `/usr/bin` folder
```shell
sudo cp path/to/scamplate /usr/bin
```## Basic use
### Library
Here's a simple example of using *squiggly* to render a template in your application.
```scala
import io.github.edadma.squiggly.{Parser, Renderer}object Main extends App {
case class Task(task: String, done: Boolean)
case class User(user: String, tasks: List[Task])
val data =
User("ed",
List(Task("Improve Parser and Renderer API", done = true),
Task("Code template example", done = false),
Task("Update README", done = false)))
val template =
"""
|
|
|
| To-Do list
|
|
|
| To-Do list for user '{{ .user }}'
|
|
|
| Task
| Done
|
| {{ for .tasks -}}
|
| {{ .task }}
| {{ if .done }}Yes{{ else }}No{{ end }}
|
| {{- end }}
|
|
|
|""".trim.stripMargin
val ast = Parser.default.parse(template)Renderer.default.render(data, ast)
}
```
output:
```
To-Do list
To-Do list for user 'ed'
Task
Done
Improve Parser and Renderer API
Yes
Code template example
No
Update README
No
```
### Command line
Type
```
squiggly -h
```to get the following usage text:
```
Squiggly v0.1.14
Usage: squiggly [options] [[]]-a, --ast pretty print AST
-d, --data YAML document
-f, --template template file
-h, --help prints this usage text
-v, --version prints the version
-y, --yaml YAML data file
[] template string
```Here's a trivial example:
```shell
squiggly -d "{a: 3, b: 4}" "{{ .a }} + {{ .b }} = {{ .a + .b }}"
```output:
```
3 + 4 = 7
```## Templates
Squiggly templates are written using a language that is inspired by
both [Hugo](https://gohugo.io/templates/introduction/) and [Liquid](https://shopify.github.io/liquid/). The goal is low
boilerplate and readability. Hugo is compact and boilerplate free, but it is also a *prefix* language where operations
must always precede their operands. Prefix languages tend not to be conducive to readability. Liquid has better infix
syntax but more boilerplate. Both languages have good features that the other is missing.### Values
*squiggly* values are pieces of data that are either computed in the template or retrieved from the *context* that is
provided when a template is rendered. A value that is written manually inside a template is called a literal value.#### Literals
- `null`. The null value simply represents no value, and is rendered in a template as an empty string. It corresponds to
a Scala `null`.
- `true`, `false`. These correspond to the values of the Scala Boolean class.
- _numbers_. Numbers in *squiggly* are all instances of one type internally: the Scala `BigDecimal` number type. This
was chosen mainly because it provides exact decimal arithmetic which is desirable when working with currency
values. `BigDecimals` can also represent arbitrarily large integers.
- _strings_. String literals are written between `'` and `'`, or `"` and `"`, whichever is more convenient. Strings may
contain any of the standard escapes: `\n`, `\uxxxx`, etc.
- _lists_. List literals are written between `[` and `]` with each item in the list separated by a `,`.
- _maps_. Map literals are written between `{` and `}` with each property in the map separated by a `,`, and where a
property is a *key* (property name) and a value separated by a `:`. For example: `{one: 1, two: 2, three: 3}`There is a special *undefined* value which purposely cannot be expressed literally because it represents a property that
is missing, and is always rendered in a template as an empty string. It is not the same as `null` because a property
that is not missing can contain a `null` value, and one may wish to distinguish between them. The undefined value
corresponds to the Scala `()` value, the only instance of the `Unit` class.#### Expressions
TO DO
### Tags
Squiggly templates are plain text with the addition of *tags* that are normally between `{{` and `}}` delimiters. The
tag delimiter strings are configurable. Following are the currently available tags.#### {{ _value_ }}
where *value* is any valid *squiggly* expression which results in a data value of some kind. The resulting value is
converted to a string of characters if it is not already, and sent to the output stream.For example `{{ .title }}` will be replaced by the value of a context property called `title`.
#### {{ with _value_ }} ...(truthy) {{ else }} ...(falsy) {{ end }}
The *with* tag binds the current context to *value*, and is often used to simply using code that will be referring to
properties of a single data structure. For example `{{ with .user }}{{ .firstName }} {{ .lastName }}{{ end }}` will be
replaced by the first and last name of `.user`.#### {{ for [ _e_ [ , _i_ ] <- ] _value_ }} ... [ {{ else }} ... ] }}
The *for* tag binds context to successive elements of *value* which must be a Scala Iterable (i.e. a Seq or Map).
Optionally, *e* is also set to each value, and *i* is set to the 0-based index.TO DO
### Functions
TO DO
## Examples
TO DO
## Tests
Unit tests can be run quickly for the JVM platform by typing
```sbt
squigglyJVM / test```
Tests for all platforms can be run by typing simply
```sbt
test```
## Contributing
This project welcomes contributions from the community. Contributions are accepted using GitHub pull requests; for more
information, see
[GitHub documentation - Creating a pull request](https://help.github.com/articles/creating-a-pull-request/).For a good pull request, we ask you provide the following:
1. Include a clear description of your pull request in the description with the basic "what" and "why"s for the request.
2. The tests should pass as best as you can.
3. The pull request should include tests for the change. A new feature should have tests for the new feature and bug
fixes should include a test that fails without the corresponding code change and passes after they are applied.
4. If the pull request is a new feature, please include appropriate documentation in the `README.md` file as well.
5. To help ensure that your code is similar in style to the existing code, `scalafmt` should be used.## License
[ISC]()