mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-31 07:03:55 +00:00 
			
		
		
		
	New coroutine-based task execution
This commit is contained in:
		| @@ -6,11 +6,6 @@ PLATFORM_SCHEMA = cv.PLATFORM_SCHEMA.extend({ | ||||
|  | ||||
| }) | ||||
|  | ||||
| COVER_SCHEMA = cv.MQTT_COMMAND_COMPONENT_SCHEMA.extend({ | ||||
|     cv.GenerateID('cover'): cv.register_variable_id, | ||||
|     cv.GenerateID('mqtt_cover', CONF_MQTT_ID): cv.register_variable_id, | ||||
| }) | ||||
|  | ||||
| cover_ns = esphomelib_ns.namespace('cover') | ||||
| Cover = cover_ns.Cover | ||||
| MQTTCoverComponent = cover_ns.MQTTCoverComponent | ||||
| @@ -21,15 +16,19 @@ OpenAction = cover_ns.OpenAction | ||||
| CloseAction = cover_ns.CloseAction | ||||
| StopAction = cover_ns.StopAction | ||||
|  | ||||
| COVER_SCHEMA = cv.MQTT_COMMAND_COMPONENT_SCHEMA.extend({ | ||||
|     cv.GenerateID(): cv.declare_variable_id(Cover), | ||||
|     cv.GenerateID(CONF_MQTT_ID): cv.declare_variable_id(MQTTCoverComponent), | ||||
| }) | ||||
|  | ||||
|  | ||||
| def setup_cover_core_(cover_var, mqtt_var, config): | ||||
|     setup_mqtt_component(mqtt_var, config) | ||||
|  | ||||
|  | ||||
| def setup_cover(cover_obj, mqtt_obj, config): | ||||
|     cover_var = Pvariable(Cover, config[CONF_ID], cover_obj, has_side_effects=False) | ||||
|     mqtt_var = Pvariable(MQTTCoverComponent, config[CONF_MQTT_ID], mqtt_obj, | ||||
|                          has_side_effects=False) | ||||
|     cover_var = Pvariable(config[CONF_ID], cover_obj, has_side_effects=False) | ||||
|     mqtt_var = Pvariable(config[CONF_MQTT_ID], mqtt_obj, has_side_effects=False) | ||||
|     setup_cover_core_(cover_var, mqtt_var, config) | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -7,8 +7,10 @@ from esphomeyaml.const import CONF_CLOSE_ACTION, CONF_LAMBDA, CONF_MAKE_ID, CONF | ||||
|     CONF_OPEN_ACTION, CONF_STOP_ACTION, CONF_OPTIMISTIC | ||||
| from esphomeyaml.helpers import App, Application, NoArg, add, process_lambda, variable | ||||
|  | ||||
| MakeTemplateCover = Application.MakeTemplateCover | ||||
|  | ||||
| PLATFORM_SCHEMA = vol.All(cover.PLATFORM_SCHEMA.extend({ | ||||
|     cv.GenerateID('template_cover', CONF_MAKE_ID): cv.register_variable_id, | ||||
|     cv.GenerateID(CONF_MAKE_ID): cv.declare_variable_id(MakeTemplateCover), | ||||
|     vol.Optional(CONF_LAMBDA): cv.lambda_, | ||||
|     vol.Optional(CONF_OPTIMISTIC): cv.boolean, | ||||
|     vol.Optional(CONF_OPEN_ACTION): automation.ACTIONS_SCHEMA, | ||||
| @@ -16,24 +18,30 @@ PLATFORM_SCHEMA = vol.All(cover.PLATFORM_SCHEMA.extend({ | ||||
|     vol.Optional(CONF_STOP_ACTION): automation.ACTIONS_SCHEMA, | ||||
| }).extend(cover.COVER_SCHEMA.schema), cv.has_at_least_one_key(CONF_LAMBDA, CONF_OPTIMISTIC)) | ||||
|  | ||||
| MakeTemplateCover = Application.MakeTemplateCover | ||||
|  | ||||
|  | ||||
| def to_code(config): | ||||
|     rhs = App.make_template_cover(config[CONF_NAME]) | ||||
|     make = variable(MakeTemplateCover, config[CONF_MAKE_ID], rhs) | ||||
|     make = variable(config[CONF_MAKE_ID], rhs) | ||||
|  | ||||
|     if CONF_LAMBDA in config: | ||||
|         template_ = process_lambda(config[CONF_LAMBDA], []) | ||||
|         template_ = None | ||||
|         for template_ in process_lambda(config[CONF_LAMBDA], []): | ||||
|             yield | ||||
|         add(make.Ptemplate_.set_state_lambda(template_)) | ||||
|     if CONF_OPEN_ACTION in config: | ||||
|         actions = automation.build_actions(config[CONF_OPEN_ACTION], NoArg) | ||||
|         actions = None | ||||
|         for actions in automation.build_actions(config[CONF_OPEN_ACTION], NoArg): | ||||
|             yield | ||||
|         add(make.Ptemplate_.add_open_actions(actions)) | ||||
|     if CONF_CLOSE_ACTION in config: | ||||
|         actions = automation.build_actions(config[CONF_CLOSE_ACTION], NoArg) | ||||
|         actions = None | ||||
|         for actions in automation.build_actions(config[CONF_CLOSE_ACTION], NoArg): | ||||
|             yield | ||||
|         add(make.Ptemplate_.add_close_actions(actions)) | ||||
|     if CONF_STOP_ACTION in config: | ||||
|         actions = automation.build_actions(config[CONF_STOP_ACTION], NoArg) | ||||
|         actions = None | ||||
|         for actions in automation.build_actions(config[CONF_STOP_ACTION], NoArg): | ||||
|             yield | ||||
|         add(make.Ptemplate_.add_stop_actions(actions)) | ||||
|     if CONF_OPTIMISTIC in config: | ||||
|         add(make.Ptemplate_.set_optimistic(config[CONF_OPTIMISTIC])) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user