Skip to content

Complete buttons to switches library implemented for ESP32-Arduino, with flags update automation, function callbacks, tasks unblocking, task resumes, all encapsulated in classes sharing a common API for simplest implementation, use, modification or replacement when needed.

License

Notifications You must be signed in to change notification settings

GabyGold67/ButtonToSwitch_ESP32

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Buttons to Switches Library (ButtonToSwitch_ESP32)

The driving concept is pretty simple:

- Stop checking the input pin voltage.

- Start asking if the switch is On or Off.

This library is an evolutionary refactoring of my own -now archived- mpbToSwitch library.

An ESP32-RTOS Arduino library that builds switch mechanisms replacements out of simple push buttons.

By using just a push button (a.k.a. momentary switches or momentary buttons, MPB for short from here on) the classes implemented in this library will manage, calculate and update different parameters to generate the behavior of standard electromechanical switches. Those parameters include presses, releases, timings, counters or secondary input readings as needed.

The instantiated switch state is updated independently by a standard FreeRTOS software timer (or ESP-IDF FreeRTOS in this case), that keeps the state of the objects created constantly refreshed including the ON/OFF condition, without constant polling needed. The timer setup is managed by in-class methods, including the possibility to pause, resume or end the timer of each object independently of the others.
Each class offers a wide range of methods to set, read and modify every significant aspect of each switch mechanism simulated, and the signal received from the push button is debounced for a correct behavior of the event processing.

The library implements the following switches mechanisms:

  • Debounced Momentary Push Button (a.k.a. Momentary switch, a.k.a. Pushbutton)
  • Debounced Delayed Momentary Push Button (a.k.a. Delayed Pushbutton)
  • Toggle Switch Momentary Push Button (a.k.a. Alternate Pushbutton, a.k.a. Latched Switch)
  • Timer Toggled Momentary Push Button (a.k.a. Timer Switch)
  • Hinted Timer Toggled (a.k.a. Staircase Timer Switch)
  • External Unlatch Toggle (a.k.a. Emergency Latched Switch)
  • Time Voidable Momentary Push Button (a.k.a. Anti-Tampering Switch)
  • Single Service Voidable Momentary Push Button (a.k.a. Trigger Switch)
  • Short Press/Long Press Double action On/Off + Slider combo switch (a.k.a. Off/On/Dimmer, a.k.a. Off/On/Volume Radio Switch)
  • Short Press/Long Press Double action On/Off + Secondary output MPB combo switch

The benefits of the use of those simulated switches mechanisms are not just economic, as push buttons come in a wide range of prices and qualities as the simulated hardware switches come.

In any device powering on/off project, for example, detecting after the implementation, through the daily use, that an installed switch was not the best choice when a physical switch is involved, requires for the correction to a best suited kind of switch a bunch of activities to get the change of the switch unit done:

  • Searching for the availability of a best suited switch to match our intended functionalities.
  • Getting that different best suited switch, with the time and resources investment involved.
  • Uninstalling the first switch.
  • Maybe modifying the cabling.
  • Maybe modifying the switch housing.
  • Installing the new switch...

While with the simulated switches this situation might be solved by just changing the object class, modifying the instantiation parameters or calling a method if needed, and the switch is already changed!!

  • Want to keep the timed lights-on longer? Just a parameter.
  • Want to turn off the pilot light because it bothers? Another parameter.
  • Want to be sure the door mechanism isn't kept unlocked with an adhesive tape? Change the switch class.
  • Want to ensure nobody turns on a dangerous appliance while it's internals are being cleaned? Invoke a method!

In an Industrial production machines environment the operator's physical security policies enforcement implies that no time can be wasted and the switch must fit perfectly it's purpose, while still giving the chance to change it's working parameters to adjust the mechanism to changing production operations, or to use the security device in other kind of machine. In this case the development depending on a simple "OK to proceed"/"The security device is correctly activated" might become a dangerous issue if not correctly isolated and solved as a remove and replace solution. The security switches must comply with issues as:

  • Activation enforcement
  • Release enforcement
  • Time Voidable activation or releases
  • Activation sequence enforcement
  • Production related disabling of any of the switches while keeping the activation logic.
  • ... and so many others parameters involved.

