mirror of
https://github.com/esphome/esphome.git
synced 2024-11-10 01:07:45 +01:00
schema-dump-pins (#1596)
* schema dump idea accept boolean or anything default accept null also for full dicts added some common validators more simple validators support multi_conf better handle automations updates updates handle lists removed not needed class move to own folder generalized for automations lists, etc updates updates clean up clean up fix automations made comment optional basic docs support added more docs fixes docs handling updates updates fix components parent updates updates updates Fix inkplate 6 registration updates Disable logging for vscode add on better handle buses keep extended order as in CONFIGs updates updates updates disable comments moved to scripts/build_jsonschema added configurable decorators path handling fix handle list_schema fixes and cleanup add jschema_extractor to maybe updates lint no schema in git add generated loggers list * lint * support pin schema
This commit is contained in:
parent
2c0fe49b86
commit
5e5f8d5f9b
2 changed files with 49 additions and 14 deletions
|
@ -1,13 +1,14 @@
|
|||
# These are a helper decorators to help get schema from some
|
||||
# components which uses volutuous in a way where validation
|
||||
# is hidden in local functions
|
||||
"""Helpers to retrieve schema from voluptuous validators.
|
||||
|
||||
These are a helper decorators to help get schema from some
|
||||
components which uses volutuous in a way where validation
|
||||
is hidden in local functions
|
||||
These decorators should not modify at all what the functions
|
||||
originally do.
|
||||
However there is a property to further disable decorator
|
||||
impact."""
|
||||
|
||||
|
||||
# These decorators should not modify at all what the functions
|
||||
# originally do.
|
||||
#
|
||||
# However there is a property to further disable decorator
|
||||
# impat.
|
||||
#
|
||||
# This is set to true by script/build_jsonschema.py
|
||||
# only, so data is collected (again functionality is not modified)
|
||||
EnableJsonSchemaCollect = False
|
||||
|
|
|
@ -195,7 +195,7 @@ def add_components():
|
|||
"properties": {"platform": {"type": "string"}},
|
||||
}
|
||||
]
|
||||
if domain != "output" and domain != "display":
|
||||
if domain not in ("output", "display"):
|
||||
# output bases are either FLOAT or BINARY so don't add common base for this
|
||||
# display bases are either simple or FULL so don't add common base for this
|
||||
platform_schema = [
|
||||
|
@ -601,6 +601,42 @@ def convert_schema(path, vschema, un_extend=True):
|
|||
return output
|
||||
|
||||
|
||||
def add_pin_schema():
|
||||
from esphome import pins
|
||||
|
||||
add_module_schemas("PIN", pins)
|
||||
|
||||
|
||||
def add_pin_registry():
|
||||
from esphome import pins
|
||||
|
||||
pin_registry = pins.PIN_SCHEMA_REGISTRY
|
||||
assert len(pin_registry) > 0
|
||||
# Here are schemas for pcf8574, mcp23xxx and other port expanders which add
|
||||
# gpio registers
|
||||
# ESPHome validates pins schemas if it founds a key in the pin configuration.
|
||||
# This key is added to a required in jsonschema, and all options are part of a
|
||||
# oneOf section, so only one is selected. Also internal schema adds number as required.
|
||||
|
||||
for mode in ("INPUT", "OUTPUT"):
|
||||
schema_name = f"PIN.GPIO_FULL_{mode}_PIN_SCHEMA"
|
||||
internal = definitions[schema_name]
|
||||
definitions[schema_name]["additionalItems"] = False
|
||||
definitions[f"PIN.{mode}_INTERNAL"] = internal
|
||||
schemas = [get_ref(f"PIN.{mode}_INTERNAL")]
|
||||
schemas[0]["required"] = ["number"]
|
||||
# accept string and object, for internal shorthand pin IO:
|
||||
definitions[schema_name] = {"oneOf": schemas, "type": ["string", "object"]}
|
||||
|
||||
for k, v in pin_registry.items():
|
||||
pin_jschema = get_jschema(
|
||||
f"PIN.{mode}_" + k, v[1][0 if mode == "OUTPUT" else 1]
|
||||
)
|
||||
if unref(pin_jschema):
|
||||
pin_jschema["required"] = [k]
|
||||
schemas.append(pin_jschema)
|
||||
|
||||
|
||||
def dump_schema():
|
||||
import esphome.config_validation as cv
|
||||
|
||||
|
@ -669,10 +705,7 @@ def dump_schema():
|
|||
add_module_schemas("CONFIG", cv)
|
||||
get_jschema("POLLING_COMPONENT", cv.polling_component_schema("60s"))
|
||||
|
||||
add_module_schemas("PIN", pins)
|
||||
# fix short shothand pin IO:
|
||||
definitions["PIN.GPIO_FULL_INPUT_PIN_SCHEMA"]["type"] = ["string", "object"]
|
||||
definitions["PIN.GPIO_FULL_OUTPUT_PIN_SCHEMA"]["type"] = ["string", "object"]
|
||||
add_pin_schema()
|
||||
|
||||
add_module_schemas("REMOTE_BASE", remote_base)
|
||||
add_module_schemas("AUTOMATION", automation)
|
||||
|
@ -699,6 +732,7 @@ def dump_schema():
|
|||
add_components()
|
||||
|
||||
add_registries() # need second pass, e.g. climate.pid.autotune
|
||||
add_pin_registry()
|
||||
solve_pending_refs()
|
||||
|
||||
write_file_if_changed(file_path, json.dumps(output))
|
||||
|
|
Loading…
Reference in a new issue