Skip to main content

Python Parser for Cooklang

Project description

cooklang-py

Tests Format and Lint CodeQL

A parser for the Cooklang recipe markup language

Installation

To install just run:

pip install cooklang-py

Documentation

Full documentation is available at https://cooklang-py.readthedocs.io/

Recipe

The Recipe is the primary unit. There are 2 ways to create a Recipe object:

from cooklang_py import Recipe

# Create from a string in memory
recipe_string = '<your recipe here>'
recipe = Recipe(recipe_string)

# Create from a file
recipe_file = '/path/to/recipe/file'
recipe = Recipe.from_file(recipe_file)

Just like a recipe in a book a Recipe contains:

  • Ingredients
  • Cookware / equipment
  • Timings
  • Metadata (servings, cook time, etc.)

To see how to define these in your input please refer to the Cooklang language specification

When the recipe is parsed there will be a list of Step objects. Each step object can contain:

  • Ingredients
  • Cookware
  • Timings
  • Instructions (text)

At both the Recipe and Step level you can access the list of Ingredients and Cookware for the recipe or step.

Cookware, Timings, and Ingredients

Cookware, timings, and ingredients are the backbone of the recipe. In this package all three inherit from the BaseObj. They all have the following 3 attributes:

  • name - the name of the item (i.e. pot, carrot, etc.)
  • quantity - how much is needed
  • notes - any notes for the item (i.e. "greased", "peeled and diced", etc.)
    • Timings do not have notes per the Cooklang specification.

Overriding implementations

The implementations of Cookware, Timings, and Ingredients can be overridden by creating a new implementation (inheriting from either that class or from BaseObj) and calling Recipe or Step with an updated prefixes dictionary that points the desired prefix to the new class.

Compatibility

cooklang-py passes all canonical tests defined at https://github.com/cooklang/cooklang-rs/blob/main/tests/canonical.yaml for the following platforms:

  • Linux
  • MacOS
  • Windows

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

cooklang_py-0.3.1.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cooklang_py-0.3.1-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file cooklang_py-0.3.1.tar.gz.

File metadata

  • Download URL: cooklang_py-0.3.1.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for cooklang_py-0.3.1.tar.gz
Algorithm Hash digest
SHA256 62fa03cf8180baeb4eeeaa115b277d7e2223aea38066d1a7be06dfdf4f60c0aa
MD5 4a2c94ca03f9fb9230d90d4f91e6752e
BLAKE2b-256 6ef8d7bd5379f73dd7563865a8751b4ce8c7850d634245d801d75c5d80a1cfa7

See more details on using hashes here.

Provenance

The following attestation bundles were made for cooklang_py-0.3.1.tar.gz:

Publisher: publish.yml on brass75/cooklang-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cooklang_py-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: cooklang_py-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for cooklang_py-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d5a75a03f4a9c1bf44f19b537f481f5fd72ba09e7c554ad1548c5ca7bb45d483
MD5 0806089df339f19ad7805512ec086704
BLAKE2b-256 41fd42eb56b0fe6fc840ba0281fdfb9e9f6d585941821f1ec366a7a5ae44008d

See more details on using hashes here.

Provenance

The following attestation bundles were made for cooklang_py-0.3.1-py3-none-any.whl:

Publisher: publish.yml on brass75/cooklang-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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