Just to add possibilities, consider that everywhere the "Momentary Push Button" is mentioned, any kind of momentary digital activation signal provider might be used instead: touch sensors, PIR sensors, RFID signals, fingerprint reader and so on...

ButtonToSwitch Library Classes Hierarchy

The main output attribute flag kept updated for each and every class is the isOn flag, which defines the Off State (isOn=false) and the On State (isOn=true) of the instantiated objects.

The embedded behavior also includes logical replacements for temporary or extraordinary responses that usually need external hardware modifications in electromechanical switches:

  • Switch disconnection.
  • Switch bypassing
  • Minimum pressing time for turning on/off.

All classes provide several communication mechanisms to keep it's output states available by request and by having their value change automatically notified.
Those mechanisms include:
- Flags value getters: Return the value of each significant attribute flag.
- General flags value change getter: Returns a value indicating if any of the significant output flags' values has changed.
- Lightweight Binary Semaphore: Implementation of a xTaskNotify() FreeRTOS macro to unblock a developer defined task -every time any of the output flags' values changes- including a notification value indicating the state of the MPB.
- Task Resume/Suspend: A mechanism is provided to run a developer defined task while the object is in On State. The designated task will be set to "Suspended State" while the object is in Off State and will be set to "Resume" while it is in On State, providing means to execute far more complex tasks than just "turning On & turning Off" devices.
- Functions execution: A developer defined function might be set to be executed every time the instantiated object attribute flags change it's value, including:
- Entering the On State and entering the Off State, each of the functions is to be independently defined, so one, the other or both might be defined, and even the same function might be used for both events.
- Entering and exiting the Secondary function On state with the same characteristics above described for the On/Off State.
- Entering and exiting the Warning On state with the same characteristics above described for the On/Off State.
- Entering and exiting the Pilot On state with the same characteristics above described for the On/Off State.
- Entering and exiting the Voided state with the same characteristics above described for the On/Off State.
Those listed mechanisms are independent, so one or more might be simultaneously used according to implementation needs and convenience.



DbncdMPBttn class

The Debounced Momentary Button keeps the ON state since the moment the signal is stable (debouncing process) and until the moment the MPB is released.

Included Methods for DbncdMPBttn class

Method Parameters
DbncdMPBttn None
DbncdMPBttn uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett)))
begin() (unsigned long int pollDelayMs)
clrStatus() (bool clrIsOn)
disable() None
enable() None
end() None
getCurDbncTime() None
getFnWhnTrnOff() None
getFnWhnTrnOn() None
getIsEnabled() None
getIsOn() None
getIsOnDisabled() None
getOtptsSttsPkgd() None
getOutputsChange() None
getStrtDelay() None
getTaskToNotify() None
getTaskWhileOn() None
init() uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett)))
pause() None
resetDbncTime() None
resetFda() None
resume() None
setDbncTime() unsigned long int newDbncTime
setFnWhnTrnOffPtr() void* fnWhnTrnOff
setFnWhnTrnOnPtr() void* fnWhnTrnOn
setIsOnDisabled() bool newIsOnDisabled
setOutputsChange() bool newOutputChange
setTaskToNotify() TaskHandle_t newTaskHandle
setTaskWhileOn() TaskHandle_t newTaskHandle

Methods definition and use description



DbncdDlydMPBttn class

The Debounced Delayed Momentary Button, keeps the ON state since the moment the signal is stable (debouncing process), plus a delay added, and until the moment the push button is released. The reasons to add the delay are design related and are usually used to avoid registering unintentional presses, or to give some equipment (load) that needs time between repeated activations the benefit of the pause. If the push button is released before the delay configured, no press is registered at all. The delay time in this class as in the other classes that implement it, might be zero (0), defined by the developer and/or modified in runtime.

Added or modified Methods for DbncdDlydMPBttn class

