summaryrefslogtreecommitdiff
path: root/include/pio/libs/led/homekit/led.h
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
committerEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
commitd3a295872c49defb55fc8e4e43e55550991e0927 (patch)
treeb9dca15454f9027d5a9dad0d4443a20de04dbc5d /include/pio/libs/led/homekit/led.h
parentb7cbc2571c1870b4582ead45277d0aa7f961bec8 (diff)
parentbdbb296697f55f4c3a07af43c9aaf7a9ea86f3d0 (diff)
Merge branch 'master' of ch1p.io:homekit
Diffstat (limited to 'include/pio/libs/led/homekit/led.h')
-rw-r--r--include/pio/libs/led/homekit/led.h33
1 files changed, 33 insertions, 0 deletions
diff --git a/include/pio/libs/led/homekit/led.h b/include/pio/libs/led/homekit/led.h
new file mode 100644
index 0000000..775d2eb
--- /dev/null
+++ b/include/pio/libs/led/homekit/led.h
@@ -0,0 +1,33 @@
+#ifndef HOMEKIT_LIB_LED_H
+#define HOMEKIT_LIB_LED_H
+
+#include <Arduino.h>
+#include <stdint.h>
+
+namespace homekit::led {
+
+class Led {
+private:
+ uint8_t _pin;
+
+public:
+ explicit Led(uint8_t pin) : _pin(pin) {
+ pinMode(_pin, OUTPUT);
+ off();
+ }
+
+ inline void off() const { digitalWrite(_pin, HIGH); }
+ inline void on() const { digitalWrite(_pin, LOW); }
+
+ void on_off(uint16_t delay_ms, bool last_delay = false) const;
+ void blink(uint8_t count, uint16_t delay_ms) const;
+};
+
+#ifdef CONFIG_TARGET_NODEMCU
+extern const Led* board_led;
+#endif
+extern const Led* mcu_led;
+
+}
+
+#endif //HOMEKIT_LIB_LED_H