denko 0.13.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.github/workflows/build_avr.yml +61 -0
- data/.github/workflows/build_esp32.yml +58 -0
- data/.github/workflows/build_esp8266.yml +57 -0
- data/.github/workflows/build_megaavr.yml +61 -0
- data/.github/workflows/build_rp2040.yml +61 -0
- data/.github/workflows/build_sam3x.yml +59 -0
- data/.github/workflows/build_samd.yml +61 -0
- data/.github/workflows/ruby.yml +47 -0
- data/.gitignore +24 -0
- data/.gitmodules +3 -0
- data/.vscode/settings.json +5 -0
- data/.vscode/tasks.json +20 -0
- data/CHANGELOG.md +466 -0
- data/DEPS_CLI.md +80 -0
- data/DEPS_IDE.md +120 -0
- data/Gemfile +4 -0
- data/HARDWARE.md +195 -0
- data/LICENSE +22 -0
- data/README.md +152 -0
- data/Rakefile +11 -0
- data/bin/denko +22 -0
- data/build +27 -0
- data/denko.gemspec +47 -0
- data/examples/advanced/rotary_encoder_mac_volume.rb +48 -0
- data/examples/advanced/ssd1306_time_temp_rh.rb +48 -0
- data/examples/analog_io/ads1118.rb +74 -0
- data/examples/analog_io/dac_loopback.rb +32 -0
- data/examples/analog_io/input.rb +52 -0
- data/examples/connection/tcp.rb +34 -0
- data/examples/digital_io/rotary_encoder.rb +26 -0
- data/examples/display/hd44780.png +0 -0
- data/examples/display/hd44780.rb +39 -0
- data/examples/display/ssd1306.rb +40 -0
- data/examples/display/ssd1306_s2_pico.rb +29 -0
- data/examples/eeprom/built_in.rb +32 -0
- data/examples/i2c/search.rb +53 -0
- data/examples/led/apa102_bounce.rb +33 -0
- data/examples/led/apa102_breathe.rb +45 -0
- data/examples/led/builtin_blink.rb +12 -0
- data/examples/led/seven_segment_char_echo.rb +15 -0
- data/examples/led/ws2812_bounce.rb +32 -0
- data/examples/led/ws2812_builtin_blink.rb +21 -0
- data/examples/motor/l298.rb +43 -0
- data/examples/motor/servo.rb +16 -0
- data/examples/motor/stepper.png +0 -0
- data/examples/motor/stepper.rb +43 -0
- data/examples/pulse_io/buzzer.rb +30 -0
- data/examples/pulse_io/ir_transmitter.rb +55 -0
- data/examples/rtc/ds3231.rb +48 -0
- data/examples/sensor/aht10.rb +15 -0
- data/examples/sensor/aht20.rb +15 -0
- data/examples/sensor/bme280.rb +75 -0
- data/examples/sensor/dht.rb +24 -0
- data/examples/sensor/ds18b20.rb +58 -0
- data/examples/sensor/htu21d.rb +54 -0
- data/examples/sensor/htu31d.rb +31 -0
- data/examples/spi/input_register.rb +50 -0
- data/examples/spi/output_register.rb +49 -0
- data/examples/spi/ssd_through_register.rb +40 -0
- data/examples/spi/two_registers.rb +46 -0
- data/examples/uart/bit_bang_read.rb +16 -0
- data/examples/uart/bit_bang_write.rb +16 -0
- data/examples/uart/board_passthrough.rb +34 -0
- data/examples/uart/hardware_loopback.rb +16 -0
- data/lib/denko/analog_io/ads1118.rb +182 -0
- data/lib/denko/analog_io/input.rb +79 -0
- data/lib/denko/analog_io/output.rb +20 -0
- data/lib/denko/analog_io/potentiometer.rb +15 -0
- data/lib/denko/analog_io/sensor.rb +6 -0
- data/lib/denko/analog_io.rb +9 -0
- data/lib/denko/behaviors/board_proxy.rb +23 -0
- data/lib/denko/behaviors/bus_controller.rb +11 -0
- data/lib/denko/behaviors/bus_controller_addressed.rb +15 -0
- data/lib/denko/behaviors/bus_peripheral.rb +21 -0
- data/lib/denko/behaviors/bus_peripheral_addressed.rb +15 -0
- data/lib/denko/behaviors/callbacks.rb +67 -0
- data/lib/denko/behaviors/component.rb +48 -0
- data/lib/denko/behaviors/input_pin.rb +24 -0
- data/lib/denko/behaviors/listener.rb +22 -0
- data/lib/denko/behaviors/multi_pin.rb +72 -0
- data/lib/denko/behaviors/output_pin.rb +13 -0
- data/lib/denko/behaviors/poller.rb +31 -0
- data/lib/denko/behaviors/reader.rb +49 -0
- data/lib/denko/behaviors/single_pin.rb +26 -0
- data/lib/denko/behaviors/state.rb +24 -0
- data/lib/denko/behaviors/subcomponents.rb +35 -0
- data/lib/denko/behaviors/threaded.rb +54 -0
- data/lib/denko/behaviors.rb +26 -0
- data/lib/denko/board/core.rb +151 -0
- data/lib/denko/board/eeprom.rb +20 -0
- data/lib/denko/board/i2c.rb +68 -0
- data/lib/denko/board/infrared.rb +18 -0
- data/lib/denko/board/led_array.rb +18 -0
- data/lib/denko/board/map.rb +46 -0
- data/lib/denko/board/message_pack.rb +7 -0
- data/lib/denko/board/one_wire.rb +34 -0
- data/lib/denko/board/pulse.rb +26 -0
- data/lib/denko/board/servo.rb +22 -0
- data/lib/denko/board/spi.rb +65 -0
- data/lib/denko/board/spi_bit_bang.rb +41 -0
- data/lib/denko/board/tone.rb +23 -0
- data/lib/denko/board/uart.rb +42 -0
- data/lib/denko/board/uart_bit_bang.rb +33 -0
- data/lib/denko/board.rb +104 -0
- data/lib/denko/connection/base.rb +75 -0
- data/lib/denko/connection/board_uart.rb +36 -0
- data/lib/denko/connection/flow_control.rb +153 -0
- data/lib/denko/connection/handshake.rb +60 -0
- data/lib/denko/connection/serial.rb +90 -0
- data/lib/denko/connection/tcp.rb +44 -0
- data/lib/denko/connection.rb +10 -0
- data/lib/denko/digital_io/button.rb +8 -0
- data/lib/denko/digital_io/input.rb +44 -0
- data/lib/denko/digital_io/output.rb +47 -0
- data/lib/denko/digital_io/relay.rb +6 -0
- data/lib/denko/digital_io/rotary_encoder.rb +107 -0
- data/lib/denko/digital_io.rb +9 -0
- data/lib/denko/display/canvas.rb +282 -0
- data/lib/denko/display/hd44780.rb +266 -0
- data/lib/denko/display/ssd1306.rb +179 -0
- data/lib/denko/display.rb +7 -0
- data/lib/denko/eeprom/built_in.rb +69 -0
- data/lib/denko/eeprom.rb +5 -0
- data/lib/denko/fonts.rb +106 -0
- data/lib/denko/i2c/bus.rb +52 -0
- data/lib/denko/i2c/peripheral.rb +38 -0
- data/lib/denko/i2c.rb +6 -0
- data/lib/denko/led/apa102.rb +87 -0
- data/lib/denko/led/base.rb +12 -0
- data/lib/denko/led/rgb.rb +38 -0
- data/lib/denko/led/seven_segment.rb +111 -0
- data/lib/denko/led/ws2812.rb +48 -0
- data/lib/denko/led.rb +13 -0
- data/lib/denko/message.rb +92 -0
- data/lib/denko/motor/l298.rb +49 -0
- data/lib/denko/motor/servo.rb +51 -0
- data/lib/denko/motor/stepper.rb +71 -0
- data/lib/denko/motor.rb +7 -0
- data/lib/denko/one_wire/bus.rb +61 -0
- data/lib/denko/one_wire/bus_enumeration.rb +88 -0
- data/lib/denko/one_wire/constants.rb +17 -0
- data/lib/denko/one_wire/helper.rb +33 -0
- data/lib/denko/one_wire/peripheral.rb +62 -0
- data/lib/denko/one_wire.rb +9 -0
- data/lib/denko/pulse_io/buzzer.rb +25 -0
- data/lib/denko/pulse_io/ir_transmitter.rb +22 -0
- data/lib/denko/pulse_io/pwm_output.rb +34 -0
- data/lib/denko/pulse_io.rb +7 -0
- data/lib/denko/rtc/ds3231.rb +48 -0
- data/lib/denko/rtc.rb +5 -0
- data/lib/denko/sensor/aht.rb +165 -0
- data/lib/denko/sensor/bme280.rb +366 -0
- data/lib/denko/sensor/dht.rb +43 -0
- data/lib/denko/sensor/ds18b20.rb +74 -0
- data/lib/denko/sensor/htu21d.rb +168 -0
- data/lib/denko/sensor/htu31d.rb +187 -0
- data/lib/denko/sensor/virtual.rb +42 -0
- data/lib/denko/sensor.rb +13 -0
- data/lib/denko/spi/base_register.rb +37 -0
- data/lib/denko/spi/bit_bang.rb +74 -0
- data/lib/denko/spi/bus.rb +44 -0
- data/lib/denko/spi/input_register.rb +130 -0
- data/lib/denko/spi/output_register.rb +67 -0
- data/lib/denko/spi/peripheral.rb +43 -0
- data/lib/denko/spi.rb +10 -0
- data/lib/denko/uart/bit_bang.rb +69 -0
- data/lib/denko/uart/hardware.rb +65 -0
- data/lib/denko/uart.rb +6 -0
- data/lib/denko/version.rb +3 -0
- data/lib/denko.rb +39 -0
- data/lib/denko_cli/generator.rb +171 -0
- data/lib/denko_cli/helper.rb +29 -0
- data/lib/denko_cli/missing_files.txt +20 -0
- data/lib/denko_cli/packages.rb +101 -0
- data/lib/denko_cli/parser.rb +73 -0
- data/lib/denko_cli/targets.rb +30 -0
- data/lib/denko_cli/targets.txt +113 -0
- data/lib/denko_cli/usage.txt +34 -0
- data/lib/denko_cli.rb +18 -0
- data/src/denko_ethernet.ino +78 -0
- data/src/denko_serial.ino +41 -0
- data/src/denko_wifi.ino +157 -0
- data/src/lib/Denko.cpp +330 -0
- data/src/lib/Denko.h +259 -0
- data/src/lib/DenkoCoreIO.cpp +322 -0
- data/src/lib/DenkoDefines.h +116 -0
- data/src/lib/DenkoEEPROM.cpp +64 -0
- data/src/lib/DenkoI2C.cpp +155 -0
- data/src/lib/DenkoIROut.cpp +33 -0
- data/src/lib/DenkoIROutESP.cpp +26 -0
- data/src/lib/DenkoLEDArray.cpp +49 -0
- data/src/lib/DenkoOneWire.cpp +156 -0
- data/src/lib/DenkoPulseInput.cpp +57 -0
- data/src/lib/DenkoSPI.cpp +165 -0
- data/src/lib/DenkoSPIBB.cpp +156 -0
- data/src/lib/DenkoServo.cpp +83 -0
- data/src/lib/DenkoTone.cpp +25 -0
- data/src/lib/DenkoUART.cpp +118 -0
- data/src/lib/DenkoUARTBB.cpp +62 -0
- data/target.yml +3 -0
- data/test/analog_io/input_test.rb +38 -0
- data/test/analog_io/output_test.rb +26 -0
- data/test/analog_io/potentiometer_test.rb +62 -0
- data/test/behaviors/board_proxy_test.rb +24 -0
- data/test/behaviors/bus_controller_addressed_test.rb +40 -0
- data/test/behaviors/bus_controller_test.rb +28 -0
- data/test/behaviors/bus_peripheral_addressed.rb +44 -0
- data/test/behaviors/bus_peripheral_test.rb +39 -0
- data/test/behaviors/callbacks_test.rb +118 -0
- data/test/behaviors/component_test.rb +56 -0
- data/test/behaviors/input_pin_test.rb +42 -0
- data/test/behaviors/listener_test.rb +60 -0
- data/test/behaviors/multi_pin_test.rb +70 -0
- data/test/behaviors/output_pin_test.rb +27 -0
- data/test/behaviors/poller_test.rb +64 -0
- data/test/behaviors/reader_test.rb +68 -0
- data/test/behaviors/single_pin_test.rb +41 -0
- data/test/behaviors/subcomponents_test.rb +75 -0
- data/test/behaviors/threaded_test.rb +98 -0
- data/test/board/board_test.rb +130 -0
- data/test/board/core_test.rb +182 -0
- data/test/board/eeprom_test.rb +34 -0
- data/test/board/helper_test.rb +38 -0
- data/test/board/i2c_test.rb +114 -0
- data/test/board/infrared_test.rb +37 -0
- data/test/board/message_test.rb +54 -0
- data/test/board/one_wire_test.rb +69 -0
- data/test/board/pulse_test.rb +51 -0
- data/test/board/servo_test.rb +47 -0
- data/test/board/spi_test.rb +97 -0
- data/test/board/tone_test.rb +42 -0
- data/test/connection/serial_test.rb +172 -0
- data/test/connection/tcp_test.rb +37 -0
- data/test/digital_io/input_test.rb +65 -0
- data/test/digital_io/output_test.rb +64 -0
- data/test/digital_io/rotary_encoder_test.rb +99 -0
- data/test/display/hd44780_test.rb +23 -0
- data/test/eeprom/built_in_test.rb +61 -0
- data/test/i2c/bus_test.rb +66 -0
- data/test/i2c/peripheral_test.rb +50 -0
- data/test/led/base_test.rb +24 -0
- data/test/led/rgb_test.rb +64 -0
- data/test/led/seven_segment_test.rb +86 -0
- data/test/motor/servo_test.rb +62 -0
- data/test/motor/stepper_test.rb +51 -0
- data/test/one_wire/bus_enumerator_test.rb +134 -0
- data/test/one_wire/bus_test.rb +142 -0
- data/test/one_wire/helper_test.rb +18 -0
- data/test/one_wire/peripheral_test.rb +158 -0
- data/test/pulse_io/buzzer_test.rb +48 -0
- data/test/pulse_io/ir_transmitter_test.rb +38 -0
- data/test/pulse_io/pwm_output_test.rb +72 -0
- data/test/rtc/ds3231_test.rb +55 -0
- data/test/sensor/dht_test.rb +64 -0
- data/test/sensor/ds18b20_test.rb +107 -0
- data/test/spi/base_register_test.rb +34 -0
- data/test/spi/bus_test.rb +76 -0
- data/test/spi/input_register_test.rb +140 -0
- data/test/spi/output_register_test.rb +93 -0
- data/test/test_helper.rb +223 -0
- data/test/uart/bitbang_test.rb +37 -0
- data/tutorial/01-led/led.fzz +0 -0
- data/tutorial/01-led/led.pdf +0 -0
- data/tutorial/01-led/led.rb +73 -0
- data/tutorial/02-button/button.fzz +0 -0
- data/tutorial/02-button/button.pdf +0 -0
- data/tutorial/02-button/button.rb +64 -0
- data/tutorial/03-potentiometer/potentiometer.fzz +0 -0
- data/tutorial/03-potentiometer/potentiometer.pdf +0 -0
- data/tutorial/03-potentiometer/potentiometer.rb +62 -0
- data/tutorial/04-pwm_led/pwm_led.fzz +0 -0
- data/tutorial/04-pwm_led/pwm_led.pdf +0 -0
- data/tutorial/04-pwm_led/pwm_led.rb +66 -0
- data/tutorial/05-rgb_led/rgb_led.fzz +0 -0
- data/tutorial/05-rgb_led/rgb_led.pdf +0 -0
- data/tutorial/05-rgb_led/rgb_led.rb +58 -0
- data/tutorial/05-rgb_led/rgb_mapping.rb +76 -0
- data/vendor/board-maps/.gitignore +56 -0
- data/vendor/board-maps/.gitmodules +21 -0
- data/vendor/board-maps/BoardMap.h +1364 -0
- data/vendor/board-maps/README.md +51 -0
- data/vendor/board-maps/lib/boards_parser.rb +66 -0
- data/vendor/board-maps/lib/header_parser.rb +164 -0
- data/vendor/board-maps/run.rb +47 -0
- data/vendor/board-maps/yaml/0XCB_HELIOS.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S2.yml +25 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S2_REVTFT.yml +25 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S2_TFT.yml +27 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S3.yml +29 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S3_NOPSRAM.yml +29 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S3_REVTFT.yml +25 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32S3_TFT.yml +27 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_ESP32_V2.yml +30 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_CAN.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_DVI.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_PROP_MAKER.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_RFM.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_SCORPIO.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_THINKINK.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_FEATHER_RP2040_USB_HOST.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_ITSYBITSY_ESP32.yml +24 -0
- data/vendor/board-maps/yaml/ADAFRUIT_ITSYBITSY_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_KB2040_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_MACROPAD_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_MATRIXPORTAL_ESP32S3.yml +16 -0
- data/vendor/board-maps/yaml/ADAFRUIT_QTPY_ESP32C3.yml +12 -0
- data/vendor/board-maps/yaml/ADAFRUIT_QTPY_ESP32S2.yml +22 -0
- data/vendor/board-maps/yaml/ADAFRUIT_QTPY_ESP32S3_NOPSRAM.yml +20 -0
- data/vendor/board-maps/yaml/ADAFRUIT_QTPY_ESP32_PICO.yml +27 -0
- data/vendor/board-maps/yaml/ADAFRUIT_QTPY_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_STEMMAFRIEND_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ADAFRUIT_TRINKEYQT_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/ALKS.yml +34 -0
- data/vendor/board-maps/yaml/AMPERKA_WIFI_SLOT.yml +16 -0
- data/vendor/board-maps/yaml/AVR_ADK.yml +24 -0
- data/vendor/board-maps/yaml/AVR_BT.yml +16 -0
- data/vendor/board-maps/yaml/AVR_CIRCUITPLAY.yml +14 -0
- data/vendor/board-maps/yaml/AVR_DUEMILANOVE.yml +16 -0
- data/vendor/board-maps/yaml/AVR_ESPLORA.yml +20 -0
- data/vendor/board-maps/yaml/AVR_ETHERNET.yml +16 -0
- data/vendor/board-maps/yaml/AVR_FIO.yml +16 -0
- data/vendor/board-maps/yaml/AVR_GEMMA.yml +6 -0
- data/vendor/board-maps/yaml/AVR_INDUSTRIAL101.yml +20 -0
- data/vendor/board-maps/yaml/AVR_LEONARDO.yml +20 -0
- data/vendor/board-maps/yaml/AVR_LEONARDO_ETH.yml +20 -0
- data/vendor/board-maps/yaml/AVR_LILYPAD.yml +16 -0
- data/vendor/board-maps/yaml/AVR_LILYPAD_USB.yml +20 -0
- data/vendor/board-maps/yaml/AVR_LININO_ONE.yml +20 -0
- data/vendor/board-maps/yaml/AVR_MEGA.yml +24 -0
- data/vendor/board-maps/yaml/AVR_MEGA2560.yml +24 -0
- data/vendor/board-maps/yaml/AVR_MICRO.yml +20 -0
- data/vendor/board-maps/yaml/AVR_MINI.yml +16 -0
- data/vendor/board-maps/yaml/AVR_NANO.yml +16 -0
- data/vendor/board-maps/yaml/AVR_NANO_EVERY.yml +22 -0
- data/vendor/board-maps/yaml/AVR_NG.yml +16 -0
- data/vendor/board-maps/yaml/AVR_PRO.yml +16 -0
- data/vendor/board-maps/yaml/AVR_ROBOT_CONTROL.yml +22 -0
- data/vendor/board-maps/yaml/AVR_ROBOT_MOTOR.yml +19 -0
- data/vendor/board-maps/yaml/AVR_UNO.yml +16 -0
- data/vendor/board-maps/yaml/AVR_UNO_WIFI_DEV_ED.yml +16 -0
- data/vendor/board-maps/yaml/AVR_UNO_WIFI_REV2.yml +22 -0
- data/vendor/board-maps/yaml/AVR_YUN.yml +20 -0
- data/vendor/board-maps/yaml/AVR_YUNMINI.yml +20 -0
- data/vendor/board-maps/yaml/AirM2M_CORE_ESP32C3.yml +14 -0
- data/vendor/board-maps/yaml/BEE_DATA_LOGGER.yml +39 -0
- data/vendor/board-maps/yaml/BPI_BIT.yml +9 -0
- data/vendor/board-maps/yaml/BPI_LEAF_S3.yml +31 -0
- data/vendor/board-maps/yaml/BRIDGETEK_IDM2040-7A.yml +48 -0
- data/vendor/board-maps/yaml/BeeMotionS3.yml +40 -0
- data/vendor/board-maps/yaml/Bee_Motion.yml +27 -0
- data/vendor/board-maps/yaml/Bee_Motion_Mini.yml +1 -0
- data/vendor/board-maps/yaml/Bee_S3.yml +38 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_LORA_RP2040.yml +39 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_LTE_RP2040.yml +38 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_NFC_RP2040.yml +32 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_SDRTC_RP2040.yml +36 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_SUBGHZ_RP2040.yml +39 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_UWB_RP2040.yml +39 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_WIFI_BLE_RP2040.yml +42 -0
- data/vendor/board-maps/yaml/CHALLENGER_2040_WIFI_RP2040.yml +38 -0
- data/vendor/board-maps/yaml/CHALLENGER_NB_2040_WIFI_RP2040.yml +38 -0
- data/vendor/board-maps/yaml/CRABIK_SLOT_ESP32_S3.yml +19 -0
- data/vendor/board-maps/yaml/CYTRON_MAKER_FEATHER_AIOT_S3.yml +26 -0
- data/vendor/board-maps/yaml/CYTRON_MAKER_NANO_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/CYTRON_MAKER_PI_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/CoreESP32.yml +49 -0
- data/vendor/board-maps/yaml/D1_MINI32.yml +36 -0
- data/vendor/board-maps/yaml/D1_UNO32.yml +28 -0
- data/vendor/board-maps/yaml/DATANOISETV_PICOADK.yml +48 -0
- data/vendor/board-maps/yaml/DENKY.yml +26 -0
- data/vendor/board-maps/yaml/DENKY_PICOV3.yml +26 -0
- data/vendor/board-maps/yaml/DENKY_WROOM32.yml +26 -0
- data/vendor/board-maps/yaml/DEPARTMENT_OF_ALCHEMY_MINIMAIN_ESP32S2.yml +26 -0
- data/vendor/board-maps/yaml/DFROBOT_BEETLE_ESP32_C3.yml +14 -0
- data/vendor/board-maps/yaml/DFROBOT_BEETLE_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/DFROBOT_FIREBEETLE_2_ESP32E.yml +44 -0
- data/vendor/board-maps/yaml/DFROBOT_FIREBEETLE_2_ESP32S3.yml +38 -0
- data/vendor/board-maps/yaml/DFROBOT_ROMEO_ESP32S3.yml +7 -0
- data/vendor/board-maps/yaml/DPU_ESP32.yml +26 -0
- data/vendor/board-maps/yaml/DYDK.yml +38 -0
- data/vendor/board-maps/yaml/DYDK1A.yml +37 -0
- data/vendor/board-maps/yaml/DYDK1Av2.yml +45 -0
- data/vendor/board-maps/yaml/DYG.yml +20 -0
- data/vendor/board-maps/yaml/DYM.yml +40 -0
- data/vendor/board-maps/yaml/DYMv2.yml +39 -0
- data/vendor/board-maps/yaml/D_Duino_32.yml +29 -0
- data/vendor/board-maps/yaml/ELECTRONICCATS_HUNTERCAT_NFC.yml +44 -0
- data/vendor/board-maps/yaml/ESP320.yml +8 -0
- data/vendor/board-maps/yaml/ESP32C3_DEV.yml +14 -0
- data/vendor/board-maps/yaml/ESP32C3_M1_I_KIT.yml +13 -0
- data/vendor/board-maps/yaml/ESP32S2_DEV.yml +33 -0
- data/vendor/board-maps/yaml/ESP32S2_THING_PLUS.yml +34 -0
- data/vendor/board-maps/yaml/ESP32S2_USB.yml +33 -0
- data/vendor/board-maps/yaml/ESP32S3_CAM_LCD.yml +7 -0
- data/vendor/board-maps/yaml/ESP32S3_DEV.yml +38 -0
- data/vendor/board-maps/yaml/ESP32_DEV.yml +26 -0
- data/vendor/board-maps/yaml/ESP32_DEVKIT_LIPO.yml +26 -0
- data/vendor/board-maps/yaml/ESP32_EVB.yml +7 -0
- data/vendor/board-maps/yaml/ESP32_GATEWAY.yml +13 -0
- data/vendor/board-maps/yaml/ESP32_GATEWAY_C.yml +13 -0
- data/vendor/board-maps/yaml/ESP32_GATEWAY_E.yml +13 -0
- data/vendor/board-maps/yaml/ESP32_GATEWAY_F.yml +13 -0
- data/vendor/board-maps/yaml/ESP32_IOT_REDBOARD.yml +27 -0
- data/vendor/board-maps/yaml/ESP32_MICROMOD.yml +24 -0
- data/vendor/board-maps/yaml/ESP32_PICO.yml +26 -0
- data/vendor/board-maps/yaml/ESP32_POE.yml +7 -0
- data/vendor/board-maps/yaml/ESP32_POE_ISO.yml +7 -0
- data/vendor/board-maps/yaml/ESP32_S3_BOX.yml +16 -0
- data/vendor/board-maps/yaml/ESP32_S3_USB_OTG.yml +11 -0
- data/vendor/board-maps/yaml/ESP32_THING.yml +27 -0
- data/vendor/board-maps/yaml/ESP32_THING_PLUS.yml +30 -0
- data/vendor/board-maps/yaml/ESP32_THING_PLUS_C.yml +30 -0
- data/vendor/board-maps/yaml/ESP32_WROOM_DA.yml +26 -0
- data/vendor/board-maps/yaml/ESP32_WROVER_KIT.yml +26 -0
- data/vendor/board-maps/yaml/ESP8266_ADAFRUIT_HUZZAH.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_AGRUMINO_LEMON_V4.yml +8 -0
- data/vendor/board-maps/yaml/ESP8266_ARDUINO_PRIMO.yml +7 -0
- data/vendor/board-maps/yaml/ESP8266_ARDUINO_STAR_OTTO.yml +7 -0
- data/vendor/board-maps/yaml/ESP8266_ARDUINO_UNOWIFI.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESP01.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESP07.yml +20 -0
- data/vendor/board-maps/yaml/ESP8266_ESP12.yml +20 -0
- data/vendor/board-maps/yaml/ESP8266_ESP13.yml +17 -0
- data/vendor/board-maps/yaml/ESP8266_ESP210.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESPECTRO_CORE.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESPINO_ESP12.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESPINO_ESP13.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESPRESSO_LITE_V1.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_ESPRESSO_LITE_V2.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_GENERIC.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_INVENT_ONE.yml +22 -0
- data/vendor/board-maps/yaml/ESP8266_NODEMCU_ESP12.yml +20 -0
- data/vendor/board-maps/yaml/ESP8266_NODEMCU_ESP12E.yml +20 -0
- data/vendor/board-maps/yaml/ESP8266_OAK.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_PHOENIX_V1.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_PHOENIX_V2.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_SCHIRMILABS_EDUINO_WIFI.yml +25 -0
- data/vendor/board-maps/yaml/ESP8266_SONOFF_BASIC.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_SONOFF_S20.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_SONOFF_SV.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_SONOFF_TH.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_THING.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_THING_DEV.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_WEMOS_D1MINI.yml +18 -0
- data/vendor/board-maps/yaml/ESP8266_WEMOS_D1MINILITE.yml +18 -0
- data/vendor/board-maps/yaml/ESP8266_WEMOS_D1MINIPRO.yml +18 -0
- data/vendor/board-maps/yaml/ESP8266_WEMOS_D1R1.yml +25 -0
- data/vendor/board-maps/yaml/ESP8266_WEMOS_D1WROOM02.yml +18 -0
- data/vendor/board-maps/yaml/ESP8266_WIO_LINK.yml +9 -0
- data/vendor/board-maps/yaml/ESP8266_XINABOX_CW01.yml +9 -0
- data/vendor/board-maps/yaml/ESPECTRO32.yml +27 -0
- data/vendor/board-maps/yaml/ESPea32.yml +27 -0
- data/vendor/board-maps/yaml/ESPino32.yml +27 -0
- data/vendor/board-maps/yaml/ET-Board.yml +26 -0
- data/vendor/board-maps/yaml/EXTREMEELEXTRONICS_RC2040.yml +46 -0
- data/vendor/board-maps/yaml/Edgebox-ESP-100.yml +7 -0
- data/vendor/board-maps/yaml/FEATHERS2.yml +33 -0
- data/vendor/board-maps/yaml/FEATHERS2NEO.yml +30 -0
- data/vendor/board-maps/yaml/FEATHERS3.yml +29 -0
- data/vendor/board-maps/yaml/FEATHER_ESP32.yml +28 -0
- data/vendor/board-maps/yaml/FLYBOARD2040_CORE.yml +48 -0
- data/vendor/board-maps/yaml/FRANZININHO_WIFI.yml +33 -0
- data/vendor/board-maps/yaml/FRANZININHO_WIFI_MSC.yml +33 -0
- data/vendor/board-maps/yaml/FROG_ESP32.yml +26 -0
- data/vendor/board-maps/yaml/FUNHOUSE_ESP32S2.yml +22 -0
- data/vendor/board-maps/yaml/GEN4_IOD.yml +9 -0
- data/vendor/board-maps/yaml/GENERIC_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/HEALTHYPI_4.yml +27 -0
- data/vendor/board-maps/yaml/HONEYLEMON.yml +27 -0
- data/vendor/board-maps/yaml/HORNBILL_ESP32_DEV.yml +27 -0
- data/vendor/board-maps/yaml/HORNBILL_ESP32_MINIMA.yml +16 -0
- data/vendor/board-maps/yaml/ILABS_2040_RPICO32_RP2040.yml +47 -0
- data/vendor/board-maps/yaml/IMBRIOS_LOGSENS_V1P1.yml +19 -0
- data/vendor/board-maps/yaml/INTOROBOT_ESP32_DEV.yml +34 -0
- data/vendor/board-maps/yaml/LILYGO_T_DISPLAY_S3.yml +26 -0
- data/vendor/board-maps/yaml/LOLIN32.yml +27 -0
- data/vendor/board-maps/yaml/LOLIN32_LITE.yml +27 -0
- data/vendor/board-maps/yaml/LOLIN_C3_MINI.yml +14 -0
- data/vendor/board-maps/yaml/LOLIN_D32.yml +27 -0
- data/vendor/board-maps/yaml/LOLIN_D32_PRO.yml +27 -0
- data/vendor/board-maps/yaml/LOLIN_S2_MINI.yml +34 -0
- data/vendor/board-maps/yaml/LOLIN_S2_PICO.yml +34 -0
- data/vendor/board-maps/yaml/LOLIN_S3.yml +32 -0
- data/vendor/board-maps/yaml/LOLIN_S3_MINI.yml +32 -0
- data/vendor/board-maps/yaml/LOLIN_S3_PRO.yml +32 -0
- data/vendor/board-maps/yaml/Lion_Bit_Dev_Board.yml +18 -0
- data/vendor/board-maps/yaml/LoPy.yml +27 -0
- data/vendor/board-maps/yaml/LoPy4.yml +27 -0
- data/vendor/board-maps/yaml/M5STACK_CORES3.yml +8 -0
- data/vendor/board-maps/yaml/M5STACK_Core2.yml +9 -0
- data/vendor/board-maps/yaml/M5STACK_FIRE.yml +10 -0
- data/vendor/board-maps/yaml/M5Stack-Timer-CAM.yml +10 -0
- data/vendor/board-maps/yaml/M5Stack_ATOM.yml +10 -0
- data/vendor/board-maps/yaml/M5Stack_ATOMS3.yml +7 -0
- data/vendor/board-maps/yaml/M5Stack_CoreInk.yml +9 -0
- data/vendor/board-maps/yaml/M5Stack_Core_ESP32.yml +10 -0
- data/vendor/board-maps/yaml/M5Stack_Station.yml +10 -0
- data/vendor/board-maps/yaml/M5Stick_C.yml +10 -0
- data/vendor/board-maps/yaml/MAGTAG29_ESP32S2.yml +21 -0
- data/vendor/board-maps/yaml/MELOPERO_COOKIE_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/MELOPERO_SHAKE_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/METRO_ESP32S2.yml +34 -0
- data/vendor/board-maps/yaml/MGBOT_IOTIK32A.yml +27 -0
- data/vendor/board-maps/yaml/MGBOT_IOTIK32B.yml +27 -0
- data/vendor/board-maps/yaml/MH_ET_LIVE_ESP32DEVKIT.yml +27 -0
- data/vendor/board-maps/yaml/MH_ET_LIVE_ESP32MINIKIT.yml +27 -0
- data/vendor/board-maps/yaml/MICROS2.yml +34 -0
- data/vendor/board-maps/yaml/MOD_WIFI_ESP8266.yml +9 -0
- data/vendor/board-maps/yaml/Metro.yml +8 -0
- data/vendor/board-maps/yaml/NANO32.yml +27 -0
- data/vendor/board-maps/yaml/NANO_RP2040_CONNECT.yml +35 -0
- data/vendor/board-maps/yaml/NEBULAS3.yml +33 -0
- data/vendor/board-maps/yaml/NEKOSYSTEMS_BL2040_MINI.yml +48 -0
- data/vendor/board-maps/yaml/NULLBITS_BIT_C_PRO.yml +48 -0
- data/vendor/board-maps/yaml/Node32s.yml +27 -0
- data/vendor/board-maps/yaml/NodeMCU_32S.yml +27 -0
- data/vendor/board-maps/yaml/ODROID_ESP32.yml +10 -0
- data/vendor/board-maps/yaml/ONEHORSE_ESP32_DEV.yml +24 -0
- data/vendor/board-maps/yaml/OROCA_EDUBOT.yml +33 -0
- data/vendor/board-maps/yaml/PIMORONI_PGA2040.yml +48 -0
- data/vendor/board-maps/yaml/PROS3.yml +28 -0
- data/vendor/board-maps/yaml/PYCOM_GPY.yml +27 -0
- data/vendor/board-maps/yaml/Piranha.yml +16 -0
- data/vendor/board-maps/yaml/Pocket32.yml +27 -0
- data/vendor/board-maps/yaml/QUANTUM.yml +26 -0
- data/vendor/board-maps/yaml/RASPBERRY_PI_PICO.yml +48 -0
- data/vendor/board-maps/yaml/RASPBERRY_PI_PICO_W.yml +48 -0
- data/vendor/board-maps/yaml/REDPILL_ESP32S3.yml +32 -0
- data/vendor/board-maps/yaml/RMP.yml +33 -0
- data/vendor/board-maps/yaml/SAMD_CIRCUITPLAYGROUND_EXPRESS.yml +12 -0
- data/vendor/board-maps/yaml/SAMD_MKR1000.yml +20 -0
- data/vendor/board-maps/yaml/SAMD_MKRFox1200.yml +19 -0
- data/vendor/board-maps/yaml/SAMD_MKRGSM1400.yml +15 -0
- data/vendor/board-maps/yaml/SAMD_MKRNB1500.yml +15 -0
- data/vendor/board-maps/yaml/SAMD_MKRVIDOR4000.yml +19 -0
- data/vendor/board-maps/yaml/SAMD_MKRWAN1300.yml +18 -0
- data/vendor/board-maps/yaml/SAMD_MKRWAN1310.yml +18 -0
- data/vendor/board-maps/yaml/SAMD_MKRWIFI1010.yml +19 -0
- data/vendor/board-maps/yaml/SAMD_MKRZERO.yml +19 -0
- data/vendor/board-maps/yaml/SAMD_NANO_33_IOT.yml +13 -0
- data/vendor/board-maps/yaml/SAMD_TIAN.yml +15 -0
- data/vendor/board-maps/yaml/SAMD_ZERO.yml +14 -0
- data/vendor/board-maps/yaml/SAM_DUE.yml +26 -0
- data/vendor/board-maps/yaml/SAM_ZERO.yml +15 -0
- data/vendor/board-maps/yaml/SEEED_INDICATOR_RP2040.yml +47 -0
- data/vendor/board-maps/yaml/SEEED_XIAO_RP2040.yml +29 -0
- data/vendor/board-maps/yaml/SOLDERPARTY_RP2040_STAMP.yml +48 -0
- data/vendor/board-maps/yaml/SONOFF_DUALR3.yml +26 -0
- data/vendor/board-maps/yaml/SPARKFUN_PROMICRO_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/SPARKFUN_THINGPLUS_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/STAMP_S3.yml +4 -0
- data/vendor/board-maps/yaml/TAMC_TERMOD_S3.yml +31 -0
- data/vendor/board-maps/yaml/TBEAM_USE_RADIO_SX1262.yml +23 -0
- data/vendor/board-maps/yaml/TBEAM_USE_RADIO_SX1268.yml +23 -0
- data/vendor/board-maps/yaml/TBEAM_USE_RADIO_SX1276.yml +23 -0
- data/vendor/board-maps/yaml/TBEAM_USE_RADIO_SX1278.yml +23 -0
- data/vendor/board-maps/yaml/TBEAM_USE_RADIO_SX1280.yml +23 -0
- data/vendor/board-maps/yaml/TBeam.yml +23 -0
- data/vendor/board-maps/yaml/TINYPICO.yml +26 -0
- data/vendor/board-maps/yaml/TINYS2.yml +33 -0
- data/vendor/board-maps/yaml/TINYS3.yml +25 -0
- data/vendor/board-maps/yaml/TTGO-T-OI-PLUS_DEV.yml +11 -0
- data/vendor/board-maps/yaml/TTGO_LoRa32_V1.yml +28 -0
- data/vendor/board-maps/yaml/TTGO_LoRa32_V2.yml +28 -0
- data/vendor/board-maps/yaml/TTGO_LoRa32_v21new.yml +28 -0
- data/vendor/board-maps/yaml/TTGO_T1.yml +27 -0
- data/vendor/board-maps/yaml/TTGO_T7_V13_Mini32.yml +27 -0
- data/vendor/board-maps/yaml/TTGO_T7_V14_Mini32.yml +27 -0
- data/vendor/board-maps/yaml/TWATCH_2020_V1.yml +10 -0
- data/vendor/board-maps/yaml/TWATCH_2020_V2.yml +10 -0
- data/vendor/board-maps/yaml/TWATCH_2020_V3.yml +10 -0
- data/vendor/board-maps/yaml/TWATCH_BASE.yml +10 -0
- data/vendor/board-maps/yaml/TWatch.yml +10 -0
- data/vendor/board-maps/yaml/Trueverit_ESP32_Universal_IoT_Driver.yml +18 -0
- data/vendor/board-maps/yaml/Trueverit_ESP32_Universal_IoT_Driver_MK_II.yml +18 -0
- data/vendor/board-maps/yaml/UBLOX_NINA_W10.yml +48 -0
- data/vendor/board-maps/yaml/UBLOX_NORA_W10.yml +43 -0
- data/vendor/board-maps/yaml/UPESY_RP2040_DEVKIT.yml +48 -0
- data/vendor/board-maps/yaml/VALTRACK_V4_MFW_ESP32_C3.yml +23 -0
- data/vendor/board-maps/yaml/VALTRACK_V4_VTS_ESP32_C3.yml +23 -0
- data/vendor/board-maps/yaml/VIYALAB_MIZU_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/WATCHY.yml +7 -0
- data/vendor/board-maps/yaml/WATCHY_V10.yml +7 -0
- data/vendor/board-maps/yaml/WATCHY_V15.yml +7 -0
- data/vendor/board-maps/yaml/WATCHY_V20.yml +7 -0
- data/vendor/board-maps/yaml/WAVESHARE_RP2040_LCD_0_96.yml +47 -0
- data/vendor/board-maps/yaml/WAVESHARE_RP2040_LCD_1_28.yml +47 -0
- data/vendor/board-maps/yaml/WAVESHARE_RP2040_ONE.yml +47 -0
- data/vendor/board-maps/yaml/WAVESHARE_RP2040_PLUS.yml +48 -0
- data/vendor/board-maps/yaml/WAVESHARE_RP2040_ZERO.yml +47 -0
- data/vendor/board-maps/yaml/WESP32.yml +17 -0
- data/vendor/board-maps/yaml/WIDORA_AIR.yml +34 -0
- data/vendor/board-maps/yaml/WIFIDUINO_ESP8266.yml +23 -0
- data/vendor/board-maps/yaml/WIFINFO.yml +20 -0
- data/vendor/board-maps/yaml/WIPY3.yml +27 -0
- data/vendor/board-maps/yaml/WIZNET_5100S_EVB_PICO.yml +48 -0
- data/vendor/board-maps/yaml/WIZNET_5500_EVB_PICO.yml +48 -0
- data/vendor/board-maps/yaml/WIZNET_WIZFI360_EVB_PICO.yml +48 -0
- data/vendor/board-maps/yaml/WT32_ETH01.yml +8 -0
- data/vendor/board-maps/yaml/WiFiduino32S3.yml +27 -0
- data/vendor/board-maps/yaml/WiFiduinoV2.yml +27 -0
- data/vendor/board-maps/yaml/Wifiduino32.yml +40 -0
- data/vendor/board-maps/yaml/XIAO_ESP32C3.yml +22 -0
- data/vendor/board-maps/yaml/XIAO_ESP32S3.yml +36 -0
- data/vendor/board-maps/yaml/YD_RP2040.yml +48 -0
- data/vendor/board-maps/yaml/atmegazero_esp32s2.yml +30 -0
- data/vendor/board-maps/yaml/connaxio_espoir.yml +18 -0
- data/vendor/board-maps/yaml/esp32vn_iot_uno.yml +22 -0
- data/vendor/board-maps/yaml/fm_devkit.yml +15 -0
- data/vendor/board-maps/yaml/heltec_wifi_32_lora_V3.yml +31 -0
- data/vendor/board-maps/yaml/heltec_wifi_kit_32.yml +28 -0
- data/vendor/board-maps/yaml/heltec_wifi_kit_32_V3.yml +32 -0
- data/vendor/board-maps/yaml/heltec_wifi_lora_32.yml +27 -0
- data/vendor/board-maps/yaml/heltec_wifi_lora_32_V2.yml +27 -0
- data/vendor/board-maps/yaml/heltec_wireless_stick.yml +27 -0
- data/vendor/board-maps/yaml/heltec_wireless_stick_LITE.yml +27 -0
- data/vendor/board-maps/yaml/openkb.yml +27 -0
- data/vendor/board-maps/yaml/roboheart_hercules.yml +17 -0
- data/vendor/board-maps/yaml/sensesiot_weizen.yml +26 -0
- data/vendor/board-maps/yaml/uPesy_WROOM.yml +27 -0
- data/vendor/board-maps/yaml/uPesy_WROVER.yml +27 -0
- data/vendor/board-maps/yaml/unphone8.yml +32 -0
- data/vendor/board-maps/yaml/unphone9.yml +32 -0
- data/vendor/board-maps/yaml/wifi_kit_8.yml +15 -0
- metadata +800 -0
data/CHANGELOG.md
ADDED
@@ -0,0 +1,466 @@
|
|
1
|
+
# Changelog
|
2
|
+
|
3
|
+
## 0.13.0
|
4
|
+
|
5
|
+
### New Features
|
6
|
+
|
7
|
+
- `Board#map`
|
8
|
+
- Returns a hash mapping named pins (taken from the Arduino framework) to their integer GPIO values, once the board is supported. Examples: `:A0`, `:DAC0`, `:MOSI`, `:LED_BUILTIN`.
|
9
|
+
- Pins can be given as symbols when creating peripherals. The `Board` instance converts them to integer using `Board#convert_pin`.
|
10
|
+
- This works by having the board send an identifier string (again taken from the Arduino framework) during handshake. The identifier is cross-referenced against a directory of YAML files, loading the right map for each board.
|
11
|
+
- This uses [`arduino-yaml-board-maps`](https://github.com/denko-rb/arduino-yaml-board-maps). See that repo for which Arduino cores / boards are supported.
|
12
|
+
|
13
|
+
### New Boards
|
14
|
+
|
15
|
+
- ESP32-S2, ESP32-S3 and ESP32-C3 variants (`--target esp32`):
|
16
|
+
- Newer versions of the ESP32 chip with native USB support.
|
17
|
+
- No DACs on the S3.
|
18
|
+
- No DACs or capacitive touch on the C3.
|
19
|
+
|
20
|
+
- SAMD21 Boards, Arduino Zero (`--target samd`):
|
21
|
+
|
22
|
+
- RP2040 Based Boards, Raspberry Pi Pico (W) (`--target rp2040`):
|
23
|
+
- WS2812 LED arrays don't work.
|
24
|
+
|
25
|
+
- Raspberry Pi SBC (not Pico) built-in GPIO support, using [`denko-piboard`](https://github.com/denko-rb/denko-piboard) extension gem:
|
26
|
+
- Ruby needs to be running on the Pi itself.
|
27
|
+
- Only works with CRuby. No JRuby or TruffleRuby.
|
28
|
+
- Folllow install instructions from `denko-piboard` gem's readme.
|
29
|
+
- `require "denko/piboard"` instead of `require "denko"`
|
30
|
+
- Substitute `Denko::PiBoard` for `Denko::Board` as board class.
|
31
|
+
- Not all interfaces and components from `denko` are supported yet.
|
32
|
+
|
33
|
+
### New Components
|
34
|
+
|
35
|
+
- Hardware UART support:
|
36
|
+
- Class: `Denko::UART::Hardware`.
|
37
|
+
- Read/write support for a board's open (not tied to a USB port) hardware UARTs. Allows interfacing with serial peripherals.
|
38
|
+
- Initialize giving `:index` as the UART's number, according to the Arduino IDE/pinout. `Serial1` has index `1`. `Serial2` has index `2`, and so on.
|
39
|
+
- `:baud` argument can be given when initializing, or call `UART::Hardware#start(YOUR_BAUD_RATE)`. Default is 9600.
|
40
|
+
- No pin arguments are needed to start the UART, but peripherals must be connected properly. Refer to your board's pinout.
|
41
|
+
- UARTs 1..3 are supported, and map to "virtual pins" 251..253, for purposes of identifying bytes read from the board.
|
42
|
+
- The 0th UART (`Serial`) is never used, even on boards where it is not in use, and `SerialUSB` is the Denko transport.
|
43
|
+
- `UART::Hardware#write` accepts either a String or Array of bytes to send binary data.
|
44
|
+
- The `UART::Hardware` instance itself buffers read bytes. Complete lines can be read with `UART::Hardware#gets`.
|
45
|
+
- Callbacks can be attached, like other input classes, to handle each batch of raw bytes as they arrive.
|
46
|
+
- Call `UART::Hardware#stop` to disable the UART and return the pins to regular GPIO.
|
47
|
+
- Added `Denko::Connection::BoardUART`, allowing a board's UART to be the transport for another `Board` instance. See [this example](examples/uart/board_passthrough.rb).
|
48
|
+
|
49
|
+
- ADS1118 Analog-to-Digital Converter:
|
50
|
+
- Class: `Denko::AnalogIO::ADS1118`.
|
51
|
+
- Connects via SPI bus. Driver written in Ruby.
|
52
|
+
- Can be used directly by calling `ADS1118#read` with the 2 config register bytes.
|
53
|
+
- `#read` automatically waits for conversion before reading result.
|
54
|
+
- Implements `BoardProxy` interface, so `AnalogIO::Input` can use it in place of `Board`.
|
55
|
+
- For each `AnalogIO::Input` subcomponent:
|
56
|
+
- Negative pin (1 or 3) of differential pair can be set with the keyword argument `negative_pin:`
|
57
|
+
- Gain can be set with the keyword argument `gain:`
|
58
|
+
- Sample rate can be set with the keyword argument `sample_rate:`
|
59
|
+
- Sample rate doesn't affect update rate. Higher sample rates oversample for a single reading, increasing resolution.
|
60
|
+
- `ADS1118` sets `@volts_per_bit` in the subcomponent, so exact voltages can be calculated.
|
61
|
+
- There is no listening interface for subcomponents.
|
62
|
+
- Built in temperature sensor can be read with `ADS1118#temperature_read`. Only 128 SPS. No polling.
|
63
|
+
|
64
|
+
- Bosch BME/BMP 280 Temperature + Pressure + Humidity Sensor:
|
65
|
+
- Classes: `Denko::Sensor::BME280` and `Denko::Sensor::BMP280`
|
66
|
+
- Connects via I2C bus. Driver written in Ruby.
|
67
|
+
- All features in the datasheet are implemented, except status checking.
|
68
|
+
- Both are mostly identical, except for BMP280 lacking humidity.
|
69
|
+
|
70
|
+
- HTU21D Temperature + Humidity Sensor:
|
71
|
+
- Class: `Denko::Sensor::HTU21D`
|
72
|
+
- Connects via I2C bus. Driver written in Ruby.
|
73
|
+
- Most features implemented, except reading back the configuration register, and releasing the I2C bus during measurement. Since conversion times can vary, it's simpler to let the sensor hold the line until its data is ready to be read.
|
74
|
+
- Always uses CRC. Readings are silently ignored if CRC fails.
|
75
|
+
- Can be read with direct methods `HTU21D#read_temperature` and `HTU21D#read_humidity`, but these do not accept block callbacks, and there is no polling.
|
76
|
+
- For callbacks and polling, use the sub-objects accessible through `HTU21D#temperature` and `HTU21D#humidity`. See examples for more info.
|
77
|
+
|
78
|
+
- HTU31D Temperature + Humidity Sensor:
|
79
|
+
- Class: `Denko::Sensor::HTU31D`
|
80
|
+
- Connects via I2C bus. Driver written in Ruby.
|
81
|
+
- Similar to HTU21D, but temperature and humidity can be, and always are, read together.
|
82
|
+
- Always uses CRC. Readings are silently ignored if CRC fails.
|
83
|
+
- Diagnostic register reading not implemented yet.
|
84
|
+
|
85
|
+
- AHT10 / AHT15 Temperature + Humidity Sensors:
|
86
|
+
- Both share a compatible interface, and use the same class: `Denko::Sensor::AHT10`
|
87
|
+
- Connects via I2C bus. Driver written in Ruby.
|
88
|
+
- Always uses calibrated mode.
|
89
|
+
|
90
|
+
- AHT20 / AHT21 / AHT25 / AM2301B Temperature + Humidity Sensors:
|
91
|
+
- All share a compatible interface, and use the same class: `Denko::Sensor::AHT20`
|
92
|
+
- Connects via I2C bus. Driver written in Ruby.
|
93
|
+
- Always uses calibrated mode.
|
94
|
+
- Always uses CRC. Readings are silently ignored if CRC fails.
|
95
|
+
|
96
|
+
- SSD1306 OLED Display:
|
97
|
+
- Class: `Denko::Display::SSD1306`
|
98
|
+
- Connects via I2C bus. Driver written in Ruby.
|
99
|
+
- By default, `SSD1306#draw` refreshes the entire frame, using horizontal addressing mode.
|
100
|
+
- Can do partial refreshes with `SSD1306#draw(x_min, x_max, y_min, y_max)`, defining a bounding box to redraw.
|
101
|
+
- One 6x8 font and graphic primitves, included through `Denko::Display::Canvas`.
|
102
|
+
|
103
|
+
- L298 H-Bridge Motor Driver:
|
104
|
+
- Class: `Denko::Motor::L298`
|
105
|
+
- Forward, reverse, idle, and brake modes implemented.
|
106
|
+
- Speed controlled by PWM output on enable pin.
|
107
|
+
|
108
|
+
- WS2812 / WS2812B / NeoPixel RGB LED Array:
|
109
|
+
- Class: `Denko::LED::WS2812`
|
110
|
+
- No fancy functions yet. Just clear, set pixels, and show.
|
111
|
+
|
112
|
+
- APA102 / Dotstar RGB LED Array:
|
113
|
+
- Class: `Denko::LED::APA102`
|
114
|
+
- No fancy functions yet. Just clear, set pixels, show, global and per-pixel brightness control.
|
115
|
+
- Needs its own dedicated SPI bus. Select pin is automatically set to 255 (no pin).
|
116
|
+
|
117
|
+
See new examples in the [examples](examples) folder to learn more.
|
118
|
+
|
119
|
+
### Changed Components
|
120
|
+
|
121
|
+
- Virtually every component has been renamed to bring them out of the `Denko::Components` namespace, make naming clearer.
|
122
|
+
- TODO: Update here with a list of renamed components.
|
123
|
+
|
124
|
+
- SPI peripherals now go through a `Denko::SPI::Bus` object:
|
125
|
+
- Instead of giving a board directly when creating a new SPI peripheral, a bus must be created first:
|
126
|
+
```ruby
|
127
|
+
board = Denko::Board.new(connection)
|
128
|
+
bus = Denko::SPI::Bus.new(board: board) # board's default SPI interface
|
129
|
+
output_register = Denko::SPI::OutputRegister.new(bus: bus, pin: 9) # 9 is register select pin
|
130
|
+
input_register = Denko::SPI::InputRegister.new(bus: bus, pin: 10) # 10 is register select pin
|
131
|
+
```
|
132
|
+
- For now, this always uses the default SPI device set by the Arduino framework (`SPI` or `SPI0`), but this change will allow access to multiple SPI interfaces on a single board in the future.
|
133
|
+
- It also allows a peripheral to mutex lock the bus for atomic operations if needed.
|
134
|
+
- When a peripheral is added to the SPI bus, callbacks are hooked (using its select pin as identifier) directly to the board.
|
135
|
+
- `SPI::Bus` validates select pin uniquness among peripherals, per bus instance.
|
136
|
+
- `SPI::Bus` treats a select (enable) pin of 255 as no select pin at all (won't toggle before and after transferring).
|
137
|
+
- See the updated [SPI examples](examples/spi) to learn more.
|
138
|
+
|
139
|
+
- Shift In/Out features refactored into `SPI::BitBang` which is class-compatible with `SPI::Bus`, except for frequency.
|
140
|
+
- See SPI changes above.
|
141
|
+
|
142
|
+
- `SPI::Peripheral` has been extracted from the various SPI Register classes.
|
143
|
+
- This should be used for most peripherals, and the register classes used only for simple I/O expansion registers.
|
144
|
+
|
145
|
+
- `I2C::Bus` does not automatically search when initialized.
|
146
|
+
|
147
|
+
- I2C frequency now configurable:
|
148
|
+
- `I2C::Peripheral` and it's subclasses take `:i2c_frequency` keywoard arg when instantiating. It's stored in `@i2c_frequency` and used for all reads and writes.
|
149
|
+
- `Board#i2c_write` and `Board#i2c_read` also accept `:i2c_frequency` as a keyword arg.
|
150
|
+
- Valid values are: `100000, 400000, 1000000, 3400000`. Defaults to `100000` at the `Board` level, when not given.
|
151
|
+
- **Note:** This DOES NOT work if using `denko-piboard`. See the README on that gem for more info.
|
152
|
+
|
153
|
+
- Hitachi HD44780 LCD driver rewritten in Ruby:
|
154
|
+
- New class: `Denko::Display::HD44780`
|
155
|
+
- `#puts` changed to `#print` to better represent functionality.
|
156
|
+
- No longer depends on the `LiquidCrystal` Arduino library, which has been removed.
|
157
|
+
- Depends only on `Denko::DigitalIO::Output` and `#micro_delay`.
|
158
|
+
- Old implementation in `Denko::Components::LCD` removed.
|
159
|
+
- This solves compatibility with boards that the library didn't work on.
|
160
|
+
- `HD44780#create_char` allows 8 custom characters to be defined in memory addresses 0-7.
|
161
|
+
- `HD44780#write` draws the custom (or standard) character from a given memory address.
|
162
|
+
|
163
|
+
- `Denko::PulseIO::PWMOutput` (previously `Denko::Components::Basic::AnalogOutput`):
|
164
|
+
- Changed `#analog_write` to `#pwm_write`.
|
165
|
+
- Added `#pwm_enable` and `#pwm_disable` methods.
|
166
|
+
- `#pwm_enable` is implicit when calling `#pwm_write`. Lazy initialize PWM peripherals on the chip. Never happens if only `#digital_write` gets called.
|
167
|
+
- `#pwm_disable` sets the pin mode to `:output` (`OUTPUT` in Arduino), disconnects and deconfigures any PWM generating peripheral.
|
168
|
+
- On the ESP32 `#pwm_disable` releases the LEDC channel that the pin was using, so it can be reused.
|
169
|
+
|
170
|
+
- `Denko::AnalogIO::Output` (also previously `Denko::Components::Basic::AnalogOutput`):
|
171
|
+
- Changed `#analog_write` to `#dac_write`.
|
172
|
+
- Does not implement `#digital_write` at all. Analog values must be used instead of `board.high` or `board.low`.
|
173
|
+
|
174
|
+
- `Denko::UART::BitBang` (previously `Denko::Components::SoftwareSerial`):
|
175
|
+
- Only inclduedo on AVR boards. Cross-platform support isn't good, and isn't necessary since almost everything has extra hardware UARTs.
|
176
|
+
- Read functionality added. The board listens for incoming bytes and forwards them.
|
177
|
+
- Interface matches `Denko::UART::Hardware` except for :tx and :rx pins given when initializing. See that entry in New Components above for more info.
|
178
|
+
|
179
|
+
- `Denko::TxRx` moved to `Denko::Connection`.
|
180
|
+
|
181
|
+
### Board API Changes
|
182
|
+
|
183
|
+
- `microDelay` function exposed from the board:
|
184
|
+
- Implements a platform independent microsecond delay.
|
185
|
+
- All calls to `delayMicroseconds()` should be replaced with this.
|
186
|
+
- Exposed in Ruby via `CMD=99`. It takes one argument, uint_16 for delay length in microsceonds.
|
187
|
+
- `Board#micro_delay` and `Component::#micro_delay` are defined.
|
188
|
+
|
189
|
+
- `dacWrite` function added to board library. `aWrite` function renamed to `pwmWrite`. Need this to avoid conflict between DAC, PWM and regular output on some chips.
|
190
|
+
|
191
|
+
- CMD numbers for some board functions changed to accomodate dacWrite:
|
192
|
+
````
|
193
|
+
dacWrite -> 4
|
194
|
+
aread 4 -> 5
|
195
|
+
setListener 5 -> 6
|
196
|
+
eepromRead 6 -> 7
|
197
|
+
eepromWrite 7 -> 8
|
198
|
+
pulseread 11 -> 9
|
199
|
+
servoToggle 8 -> 10
|
200
|
+
servoWrite 9 -> 11
|
201
|
+
````
|
202
|
+
|
203
|
+
- `Board#analog_write` replaced by `Board#pwm_write` and `Board#dac_write`, matching the two C functions.
|
204
|
+
|
205
|
+
- `Board#set_pin_mode` significantly changed to better manage pullups, pulldowns, `:input_output` mode, and freeing DAC and PWM peripherals for relevant chips.
|
206
|
+
|
207
|
+
- `Board#digital_write` implicitly disconnects a PWM or DAC peripheral from the pin, but does not free it. This is necessary on chips like the ATSAMD21 and ESP32 or the `#digital_write` will not work.
|
208
|
+
|
209
|
+
- `Board#analog_write` implicitly reconnects a PWM peripheral to the pin if one was previously assigned, or assigns a new one and connects it.
|
210
|
+
|
211
|
+
- `Board#analog_resolution` has been split into `Board#analog_write_resolution` and `Board#analog_read_resoluton`, defaulting to 8 and 10-bits respectively. Write resolution applies to both PWM and DACs.
|
212
|
+
|
213
|
+
- `Board#pwm_high`, `Board#dac_high` and `Board#adc_high` defined for convenience.
|
214
|
+
|
215
|
+
- I2C and SPI transfer methods on `Board` changed to avoid using the options Hash pattern. I2C uses only positional arguments, and SPI uses positional and keyword arguments. This gives a significant performance boost on lower end processors like the Raspberry Pi Zero, and reduces CPU usage in general.
|
216
|
+
|
217
|
+
- `Board#i2c_read` and `Board#i2c_write` now only accept positional arguments, with frequency and repeated_start always being last, in that order, and optional.
|
218
|
+
|
219
|
+
- `Board#spi_transfer` and `Board#spi_bb_transfer` now only accept `:spi_mode` and `:spi_frequency` keywords for the respective arguments.
|
220
|
+
|
221
|
+
- `Board#spi_listen` and `Board#spi_bb_listen` now share the same listener storage on the board. Default is 4 listeners. `shiftListeners` have been removed.
|
222
|
+
|
223
|
+
### Minor Changes
|
224
|
+
|
225
|
+
- When instantiating a component, `Board#convert_pin` is run immediately, then the converted integer for the pin (based on the board map), is saved in `@pin`, instead of whatever form was given to `#initialize`. After this, the integer is always used as-is for sending / receiving messages. This reduces CPU usage, since `Board#convert_pin` doesn't need to be called for every message.
|
226
|
+
|
227
|
+
- As a consequence of the above change, when `Board` methods are called directly, pins must always be given as integers.
|
228
|
+
|
229
|
+
- `Poller#poll` no longer defaults to a 3 second interval and will raise an error if a numeric interval is not given.
|
230
|
+
|
231
|
+
- `MultiPin` validation and proxying has changed to not use class methods. Everything is done inside `#initialize_pins` per-instance instead. This reduces the amount of `eval` and `rescue` going on, so it's easier to understand, and changes are more portable to mruby.
|
232
|
+
|
233
|
+
- Calling `#update` with `nil`, on any object using the `Callback` pattern, will prevent callbacks from being run, but still remove any one-time callbacks present in the `:read` key.
|
234
|
+
|
235
|
+
- If `#pre_callback_filter` returns nil, callbacks will also not be run, behaving just as above.
|
236
|
+
|
237
|
+
- Added [this example](examples/ws2812/ws2812_builtin_blink.rb) as a blink example for boards where :LED_BUILTIN maps to a single on-board WS2812 LED, instead of a regular LED.
|
238
|
+
|
239
|
+
- Removed `Denko::Board::ESP8266`, in favor of the new board mapping functionality. See New Features above.
|
240
|
+
|
241
|
+
- Aux message size limits changed to:
|
242
|
+
- 512 + 16: When using IR output or WS2812 and not using ATmega168
|
243
|
+
- 256 + 16: When not using IR output or WS2812, any board
|
244
|
+
- 32 + 16: When all the features that use lots of aux are disabled (core sketch)
|
245
|
+
|
246
|
+
- `Denko::Connection::Serial` tries to read up to 64 bytes each time now instead of 1, reducing the number of FFI calls, and CPU usage.
|
247
|
+
|
248
|
+
- `Denko::Connection::FlowControl` simplified to always wait 1ms if no bytes to read or write. This also reduces CPU usage. This might affect the time precision of values received from listeners, but they weren't guaranteed to be evenly spaced anyway. Will add a timestamped listener feature in the future if needed.
|
249
|
+
|
250
|
+
- All `Serial.print` style debugging removed from the Arduino sketch, in favor of the new debugger in the Arduino IDE. If this style of debugging is still needed, the sketch should emit lines beginning with "DBG:". These will be caught by the Ruby parser and printed to the terminal.
|
251
|
+
|
252
|
+
- Started using `simplecov` gem to track test coverage.
|
253
|
+
|
254
|
+
### Bug Fixes
|
255
|
+
|
256
|
+
- Fixed `Denko::DigitalIO::Output` not setting its state through its mutex.
|
257
|
+
|
258
|
+
- Fixed `Piezo` functionality. Frequency and duration values weren't being properly cast on the board. Duration is also limited to 16 bits now, instead of 32, as it should be to match the Arduino function.
|
259
|
+
|
260
|
+
- Added validation for I2C writes not exceeding 32 bytes, since this is a limit of the native (AVR) library buffer. May increase for boards with bigger buffers in the future.
|
261
|
+
|
262
|
+
- Stricter regex validation in `I2C::Bus` for identifying a series of bytes coming from a specific I2C address.
|
263
|
+
|
264
|
+
- `I2C::Bus` and `OneWire::Bus` now validate peripheral addresses as unique, per bus instance.
|
265
|
+
|
266
|
+
## 0.12.0
|
267
|
+
|
268
|
+
### New Boards
|
269
|
+
- The `denko sketch` shell command now accepts a `--target` argument. It includes/excludes features to tailor the sketch for different boards/chips. Run `denko targets` for more info.
|
270
|
+
|
271
|
+
- ATmega Based Boards (default) (`--target mega`):
|
272
|
+
- This is the default sketch if `--target` isn't specified, and works for Arduino (and other) products based on the ATmega AVR chips, like the Uno, Nano, Leonardo and Mega.
|
273
|
+
|
274
|
+
- ESP8266 (`--target esp8266`):
|
275
|
+
- Works with either built in WiFi or Serial.
|
276
|
+
- WiFi version supports OTA (over-the-air) update in the Arduino IDE. Initial flash must still be done via serial.
|
277
|
+
- Dev boards can map GPIOs to physical pins differently. Always look up the GPIO numbers and use those for pin numbers.
|
278
|
+
- **Note:** SoftwareSerial and LiquidCrystal (LCD) both do not work on the ESP8266, and are excluded from the sketch.
|
279
|
+
|
280
|
+
- ESP32 (`--target esp32`):
|
281
|
+
- Works with either built in WiFi or Serial.
|
282
|
+
- WiFi version does NOT support OTA (over-the-air) updates yet.
|
283
|
+
- Only tested with the original ESP32 module so far, not the later revisions with slightly different hardware.
|
284
|
+
- Dev boards can map GPIOs to physical pins differently. Always look up the GPIO numbers and use those for pin numbers.
|
285
|
+
- **Note:** Servos and analog outputs share the `LEDC` channels on the board. Maximum of 16 combined.
|
286
|
+
- **Note:** SoftwareSerial and LiquidCrystal (LCD) both do not work on the ESP32, and are excluded from the sketch.
|
287
|
+
- **Note:** SPI bug exists where input modes don't match other platforms. Eg. For a register using mode 0 on AVR, mode 2 needs to be set on ESP32 for it to work. Using mode 0 misses a bit.
|
288
|
+
|
289
|
+
- Arduino Due (`--target sam3x`) :
|
290
|
+
- Up to 12-bit analog in/out. Pass a `bits:` option to `Board#new` to set resolution for both.
|
291
|
+
- DAC support. Refer to DAC pins as `'DAC0'`, `'DAC1'`, just as labeled on the board. Call `#analog_write` or just `#write` on an `sensor` component that uses the pin.
|
292
|
+
- Uses the native ARM serial port by default. Configurable in sketch to use programming port.
|
293
|
+
- **Note**: SoftwareSerial, Infrared, and Tone are incompatible with the Arduino Due, and excluded from the sketch.
|
294
|
+
|
295
|
+
- ATmega168 (`--target mega168`):
|
296
|
+
- By excluding a lot of features, we can still fit the memory constraints of the ATmega168 chips found in older Arduinos.
|
297
|
+
- SoftwareSerial, LCD, OneWire and IROut are compatible, but left out to keep memory usage down.
|
298
|
+
- Included libraries can be toggled in `DenkoDefines.h` to suit your needs.
|
299
|
+
- **Note:** Aux message is limited to 264 bytes on the mega168, or less depending on included libraries. The only feature currently affected by this is sending long infrared signals, like for an air conditioner.
|
300
|
+
|
301
|
+
### New Components
|
302
|
+
|
303
|
+
- `TxRx::TCP` allows communication with the board over an IP network, instead of serial connection. Tested on Arduino Uno Ethernet Shield (Wiznet W5100), and ESP8266 native WiFi. Should work on Uno WiFi shield, but is **untested**. WiFi must be configured before flashing. Instad of `denko sketch serial`, use `denko sketch wifi`.
|
304
|
+
|
305
|
+
- Hitachi HD44780 LCD support. _Uses Arduino `LiquidCrystal` library._
|
306
|
+
|
307
|
+
- Seven Segment Display support. _Ruby implementation as multiple LEDs._
|
308
|
+
|
309
|
+
- Infrared Emitter support. _Uses [Arduino-IRremote](https://github.com/z3t0/Arduino-IRremote), and the [ESP8266 fork](https://github.com/markszabo/IRremoteESP8266) where applicable._
|
310
|
+
|
311
|
+
- Tone (piezo) support. _Uses Arduino `tone`,`noTone` functions._
|
312
|
+
|
313
|
+
- SoftwareSerial **(write only)**. _Uses Arduino `SoftSerial` library. Only tested on ATmega chips._
|
314
|
+
|
315
|
+
- Potentiometer class, based on AnalogInput, but enables moving average smoothing by default, and adds #on_change callback method.
|
316
|
+
|
317
|
+
- Rotary encoder support. _Polls @ 1ms interval._ **WARNING**: Not suitable for high speed or precise position needs. It will definitely miss steps. Sufficient for rotary knobs as user input.
|
318
|
+
|
319
|
+
- DHT11 / DHT 21 (AM2301) / DHT22 temperature and relative humidity sensor support. _Custom implementation where input pulses are measured on the board, then decoded in Ruby._
|
320
|
+
|
321
|
+
- DS3231 RTC (real time clock) over I2C _(Ruby implementation)_
|
322
|
+
|
323
|
+
- DS18B20 temperature sensor. _Uses custom implementation of Dallas/Maxim 1-Wire bus below._
|
324
|
+
|
325
|
+
- Dallas/Maxim 1-Wire bus support. _Low level timing functions run on the board. High level logic in Ruby._
|
326
|
+
- Most bus features are implemented: reset/presence detect, parasite power handling, bus search and slave device identification, CRC. No overdrive support.
|
327
|
+
- Based on [Kevin Darrah's video](https://www.youtube.com/watch?v=ZKNQhzPwH0s) explaining the DS18B20 datasheet.
|
328
|
+
|
329
|
+
- I2C bus support. _Uses Arduino `Wire` library._
|
330
|
+
|
331
|
+
- Shift Register support. _Uses Arduino `ShiftOut` and `ShiftIn` functions._
|
332
|
+
|
333
|
+
- SPI bus support (_uses Arduino `SPI` library_) :
|
334
|
+
- Read/Write Transfers
|
335
|
+
- Read-Only Listeners (like digital/analog listeners, but reads n bytes from MISO)
|
336
|
+
|
337
|
+
- Generic input and output register classes for the above 2: `Register::ShiftIn`, `Register::ShiftOut`, `Register::SPIIn`, `Register::SPIOut`.
|
338
|
+
|
339
|
+
- Board EEPROM support. _Uses Arduino `EEPROM` library._
|
340
|
+
|
341
|
+
### Changed Components
|
342
|
+
- Servos can now be connected to arbitrary pins as long as they are supported by the board.
|
343
|
+
|
344
|
+
- Digital and analog listeners now have dividers on a per-pin basis.
|
345
|
+
- Timing is based on a 1000 microsecond tick being counted by the board.
|
346
|
+
- Call `#listen` with a value as the first argument. Eg. `analog_sensor.listen(64)` will tell the board to send us that specific sensor's state every 64 ticks (~64ms) or around 16 times per second, without affecting other components' rates.
|
347
|
+
- Valid dividers are: `1, 2, 4, 8, 16, 32, 64, 128`.
|
348
|
+
- Defaults are same as before: `4` for digital, `16` for analog.
|
349
|
+
|
350
|
+
### Hardware Abstraction
|
351
|
+
|
352
|
+
- `MultiPin` abstraction for components using more than one pin:
|
353
|
+
- Components connecting to more than 1 pin, like an RGB LED or rotary encoder, are now modeled as `MultiPin` and contain multiple `SinglePin` `proxies`. An `RGBLed` is built from 3 `sensor`s, for example, one for each color, connected to a separate pin.
|
354
|
+
- `MultiPin` implements a shortcut class method `proxy_pins`. Proxying a pin allows subcomponent pin numbers to be given as a hash when initializing an instance of a `MultiPin` component. Eg: `{red: 9, green: 10, blue: 11}` given as the `pins:` option for `RGBLed#new`.
|
355
|
+
- When initialized, subcomponents corresponding to the proxied pins are automatically created. They're stored in `#proxies` and `attr_reader` methods are created for each, corresponding to their key in the `pins:` hash. Eg: `RGBLed#green` and `RGBLed#proxies[:green]` both give the `sensor` component that represents the green LED inside the RGB LED, connected to pin 10.
|
356
|
+
|
357
|
+
- `BoardProxy` abstraction for shift/SPI registers:
|
358
|
+
- The `Register` classes implement enough of the `Board` interface to satisfy components based on `DigitalInput` and `DigitalOutput`, such as `Led` or `Button`.
|
359
|
+
- This lets you call methods on components directly, rather than manipulating the register data to control components indirectly.
|
360
|
+
- Initialize the appropriate `Register` object for the type of register. To initialize a component connected to the register, use the register as the `board:`, and give the parallel I/O pin on the register that the component is connected to. Pin 0 maps to the lowest bit.
|
361
|
+
- This also works for `MultiPin` components built out of only `DigitalInput` or `DigitalOutput`, eg. `SSD` - seven segment display or `RGBLed`. See `examples/register` for more.
|
362
|
+
|
363
|
+
### Input Components, Callbacks and State
|
364
|
+
- `@value` has been renamed to `@state`.
|
365
|
+
- By default, all components define `#state` and `#state=`, which access `@state` through `@state_mutex`. This way we don't try to read with `#state` while a callback is updating it with `#state=`.
|
366
|
+
- `@state` can be any Ruby object representing the state of the component.
|
367
|
+
|
368
|
+
- Callback functionality for components has been extracted into a mixin module, `Mixins::Callbacks`.
|
369
|
+
- Like before, callbacks for all components on a board run sequentially, in a single "update" thread, separate from the main thread. This is the same thread reading from TxRx.
|
370
|
+
- `#add_callback` and `#remove_callback` methods are available, and take an optional `key` as argument.
|
371
|
+
- Blocks given to `#add_callback` are stored in `@callbacks[key]`, to be called later, when the "update" thread receives data for the component. The default key is `:persistent`.
|
372
|
+
- Each key represents an array of callbacks, so multiple callbacks can share the same key.
|
373
|
+
- Calling `#remove_callbacks` with a key empties that array. Calling with no key removes **all** callbacks for the component.
|
374
|
+
- `#pre_callback_filter` is defined in the `Callbacks` module. The return value of this method is what is given to the component's callbacks and to update its `@state`. By default, it returns whatever was given from the board.
|
375
|
+
- Override `#pre_callback_filter` to process data before giving it to callbacks and `@state`. Eg: given raw bytes from a DHT sensor, process them into a hash containing `:celsius`, `: fahrenheit` and `:humidity` values. That hash is given to to callbacks and `#update_state` instead of the original string of raw bytes.
|
376
|
+
- `#update_state` is defined in the `Callbacks` module. It is called after all callbacks are run and given the return value of `#pre_callback_filter`. By default, it sets `@state=` to the value given.
|
377
|
+
- Override it if updating `@state` is more complex than this, but be sure to either use `#state=` only once, or wrap the operation in `@state_mutex.synchronize`.
|
378
|
+
|
379
|
+
- Input components no longer automatically start listening when created, since there are more options for reading inputs.
|
380
|
+
- `DigitalInput` and its subclasses are the exception to this. They automatically listen, since there is little advantage to other modes.
|
381
|
+
|
382
|
+
- Input components can have any combination of `#read`, `#poll` and `#listen` methods now, coming from `Reader`, `Poller`, and `Listener` respectively, inside `Mixins`.
|
383
|
+
- `#read` sends a single read command by calling `#_read`, and blocks the main thread, until `data` is received from `#pre_callback_filter`. When received, any block that was given to `#read` will run once as a callback and be removed immediately. `#read` then stops blocking the main thread and returns `data`.
|
384
|
+
- `#poll` requires an interval (in seconds) as its first argument. It starts a new thread, and keeps calling `#_read` in it, at the given interval. `#poll` does not block the main thread, and does not return a value. A block given will be added as a callback inside the `:poll` key.
|
385
|
+
- `#listen` adds its block as a callback inside the `:listen` key, calls `#_listen` and returns immediately.
|
386
|
+
- `#stop` stops polling **and** listening. It also **removes all callbacks** in the **`:poll` and `:listen` keys** (callbacks added as blocks when polling or listening).
|
387
|
+
|
388
|
+
### Minor Changes
|
389
|
+
- Serial communication now uses the [`rubyserial`](https://github.com/hybridgroup/rubyserial) gem instead of [`serialport`](https://github.com/hparra/ruby-serialport).
|
390
|
+
- Switched from `rspec` to `minitest` for testing.
|
391
|
+
- Added more useful information and errors during the connect & handshake process.
|
392
|
+
- Extended message syntax so the Arduino can receive arbitrary length messages, including binary.
|
393
|
+
- Created `Denko::Message` class to handle message construction.
|
394
|
+
- Moved CLI into it's own class, `Denko::CLI`.
|
395
|
+
- Added simple flow control to avoid overrunning the 64 byte input buffer in the Arduino `Serial` library. No flow control for Ruby receiving data.
|
396
|
+
|
397
|
+
## 0.11.3
|
398
|
+
* Backport bug fixes from 0.12:
|
399
|
+
* Listeners weren't working properly on the Arduino MEGA.
|
400
|
+
* More reliable handshake.
|
401
|
+
|
402
|
+
## 0.11.2
|
403
|
+
|
404
|
+
* Make servos work better by using the existing Arduino Servo library.
|
405
|
+
* Up to 12 servos can be controlled.
|
406
|
+
* On MEGA boards, servos may be used on pins 22-33 ONLY.
|
407
|
+
* On other boards, servos may be used on pins 2-13 ONLY.
|
408
|
+
* Flashing the updated sketch to the board is required.
|
409
|
+
|
410
|
+
## 0.11.1
|
411
|
+
|
412
|
+
### New Features
|
413
|
+
|
414
|
+
* Support for the Arduino Ethernet shield and compatibles (Wiznet W5100 chipset).
|
415
|
+
|
416
|
+
* Added a `denko` command-line tool for generating and customizing the different Arduino sketches.
|
417
|
+
|
418
|
+
* Instead of reading the value of a pin by repeatedly sending messages to ask for its value, we can now set up "listeners". We tell the board which pin we'd like to listen to, and it will periodically send us the pin's value.
|
419
|
+
* By default, digital listeners are polled every ~4ms (~250Hz).
|
420
|
+
* Analog listeners are on a 4x divider, so they update every ~16ms (~63Hz).
|
421
|
+
* These can be changed with the `Board#heart_rate=` and `Board#analog_divider=` methods respectively.
|
422
|
+
* Digital listeners only send a message if the value has changed since the last check.
|
423
|
+
* Analog listeners always send a message.
|
424
|
+
* Digital listeners can be set up on any pin, including analog pins. Analog listeners should only be set up on analog pins.
|
425
|
+
|
426
|
+
* Registering a listener is now the default for read components such as `Sensor` and `Button`. No changes need to be made for existing or future components. Anything using `Board#add_analog_hardware` or `Board#add_digital_hardware` will set up a listener.
|
427
|
+
|
428
|
+
__NOTE__: Because of these changes, you'll need to upload the newest version of the sketch to your board for this version of the gem to work properly.
|
429
|
+
|
430
|
+
* Support for all 70 pins on the Arduino Mega boards.
|
431
|
+
|
432
|
+
* Built-in pullup resistors on the Arduino are now configurable in Ruby. Disabled by default.
|
433
|
+
|
434
|
+
* Support up to COM9 on Windows.
|
435
|
+
|
436
|
+
* Connect to a specific serial device by setting `device:` in the options hash when calling `Denko::TxRx::Serial.new`.
|
437
|
+
|
438
|
+
* Baud rate for serial connections is now configurable. Use the `--baud XXXXXX` option for `denko` to set the rate before uploading the sketch. Set `baud: XXXXXX` in the options hash for Denko::TxRx::Serial.new` to set the rate when connecting. Both values need to match.
|
439
|
+
|
440
|
+
* Added color methods to `RgbLed` for cyan, yellow, magenta, white and off.
|
441
|
+
|
442
|
+
### Major Changes
|
443
|
+
|
444
|
+
* All Arduino code that interacts with components has been extracted into an Arduino library. The sketches now only handle communication between a `Denko::TxRx::` class in Ruby and this library. Writing new sketches for arbitray protocols should be simpler.
|
445
|
+
|
446
|
+
* Arduino-level debug messages now use preprocessor directives instead of `if(debug)` statements. The performance and memory usage of sketches with debugging disabled is improved.
|
447
|
+
|
448
|
+
* As a result, enabling and disabling Arduino-level debug messages can no longer be done in Ruby. You'll need to enable debug messages before uploading a sketch by using the `--debug` option when generating the sketch with `denko`.
|
449
|
+
|
450
|
+
* Removed `TxRx::Telnet`. `TxRx::TCP`, written for the Ethernet shield, works even better for ser2net.
|
451
|
+
|
452
|
+
### Minor Changes
|
453
|
+
|
454
|
+
* Handshake protocol: The first command sent to the Arduino resets the board to defaults. It acknowledges and responds with the raw pin number of its first analog pin, 'A0' (pin 14 on an UNO).
|
455
|
+
|
456
|
+
* When sending messages between Ruby and the Arduino, all pins are now referenced by this numerical syntax. The value received in the handshake is used by `Denko::Board` to calculate values on the fly, so the more friendly 'A0' syntax may be used everywhere else in Ruby. This was done mostly to replace some complicated Arduino code and support > 10 analog pins.
|
457
|
+
|
458
|
+
* The Arduino's read and write operations no longer implicitly set the mode of a pin. Calling `board#set_pin_mode` when initializing a component is now required. `board#add_analog_hardware` or `board#add_digital_hardware` for read components will take care of this as well.
|
459
|
+
|
460
|
+
* The syntax of the messages sent from the Arduino to Ruby has changed slightly from "PP::VVVV\r\n" to "PP:VVVV\n" where PP and VVVV represent the pin and value respectively. The increase in (serial) throughput is usable when many analog listeners are set or polling at high rates.
|
461
|
+
|
462
|
+
* Sensors accept blocks instead of procs now.
|
463
|
+
|
464
|
+
### Fixes
|
465
|
+
|
466
|
+
* `Board#set_pin_mode` works correctly now. Input and output were swapped previously and this error was being hidden by the implicit operations mentioned above.
|
data/DEPS_CLI.md
ADDED
@@ -0,0 +1,80 @@
|
|
1
|
+
## Install Arduino Dependencies for Denko (CLI)
|
2
|
+
|
3
|
+
Once `arduino-cli` is installed, you can copy and paste into your shell for easy installation.
|
4
|
+
|
5
|
+
**Note:** `arduino-cli config init` attempts to create a CLI config file for new installs. It's safe to ignore any errors generated if you already have one.
|
6
|
+
|
7
|
+
**Install Everything:**
|
8
|
+
````shell
|
9
|
+
arduino-cli config init
|
10
|
+
arduino-cli config add board_manager.additional_urls https://arduino.esp8266.com/stable/package_esp8266com_index.json
|
11
|
+
arduino-cli config add board_manager.additional_urls https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_index.json
|
12
|
+
arduino-cli config add board_manager.additional_urls https://github.com/earlephilhower/arduino-pico/releases/download/global/package_rp2040_index.json
|
13
|
+
arduino-cli core update-index
|
14
|
+
arduino-cli core install arduino:megaavr
|
15
|
+
arduino-cli core install arduino:sam
|
16
|
+
arduino-cli core install arduino:samd
|
17
|
+
arduino-cli core install esp8266:esp8266
|
18
|
+
arduino-cli core install esp32:esp32
|
19
|
+
arduino-cli core install rp2040:rp2040
|
20
|
+
arduino-cli lib install Servo
|
21
|
+
arduino-cli lib install Ethernet
|
22
|
+
arduino-cli lib install WiFi
|
23
|
+
arduino-cli lib install IRremote@4.0.0
|
24
|
+
arduino-cli lib install IRremoteESP8266@2.8.4
|
25
|
+
arduino-cli lib install ESP32Servo
|
26
|
+
arduino-cli lib install "Adafruit NeoPixel"
|
27
|
+
````
|
28
|
+
|
29
|
+
**AVR-based Arduinos & Clones Only:**
|
30
|
+
````shell
|
31
|
+
arduino-cli core update-index
|
32
|
+
arduino-cli core install arduino:megaavr
|
33
|
+
arduino-cli lib install Servo
|
34
|
+
arduino-cli lib install Ethernet
|
35
|
+
arduino-cli lib install WiFi
|
36
|
+
arduino-cli lib install IRremote@4.0.0
|
37
|
+
arduino-cli lib install "Adafruit NeoPixel"
|
38
|
+
````
|
39
|
+
|
40
|
+
**ARM-based Arduinos & Clones Only:**
|
41
|
+
````shell
|
42
|
+
arduino-cli core update-index
|
43
|
+
arduino-cli core install arduino:sam
|
44
|
+
arduino-cli core install arduino:samd
|
45
|
+
arduino-cli lib install Servo
|
46
|
+
arduino-cli lib install Ethernet
|
47
|
+
arduino-cli lib install WiFi
|
48
|
+
arduino-cli lib install IRremote@4.0.0
|
49
|
+
arduino-cli lib install "Adafruit NeoPixel"
|
50
|
+
````
|
51
|
+
|
52
|
+
**ESP8266 Only:**
|
53
|
+
````shell
|
54
|
+
arduino-cli config init
|
55
|
+
arduino-cli config add board_manager.additional_urls https://arduino.esp8266.com/stable/package_esp8266com_index.json
|
56
|
+
arduino-cli core update-index
|
57
|
+
arduino-cli core install esp8266:esp8266
|
58
|
+
arduino-cli lib install IRremoteESP8266@2.8.4
|
59
|
+
arduino-cli lib install "Adafruit NeoPixel"
|
60
|
+
````
|
61
|
+
|
62
|
+
**ESP32 Only:**
|
63
|
+
````shell
|
64
|
+
arduino-cli config init
|
65
|
+
arduino-cli config add board_manager.additional_urls https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_index.json
|
66
|
+
arduino-cli core update-index
|
67
|
+
arduino-cli core install esp32:esp32
|
68
|
+
arduino-cli lib install ESP32Servo
|
69
|
+
arduino-cli lib install IRremoteESP8266@2.8.4
|
70
|
+
arduino-cli lib install "Adafruit NeoPixel"
|
71
|
+
````
|
72
|
+
|
73
|
+
**RP2040 Only:**
|
74
|
+
````shell
|
75
|
+
arduino-cli config init
|
76
|
+
arduino-cli config add board_manager.additional_urls https://github.com/earlephilhower/arduino-pico/releases/download/global/package_rp2040_index.json
|
77
|
+
arduino-cli core update-index
|
78
|
+
arduino-cli core install rp2040:rp2040
|
79
|
+
arduino-cli lib install IRremote@4.0.0
|
80
|
+
````
|