Method Parameters
DbncdDlydMPBttn None
DbncdDlydMPBttn uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))
init uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))
setStrtDelay() (unsigned long int newStrtDelay)

Methods definition and use description



LtchMPBttn class

This is an Abstract Class meaning that no object can be instantiated from it. The members defined are meant to be available for the LtchMPBttn subclasses instantiated objects, and define common behavior for all the "Latched Button Subclasses".

  • Latched DD-MPBs are MPBs whose distinctive characteristic is that models switches that keep the ON state since the moment the input signal is stable (debouncing + Delay process), and keeps the ON state after the MPB is released and until an event un-latches them, setting them free to move back to the Off State.
  • The un-latching mechanisms include but are not limited to: same MPB presses, timers, other MPB presses, other GPIO external un-latch signals or the use of the public method unlatch().
    The different un-latching events defines the sub-classes of the LDD-MPB class.

Attention: The range of signals accepted by the instantiated objects to execute the unlatch process is diverse, and their nature and characteristics might affect the expected switch behavior. While some of the signals might be instantaneous, meaning that the start of the unlatch signal is coincidental with the end of the unlatch signal, some others might extend the time between both ends. To accommodate the logic required by each subclass, and the requirements of each design, the unlatch process is then split into two stages:

  1. Validated Unlatch signal (or Validated Unlatch signal start).
  2. Validated Unlatch Release signal (or Validated Unlatch signal end).

The class provides methods to generate those validated signals independently of the designated signal source to modify the instantiated object behavior if needed by the design requirements, Validated Unlatch signal (see LtchMPBttn::setUnlatchPend(const bool) ), Validated Unlatch Release signal (see LtchMPBttn::setUnlatchRlsPend(const bool) ), or to set both flags to generate an unlatch (see LtchMPBttn::unlatch() ).

Added or Modified Methods for LtchMPBttn class

Method Parameters
getIslatched() None
getTrnOffASAP() None
getUnlatchPend() None
getUnlatchRlsPend() None
setTrnOffASAP() bool newVal
setUnlatchPend() bool newVal
setUnlatchRlsPend() bool newVal
unlatch() None

Methods definition and use description



TgglLtchMPBttn class

The Toggle switch keeps the ON state since the moment the signal is stable (debouncing + Delay process), and keeps the ON state after the push button is released and until it is pressed once again. So this simulates a simple On-Off switch like the ones used to turn on/off a room light, or any electronic device. There's a lot of advantages in software simulated switches: any amount of switches might be set up in a parallel configuration, so that an unlimited number of entrances or easy accessible points can each have a switch to turn on/off the same resource, the switch might be temporarily disabled, either keeping the On State or the Off State, and some more.

Added or Modified Methods for LtchMPBttn class

Method Parameters
TgglLtchMPBttn uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))

Methods definition and use description



TmLtchMPBttn class

The Time latched or Timer Switch keeps the ON state since the moment the signal is debounced and delayed, and keeps the ON state during a set time. The Service time is set at instantiation, and can be modified through the provided methods. The switch implementation gives the option to allow to reset the timer before reaches the time limit if the push button is pressed again.

Added or Modified Methods for TmLtchMPBttn class

Method Parameters
TmLtchMPBttn uint8_t mpbttnPin, unsigned long int actTime(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))
getSrvcTime() None
setSrvcTime() unsigned long int newSvcTime
setTmerRstbl() bool newIsRstbl

Methods definition and use description



HntdTmLtchMPBttn class

