esphome/esphomeyaml/components/i2c.py

39 lines
1.4 KiB
Python
Raw Normal View History

2018-04-07 01:23:03 +02:00
import voluptuous as vol
from esphomeyaml import pins
2018-11-19 22:12:24 +01:00
import esphomeyaml.config_validation as cv
from esphomeyaml.const import CONF_FREQUENCY, CONF_ID, CONF_RECEIVE_TIMEOUT, CONF_SCAN, CONF_SCL, \
CONF_SDA
from esphomeyaml.cpp_generator import Pvariable, add
from esphomeyaml.cpp_helpers import setup_component
from esphomeyaml.cpp_types import App, Component, esphomelib_ns
2018-04-07 01:23:03 +02:00
I2CComponent = esphomelib_ns.class_('I2CComponent', Component)
I2CDevice = pins.I2CDevice
2018-06-02 22:22:20 +02:00
2018-04-07 01:23:03 +02:00
CONFIG_SCHEMA = vol.Schema({
2018-06-02 22:22:20 +02:00
cv.GenerateID(): cv.declare_variable_id(I2CComponent),
2018-11-19 22:12:24 +01:00
vol.Required(CONF_SDA, default='SDA'): pins.input_pullup_pin,
vol.Required(CONF_SCL, default='SCL'): pins.input_pullup_pin,
2018-06-06 08:12:17 +02:00
vol.Optional(CONF_FREQUENCY): vol.All(cv.frequency, vol.Range(min=0, min_included=False)),
2018-05-06 15:56:12 +02:00
vol.Optional(CONF_SCAN): cv.boolean,
vol.Optional(CONF_RECEIVE_TIMEOUT): cv.invalid("The receive_timeout option has been removed "
"because timeouts are already handled by the "
"low-level i2c interface.")
}).extend(cv.COMPONENT_SCHEMA.schema)
2018-04-07 01:23:03 +02:00
def to_code(config):
2018-05-06 15:56:12 +02:00
rhs = App.init_i2c(config[CONF_SDA], config[CONF_SCL], config.get(CONF_SCAN))
2018-06-02 22:22:20 +02:00
i2c = Pvariable(config[CONF_ID], rhs)
2018-05-06 15:56:12 +02:00
if CONF_FREQUENCY in config:
add(i2c.set_frequency(config[CONF_FREQUENCY]))
setup_component(i2c, config)
2018-05-06 15:56:12 +02:00
BUILD_FLAGS = '-DUSE_I2C'
2018-05-14 11:50:56 +02:00
LIB_DEPS = 'Wire'