Skip to content

blb4github/heishamon_rules_minify

 
 

Repository files navigation

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.

Release History

  • 0.0.1
    • Initial version

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

About

A Python CLI to minify Heishamon rules

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%