The Hinted Timer Latched, or Staircase Timer Switch, keeps the ON state since the moment the signal is debounced, and keeps the state during a set time, the switch time is set at instantiation, and can be modified through the provided methods. The switch implementation gives the option to allow to reset the timer before it gets to the end if the push button is pressed, the option to give a warning when the time is close to the end through a second flag (remaining time is defined as a percentage of the total ON time and it's configurable), and the possibility to set a third signal ON while the switch is off, just like the pilot light (hint) in a staircase timer switch. The warning signal is independent of the off hint.

Added or Modified Methods for HntdTmLtchMPBttn class

Method Parameters
HntdTmLtchMPBttn uint8_t mpbttnPin, unsigned long int actTime(, unsigned int wrnngPrctg(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay)))))
getFnWhnTrnOffPilot() None
getFnWhnTrnOffWrnng() None
getFnWhnTrnOnPilot() None
getFnWhnTrnOnWrnng() None
getPilotOn() None
getWrnngOn() None
setFnWhnTrnOffPilot() void* newFnWhnTrnOff
setFnWhnTrnOffWrnng() void* newFnWhnTrnOff
setFnWhnTrnOnPilot() void* newFnWhnTrnOn
setFnWhnTrnOnWrnng() void* newFnWhnTrnOn
setKeepPilot() bool keepPilot
setWrnngPrctg() unsigned int newWrnngPrctg

Methods definition and use description



XtrnUnLtchMPBttn class

The External released toggle (a.k.a. Emergency latched), keeps the On state since the moment the signal is debounced, and until an external signal is received. This kind of switch is used when an "abnormal situation" demands the push of the switch On, but a higher authority is needed to reset it to Off from a different signal source. Smoke, flood, intrusion alarms and "last man locks" are some examples of the use of this switch. As the external release signal can be physically or logically generated it can be implemented to be received from a switch or a remote signal of any usual kind.

Added or Modified Methods for XtrnUnltchMPBttn class

Method Parameters
XtrnUnLtchMPBttn uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))
XtrnUnLtchMPBttn uint8_t mpbttnPin, DbncDlydMPBttn* unltchBttn(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))

Methods definition and use description



DblActnLtchMPBttn class


This is an Abstract Class meaning that no object can be instantiated from it. The members defined are meant to be available for the Double Action Latched DD-MPB (DblActnLtchMPBttn) subclasses instantiated objects, and define common behavior for all the "Double Action Latched Button Subclasses".

Double Action Latched DD-MPB are MPBs whose distinctive characteristic is that models switches that present different behaviors based on the time length of the presses detected and the sequence of the presses.
The pattern selected for this class is the following:

  • A short press makes the MPB to behave as a Toggle LDD-MPB Switch (ToLDD-MPB) -designated as the main behavior-, swapping from the Off state to the On state and back as usual LDD-MPB.
  • A long press activates an alternative behavior, allowing the single MPB to be used as a second MPB. That different behavior -designated as the secondary behavior- defines the sub-classes of the DALDD-MPB class.
    Using a notation where the first component is the Off/On state of the main behavior and the second component the state of the secondary behavior the only possible combinations would be:
  • 1. Off - Off
  • 2. On - Off
  • 3. On - On

The presses patterns are:

  • 1. -> 2.: short press.
  • 1. -> 3.: long press.
  • 2. -> 3.: long press.
  • 2. -> 1.: short press.
  • 3. -> 2.: secondary behavior unlatch (subclass dependent, maybe release, external unlatch, etc.)

[!NOTE] The short press will always be calculated as the Debounce + Delay set attributes.

[!NOTE] The long press is a configurable attribute of the class, the Secondary Mode Activation Delay (scndModActvDly) that holds the time after the Debounce + Delay period that the MPB must remain pressed to activate the mentioned mode. The same time will be required to keep pressed the MPB while in Main Behavior to enter the Secondary behavior.

Added or Modified Methods for DblActnLtchMPBttn class

Method Parameters
getFnWhnTrnOffScndry() None
getFnWhnTrnOnScndry() None
getIsOnScndry() None
getScndModActvDly() None
getTaskWhileOnScndry() None
setFnWhnTrnOffScndryPtr() void* fnWhnTrnOff
setFnWhnTrnOnScndryPtr() void* fnWhnTrnOn
setScndModActvDly() unsigned long newVal
setTaskWhileOnScndry() TaskHandle_t newTaskHandle

Methods definition and use description



DDlydDALtchMPBttn class


