Skip to main content

toy language on yaml or json

Project description

https://travis-ci.org/podhmo/zenmai.svg?branch=master

toylang on yaml or json

command line example

main.yaml

code:
  $import: ./filters.py
  as: f
definitions:
  $let:
    nums: {$load: ./nums.yaml#/definitions/nums0/enum}
  odds:
    type: integer
    enum:
      $f.odds: {$get: nums}
  even:
    type: integer
    enum:
      $f.evens: {$get: nums}

nums.yaml

definitions:
  nums0:
    type: integer
    enum:
      [1, 2, 3, 4, 5, 6]
  nums1:
    type: integer
    enum:
      [1, 2, 3, 5, 7, 11]

filters.py

def odds(nums):
    return [n for n in nums if n % 2 == 1]


def evens(nums):
    return [n for n in nums if n % 2 == 0]

run.

$ zenmai examples/readme2/main.yaml

output

zenmai main.yaml
definitions:
  odds:
    type: integer
    enum:
    - 1
    - 3
    - 5
  even:
    type: integer
    enum:
    - 2
    - 4
    - 6

config loader

using zenmai as config loader.

from zenma.loader import load

with open("config.yaml") as rf:
    d = load(rf)

0.3.0

  • $concat improvement

  • tiny error reporting improvement

  • changing $load’s scope

0.2.3

  • fix loader bug

0.2.2

  • fix –data bug

0.2.1

  • raw format

0.2.0

  • add $inherit action

  • zenmai as config loader

0.1.0:

  • first release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zenmai-0.3.0.tar.gz (9.2 kB view hashes)

Uploaded Source

Built Distribution

zenmai-0.3.0-py2.py3-none-any.whl (15.7 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page