Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/AlwaysRightInstitute/Mustache
A simple Mustache parser/evaluator for Swift
https://github.com/AlwaysRightInstitute/Mustache
mustache swift swift-library swift3
Last synced: 3 months ago
JSON representation
A simple Mustache parser/evaluator for Swift
- Host: GitHub
- URL: https://github.com/AlwaysRightInstitute/Mustache
- Owner: AlwaysRightInstitute
- License: apache-2.0
- Created: 2017-03-07T15:54:47.000Z (almost 8 years ago)
- Default Branch: develop
- Last Pushed: 2024-10-09T17:50:44.000Z (4 months ago)
- Last Synced: 2024-11-13T06:04:51.962Z (3 months ago)
- Topics: mustache, swift, swift-library, swift3
- Language: Swift
- Size: 163 KB
- Stars: 24
- Watchers: 3
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Mustache
data:image/s3,"s3://crabby-images/6fff5/6fff51ad0ff7ae5f1722bd052fe7cc66bbc9d701" alt="Swift4"
data:image/s3,"s3://crabby-images/fac0d/fac0dae10cdf268198853943a4bf5aaaad4dd1d5" alt="Swift5"
data:image/s3,"s3://crabby-images/5283a/5283ac146afff127df2cf67ec2debbb09e0d0808" alt="macOS"
data:image/s3,"s3://crabby-images/c7336/c7336139b39ea64a2b5558eddc14e825c7ce94c5" alt="tuxOS"
[data:image/s3,"s3://crabby-images/8511c/8511cb02b35e007340400bc76d5e370f5ff9bd15" alt="Build and Test"](https://github.com/AlwaysRightInstitute/Mustache/actions/workflows/swift.yml)A simple [Mustache](http://mustache.github.io) parser/evaluator for Swift.
[Mustache](http://mustache.github.io) is a very simple templating language.
Implementations are available for pretty much any programming language
(check the [Mustache](http://mustache.github.io) website) - this is one for
Swift.In the context of Noze.io you don't need to call this manually,
but you can just use the Mustache template support in the
Noze.io [Express](../express) module.
Checkout the [express-simple](../../Samples/express-simple) app as an example
on how to do this.This Mustache implementation comes with a very simple Key-Value coding
implementation, which is used to extract values from model objects for
rendering.
With that you can render both, generic Dictionary/Array structures as well
as Swift objects with properties.
Since the reflection capabilities of Swift are pretty limited, so is the
KVC implementation.## Example
Sample Mustache:
Hello {{name}}
You have just won {{& value}} dollars!
{{#in_ca}}
Well, {{{taxed_value}}} dollars, after taxes.
{{/in_ca}}
{{#addresses}}
Has address in: {{city}}
{{/addresses}}
{{^addresses}}
Has NO addresses
{{/addresses}}The template features value access: `{{name}}`,
conditionals: `{{#in_ca}}`,
as well as repetitions: `{{#addresses}}`.Sample code to parse and evaluate the template:
let sampleDict : [ String : Any ] = [
"name" : "Chris",
"value" : 10000,
"taxed_value" : Int(10000 - (10000 * 0.4)),
"in_ca" : true,
"addresses" : [
[ "city" : "Cupertino" ]
]
]
var parser = MustacheParser()
let tree = parser.parse(string: template)
let result = tree.render(object: sampleDict)You get the idea.
## Swift 5 Dynamic Callable
In Swift 5 you can expose Mustache templates as regular Swift functions.
To declare a Mustache backed function:
```swift
let generateHTMLForWinner = Mustache(
"""
{% raw %}Hello {{name}}
You have just won {{& value}} dollars!
{{#in_ca}}
Well, {{{taxed_value}}} dollars, after taxes.
{{/in_ca}}
{{#addresses}}
Has address in: {{city}}
{{/addresses}}
{{^addresses}}
Has NO addresses
{{/addresses}}{% endraw %}
"""
)
```To call the function:
```swift
let winners = [
generateHTMLForWinner(
name: "Chris", value: 10000,
taxed_value: 6000, in_ca: true,
addresses: [[ "city": "Cupertino" ]]
),
generateHTMLForWinner(
name: "Michael", value: 6000,
taxed_value: 6000, in_ca: false,
addresses: [[ "city": "Austin" ]]
)
]
```Checkout our [blog](http://www.alwaysrightinstitute.com/mustachable/)
for more info on this.### Who
**mustache** is brought to you by
[The Always Right Institute](http://www.alwaysrightinstitute.com)
and
[ZeeZide](http://zeezide.de).
We like feedback, GitHub stars, cool contract work,
presumably any form of praise you can think of.
We don't like people who are wrong.Ask questions on the [Noze.io Slack](http://slack.noze.io).