DDlydDALtchMPBttn models a Debounced Delayed Double Action Latched MPB combo switch (Debounced Delayed DALDD-MPB - DD-DALDD-MPB).
This is a subclass of the DALDD-MPB whose secondary behavior is that of a DbncdDlydMPBttn (DD-MPB), that implies that:

  • While on the 1.state (Off-Off), a short press will activate only the regular main On state 2. (On-Off).
  • While on the 1.state (Off-Off), a long press will activate both the regular main On state and the secondary On state simultaneously 3. (On-On).
  • When releasing the MPB the switch will stay in the main On state 2. (On-Off).
  • While in the 2. state (On-Off), a short press will set the switch to the 1. state (Off-Off).
  • While in the 2. state (On-Off), a long press will set the switch to the 3. state (On-On), until the releasing of the MPB, returning the switch to the main On state 2. (On-Off).

Added or Modified Methods for DDlydDALtchMPBttn class

Method Parameters
DDlydDALtchMPBttn() uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))

Methods definition and use description



SldrDALtchMPBttn class


SldrDALtchMPBttn models a Slider Double Action LDD-MPB combo switch, a.k.a. off/on/dimmer, a.k.a. off/on/volume radio switch)(S-DALDD-MPB)

This is a subclass of the DALDD-MPB whose secondary behavior is analog to that of a Digital potentiometer (DigiPot) or a Discreet values increment/decrement register. That means that when in the second mode, while the MPB remains pressed, an attribute set as a register changes its value -the otptCurVal register-.
When the timer callback function used to keep the MPB status updated is called -while in the secondary mode state- the time since the last call is calculated and the time lapse in milliseconds is converted into Steps, using as configurable factor the outputSliderSpeed in a pre-scaler fashion. At instantiation the outputSliderSpeed is configured to 1 (step/millisecond, i.e. 1 step for each millisecond).
The resulting value in "steps" is then factored by the outputSliderStepSize, which holds the value that each step will modify the otptCurVal register.
The implemented embedded behavior mechanisms of the class determine how the modification of the otpCurVal register will be made, and the associated effects to the instantiated object's attribute, such as (but not limited to):

  • Incrementing otpCurVal register (by the quantity of steps multiplied by the step size) up to the "maximum value" setting.
  • Decrementing otpCurVal register (by that quantity) down to the "minimum value" setting.
  • Changing the modification's direction (from incrementing to decrementing or vice versa).

The minimum and maximum values, the rate in steps/millisecond, the size of each step and the variation direction (sign of the variation, incrementing or decrementing) are all configurable, as is the starting value and the mechanism to revert the "direction" that includes:

  • Revert directions in the next secondary mode entry.
  • Automatically revert direction when reaching the minimum and maximum values setting.
  • Revert direction by methods invocation (see setSldrDirDn(), setSldrDirUp(), swapSldrDir()).

Added or Modified Methods for SldrDALtchMPBttn class

Method Parameters
SldrDALtchMPBttn() uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay(, uint16_t initVal)))))
getOtptCurVal() None
getOtptCurValIsMax() None
getOtptCurValIsMin() None
getOtptSldrSpd() None
getOtptSldrStpSize() None
getOtptValMax() None
getOtptValMin() None
getSldrDirUp() None
setOtptCurVal() uint16_t newVal
setOtptSldrSpd() uint16_t newVal
setOtptSldrStpSize() uint16_t newVal
setOtptValMax() uint16_t newVal
setOtptValMin() uint16_t newVal
setSldrDirDn() None
setSldrDirUp() None
setSwpDirOnEnd() bool newVal
setSwpDirOnPrss() bool newVal
swapSldrDir() None

Methods definition and use description



VdblMPBttn class


This is an Abstract Class meaning that no object can be instantiated from it. The members defined are meant to be available for the VdblMPBttn DD-MPB (VDD-MPB) subclasses instantiated objects, and define common behavior for all the "Voidable Button Subclasses".
Voidable DD-MPBs are MPBs whose distinctive characteristic is that implement non-latching switches that while being pressed their state might change from On State to a Voided state due to different voiding conditions. Depending on the classes the voided state might be Voided & Off state, Voided & On state or Voided & Not enforced states, being this last one those which enter the voided state but the On state will not be forced to change due to the voidance.
Those conditions to change to a voided state include -but are not limited to- the following conditions:

  • pressing time
  • external signals
  • entering the On state

