Skip to main content

A Python CLI to minify Heishamon rules

Project description

HeishaMon Rules Minify

A Python CLI to minify Heishamon rules

HeishaMon is a project to read out a Panasonic air-water heat pump using an ESP8266 board. The HeishaMon firmware also supports the use of rules, to control the heatpump from within the HeishaMon itself. Since the ruleset must be stored within HeishaMon, its size must be limited. Therefore, it is best to use short function and variable names in order to maximize the number of rules that can be stored. Moreover, the rules library does not support comments in a ruleset, making it hard to read and maintain a ruleset, but also making it hard to share the ruleset with other.

This project aims to overcome these issues by making it possible write a ruleset with comments and descriptive function and variables names, and then minifying it. This way it is still possible to maximize the number of rules on the HeishaMon.

Note: The minifier should work for both the rule library used in version 3.2.3 and this updated rule libaray version. In the rule library from version 3.2.3, the elseif statement cannot be used

Installation

python3 -m pip install heishamon_rules_minify

Usage example

Start by creating a ruleset that adheres to the HeishaMon rules syntax, but can use the following extras:

  • Single line comments starting with -- or block comments between --[[ and ]].
  • Custom function and variable names will be minified to only keep the first letter (which will be capitalised) and capital letters, so for example #WaterTemperature will become #WT, #allowDHW will become #ADHW.

When the ruleset is finished, minify it using the following command:

heishamon-rules-minify [input_file] [output_file]

This will shorten all custom function and variable names and remove all unneeded spaces and newlines.

Extra options

There are a couple of extra options to pass with the minifier:

  • --print or -p to also print the output on the command line.
  • --comments_only or -c to only remove the comments from the input file but do no further minifying.

Release History

  • 0.0.1
    • Initial version
  • 0.0.2
    • Fix incorrect spacing for double operators, minor bugfixes
  • 0.0.3
    • Add option to only remove comments
  • 0.0.4
    • Fix extra space being added after the minus sign of negative values

Contributing

  1. Fork it (https://github.com/yourname/yourproject/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

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

heishamon_rules_minify-0.0.4.tar.gz (10.9 kB view details)

Uploaded Source

Built Distribution

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

heishamon_rules_minify-0.0.4-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file heishamon_rules_minify-0.0.4.tar.gz.

File metadata

  • Download URL: heishamon_rules_minify-0.0.4.tar.gz
  • Upload date:
  • Size: 10.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for heishamon_rules_minify-0.0.4.tar.gz
Algorithm Hash digest
SHA256 95c6029940220ac621d1ea03943589c8fc3c7ca0e6186c1c99c14827345c39dc
MD5 8859b3cb62e5c62ac08293bf6035d858
BLAKE2b-256 2fe04bd29eb94015ee21ed62d2aa74f003dd253605873bb1053fc2e89f7028c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for heishamon_rules_minify-0.0.4.tar.gz:

Publisher: publish.yml on klaashoekstra94/heishamon_rules_minify

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

File details

Details for the file heishamon_rules_minify-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for heishamon_rules_minify-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3c77ca39d2a7dcdae1296995c866c696e296dc68e756f5fdae33ec87b027e24a
MD5 edf1a88f02d04d4c9dc4f1cccbc584d6
BLAKE2b-256 4c96e9656f90e62dc193b20cb38a0fe6022e7043ab1baa1c7128cae76e86f920

See more details on using hashes here.

Provenance

The following attestation bundles were made for heishamon_rules_minify-0.0.4-py3-none-any.whl:

Publisher: publish.yml on klaashoekstra94/heishamon_rules_minify

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