Python rules defined by a dict and a text generator from the rules
Project description
dictrule
dictrule
is a simple Python module that helps generate text from defined rules in dictionary form. This module provides popular built-in rules and supports extended external rules for different usages.
With the input is dictrule.yml
in YAML format (or dictrule.json
in JSON format with a similar config) ...
- '"""'
- format_uppercase: {eval: gen.header}
- '"""'
-
- comment:
- inline:
- eval: gen.id
- '. '
- eval: gen.title
- inline: ["Creation date: ", eval: gen.date]
- inline: ["Author: ", eval: gen.author]
-
- indent_0: "class Sample:"
- indent_1: "def contents(self) -> List[str]:"
- indent_2: return [
- indent_3:
for: content
in: gen.contents
block:
- inline: [stringify: {eval: content.index}, ","]
- inline: [stringify: {eval: content}, ","]
- indent_2: "]"
And generate with example code ...
# loading dict from config file
config_file = 'dictrule.yml'
dict_config: Dict[str, Any] = load_config(config_file)
# generating string by loaded config
generator = dictrule.Generator(dict_config)
context: dictrule.Context = build_context()
generated_str = generator.generate(context)
# printing the output
print(generated_str)
Then output is ...
"""
THIS IS THE GENERATED EXAMPLE CODE
"""
# 3101. Sampler for getting sample contents
# Creation date: 01-01-2024
# Author: Zooxy Le
class Sample:
def contents(self) -> List[str]:
return [
"0",
"Train",
"1",
"Flight",
"2",
"Ship",
]
Explanation
for the methods
load_config
: load config from config file indict
formatbuild_context
: build context fordictrule.Generator
indictrule.Context
for the variables
gen.header
: "THIS IS THE GENERATED EXAMPLE CODE"gen.id
: 3101gen.title
: "Sampler for getting sample contents"gen.date
: "01-01-2024"gen.author
: "Zooxy Le"gen.contents
: ["Train", "Flight", "Ship"]
Note: The value of the variables is depended to current context by build_context
method.
Refer to my projects using dictrule
to generate text resources:
Installing dictrule
dictrule
is available on PyPI:
$ python -m pip install dictrule
dictrule
officially supports Python 3.7+.
Built-in rules
BlockRule
This rule joins a list of rules separated by a new line.
Key | Required | Value type | Value description |
---|---|---|---|
block | Yes | list | A list of other rules |
Example
>>> dictrule.Generator({
... "block": [
... "rule_1",
... "rule_2",
... "rule_3",
... ]
... }).generate()
rule_1
rule_2
rule_3
CommentRule
This rule allows generating comment text based on single-line and multi-line rules.
Key | Required | Value type | Value description |
---|---|---|---|
comment | Yes | string/list/dict | A text or a list of other rules are commented. |
style | No | string | Styles of comment: - singleline - multiline |
Building Context
with CommentRule.ContextCase
to define the comment style.
Example
>>> context = build_singleline_context("#")
>>> dictrule.Generator({
... "comment": "This is a single-line comment",
... }).generate(context)
# This is a single-line comment
>>> context = build_multiline_context('"""')
>>> dictrule.Generator({
... "style": "multiline",
... "comment": [
... "line1": "Line 1 of multi-line comment",
... "line2": "Line 2 of multi-line comment",
... ]
... }).generate(context)
"""
Line 1 of multi-line comment
Line 2 of multi-line comment
"""
EvalRule
This rule evaluates the value of provied variable or command.
Key | Required | Value type | Value description |
---|---|---|---|
eval | Yes | string | Variable name or keypath or command are provided from your generator. |
Example
>>> git_author = "Zooxy Le"
>>> dictrule.Generator({
... "eval": "git_author",
... }).generate()
Zooxy Le
>>> project_id = "123456789"
>>> dictrule.Generator({
... "eval": "project_id",
... }).generate()
123456789
ForInRule
This rule executes generatable rules in a for-in-block
loop with a provided iterable variable.
Key | Required | Value type | Value description |
---|---|---|---|
in | Yes | string | An iterable variable that can be evaluated. |
for | Yes | string | Name of iterating variable. |
block | Yes | list | A list of other rules is generated for each item in the iteration. |
Requires providing a Context
that includes the necessary information for the rules in the block
. The in
keyword must be represented by a EvalRule
variable, and the value of this variable must be a Interable
type.
Example
>>> context = build_saved_lines_context([
... Line(content="This is the line_1 content"),
... Line(content="This is the line_2 content"),
... ])
>>> dictrule.Generator({
... "for": "line",
... "in": "saved_lines",
... "block: [
... "line.index",
... "line.content",
... ]
... }).generate()
1
This is the line_1 content
2
This is the line_2 content
FormatRule
This rule formats text according to specified rules. This rule now supports the following types:
Key | Value type | Value description |
---|---|---|
format_lowercase | string/list/dict | A text or rules generated to format text in lowercase. |
format_uppercase | string/list/dict | A text or rules generated to format text in uppercase. |
format_upper_head | string/list/dict | A text or rules generated to format the first character to uppercase. |
Example
>>> dictrule.Generator({
... "format_lowercase": "UPPERCASE TITLE",
... "format_uppercase": "lowercase content",
... "format_upper_head": "camelVariable",
... "format_camel_case": "Camel case",
... "format_pascal_case": "pascal case",
... "format_kabab_case": "Kebab case",
... "format_snake_case": "Snake case",
... }).generated()
uppercase title
LOWERCASE CONTENT
CamelVariable
camelCase
PascalCase
kebab-case
snake_case
IndentRule
This rule indents generated text from provided rules by a specified number of indent spaces.
Key prefix | Required | Value type | Value description |
---|---|---|---|
indent | Yes | string/list/dict | Indents multiple lines of parsed text from rules by specified indent (splits after indent_ prefix)Example: indent_1 , indent_2 , indent_3 ,... |
Defines the number of spaces for text indentation by providing IndentRule.ContextCase
within the Context
.
Example
>>> context = build_number_spaces_context(4)
>>> dictrule.Generator({
... "class Menu:",
... "indent_1": "def content(self):",
... "indent_2": "return 'Empty'",
... }).generate(context)
class Menu:
def content(self):
return 'Empty'
InlineRule
This rule builds generated text of a list of rules that are in a line.
Key | Required | Value type | Value description |
---|---|---|---|
inline | Yes | list | A list of other rules that join in a line. |
Example
>>> dictrule.Generator({
... "inline": ["This", " is", " the", " text", " in", " a", " line"],
... }).generate()
This is the text in a line
JoinBlockRule
This rule joins generated texts for a block of rules by a specified separator.
Key | Required | Value type | Value description |
---|---|---|---|
join | Yes | string | Separator for joining. |
block | Yes | list | A list of other rules that generates a list of texts for joining. |
Example
>>> dictrule.Generator({
... "join": "-",
... "block": ["This", "is", "the", "snake", "line"],
... }).generate()
This-is-the-snake-line
JoinEvalRule
This rule joins generated texts from the value of EvalRule
by a specified separator.
Key | Required | Value type | Value description |
---|---|---|---|
join | Yes | string | Separator for joining. |
eval | Yes | string | EvalRule value for joining generated texts. |
Example
>>> context = build_football_teams_context([
... "Real Madrid",
... "Barcelona",
... "Bayern Munchen",
... "PSG",
... "MC",
... "MU",
... "AC Milan",
... ])
>>> dictrule.Generator({
... "join": ", ",
... "eval": "football_teams",
... }).generate(context)
Real Madrid, Barcelona, Bayern Munchen, PSG, MC, MU, AC Milan
StringifyRule
This rule wraps content by quotes.
Key | Required | Value type | Value description |
---|---|---|---|
stringify | Yes | string/list/dict | A text or other rules quoted after generated text. |
Examples:
>>> dictrule.Generator({
... "stringify": "This is the 1st text",
... "stringify": "This is the 2nd text",
... }).generate()
"This is the 1st text"
"This is the 2nd text"
Testing
dictrule
includes a comprehensive test suite. To run the tests, run:
pytest
Contributing
Read the Contributing Guide to learn about reporting issues, contributing code, and more ways to contribute.
Submit bug reports and feature requests to the dictrule bug tracker.
License
The dictrule
module is written by Zooxy Le elhoangvu@gmail.com.
dictrule
is released under the MIT License.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.