mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-14 05:43:56 +00:00
942bbfaefe
* add input debounce code from old fw * exampl of input api * change input API to get/release * revert input API to read * pointer instead of instance * add input API description * add display API * rewrite display names * migrate to valuemanager * add LED API * add closing brakets * add sound api * fix led api * basic api * rename API pages * change pubsub implementation * move FURI AC -> flapp, add valuemutex example, add valuemanager implementation * pubsub usage example * user led example * update example * simplify input * add composed display * add SPI/GPIO and CC1101 bus * change cc1101 api * spi api and devices * spi api and devices * move SPI to page, add GPIO * not block pin open * backlight API and more * add minunit tests * fix logging * ignore unexisting time service on embedded targets * fix warning, issue with printf * Deprecate furi_open and furi_close (#167) Rename existing furi_open and furi_close to deprecated version * add exitcode * migrate to printf * indicate test by leds * add testing description * rename furi.h * wip basic api * add valuemutex, pubsub, split files * add value expanders * value mutex realization and tests * valuemutex test added to makefile * do not build unimplemented files * fix build furmware target f2 * redesigned minunit tests to allow testing in separate files * test file for valuemutex minunit testing * minunit partial test valuemutex * local cmsis_os2 mutex bindings * implement furi open/create, tests * migrate concurrent_access to ValueMutex * add spi header * Lib: add mlib submodule. Co-authored-by: rusdacent <rusdacentx0x08@gmail.com> Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
48 lines
1.3 KiB
Text
48 lines
1.3 KiB
Text
#include "pubsub.h"
|
|
|
|
void init_pubsub(PubSub* pubsub) {
|
|
pubsub->count = 0;
|
|
|
|
for(size_t i = 0; i < NUM_OF_CALLBACKS; i++) {
|
|
pubsub->items[i].
|
|
}
|
|
}
|
|
|
|
// TODO add mutex to reconfigurate PubSub
|
|
PubSubId* subscribe_pubsub(PubSub* pubsub, PubSubCallback cb, void* ctx) {
|
|
if(pubsub->count >= NUM_OF_CALLBACKS) return NULL;
|
|
|
|
pubsub->count++;
|
|
PubSubItem* current = pubsub->items[pubsub->count];
|
|
|
|
current->cb = cb;
|
|
currrnt->ctx = ctx;
|
|
|
|
pubsub->ids[pubsub->count].self = pubsub;
|
|
pubsub->ids[pubsub->count].item = current;
|
|
|
|
flapp_on_exit(unsubscribe_pubsub, &(pubsub->ids[pubsub->count]));
|
|
|
|
return current;
|
|
}
|
|
|
|
void unsubscribe_pubsub(PubSubId* pubsub_id) {
|
|
// TODO: add, and rearrange all items to keep subscribers item continuous
|
|
// TODO: keep ids link actual
|
|
// TODO: also add mutex on every pubsub changes
|
|
|
|
// trivial implementation for NUM_OF_CALLBACKS = 1
|
|
if(NUM_OF_CALLBACKS != 1) return;
|
|
|
|
if(pubsub_id != NULL || pubsub_id->self != NULL || pubsub_id->item != NULL) return;
|
|
|
|
pubsub_id->self->count = 0;
|
|
pubsub_id->item = NULL;
|
|
}
|
|
|
|
void notify_pubsub(PubSub* pubsub, void* arg) {
|
|
// iterate over subscribers
|
|
for(size_t i = 0; i < pubsub->count; i++) {
|
|
pubsub->items[i]->cb(arg, pubsub->items[i]->ctx);
|
|
}
|
|
}
|