The mechanisms to "un-void" the MPB and return it to an operational state include -but are not limited to- the following actions:

  • releasing the MPBs.
  • receiving an external signal.
  • the reading of the isOn attribute flag status.

The voiding conditions and the un-voiding mechanisms define the VDD-MPB subclasses.

Added or Modified Methods for VdblMPBttn class

Method Parameters
getFnWhnTrnOffVdd() None
getFnWhnTrnOnVdd() None
getFrcOtptLvlWhnVdd() None
getIsVoided() None
getStOnWhnOtpFrcd() None
setFnWhnTrnOffVddPtr() void* newFnWhnTrnOff
setFnWhnTrnOnVddPtr() void* newFnWhnTrnOn
setIsNotVoided() None
setIsVoided() None

Methods definition and use description



TmVdblMPBttn class


The Time Voidable Momentary Button, keeps the ON state since the moment the signal is stable (debouncing process), plus a delay added, and until the moment the push button is released, or until a preset time in the ON state is reached. Then the switch will return to the Off position until the push button is released and pushed back. This kind of switches are used to activate limited resources related management or physical safety devices, and the possibility of a physical blocking of the switch to extend the ON signal artificially beyond designer's plans is highly undesired. Water valves, door unlocking mechanisms, hands-off security mechanisms, high power heating devices are some of the usual uses for these type of switches. It's implemented in the TmVdblMPBttn class.

Added Methods for TmVdblMPBttn class

Method Parameters
TmVdblMPBttn uint8_t mpbttnPin, unsigned long int voidTime(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay(, bool isOnDisabled)))))
getVoidTime() None
setVoidTime() None

Methods definition and use description



SnglSrvcVdblMPBttn class


This class models a Single Service Voidable DD-MPB a.k.a. Trigger switch (SSVDD-MPB)

The Single Service Voidable Momentary Push Button keeps the On state since the moment the signal is stable (debounce & delay process) and until the moment the provided mechanisms implemented to be executed when the switch enters the On State are started, that means calling the fnWhnTrnOn function, notifying the taskToNotify task and setting the isOn attribute flag.
After the configured mechanisms are triggered and the attribute flag is set to true (the only mandatory action is the attribute flag setting, all the others are configurable to execute or not) the MPB will enter the Voided State, forcing the MPB into the Off State by design. The SnglSrvcVdblMPBttn class objects requires the MPB to be released to exit the Voided State, restarting the cycle.
This kind of switches are used to handle "Single Shot Trigger" style signals, ensuring one single signal triggered per push.

[!CAUTION] Depending on checking the isOn attribute flag reading trough the getIsOn() method will surely fail due to the high risk of missing the short time the flag will be raised before it is again taken down by the voidance of the MPB. The use of the non-polling facilities ensures no loss of signals and enough time to execute the code depending on the "trigger activation", including the fnWhnTrnOn function, and the taskToNotify task.

[!NOTE] Due to the short time the isOn flag will be raised, as described above, the resuming of the taskWhileOn activation mechanism is disabled in this class. For that purpose the setTaskWhileOn(const TaskHandle_t) is made not accessible.

[!NOTE] Due to the short time the isOn flag will be raised, as described above, the short time between the fnWhnTrnOn function and the fnWhnTrnOff function callings must also need to be carefully evaluated by the user.

Added Methods for TmVdblMPBttn class

Method Parameters
TmVdblMPBttn uint8_t mpbttnPin(, bool pulledUp(, bool typeNO(, unsigned long int dbncTimeOrigSett(, unsigned long int strtDelay))))

Methods definition and use description


About

Complete buttons to switches library implemented for ESP32-Arduino, with flags update automation, function callbacks, tasks unblocking, task resumes, all encapsulated in classes sharing a common API for simplest implementation, use, modification or replacement when needed.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages