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>
83 lines
1.7 KiB
C
83 lines
1.7 KiB
C
#pragma once
|
|
|
|
#include "flipper.h"
|
|
|
|
/*
|
|
== PubSub ==
|
|
|
|
PubSub allows users to subscribe on notifies and notify subscribers.
|
|
Notifier side can pass `void*` arg to subscriber callback,
|
|
and also subscriber can set `void*` context pointer that pass into
|
|
callback (you can see callback signature below).
|
|
*/
|
|
|
|
typedef void(PubSubCallback*)(void*, void*);
|
|
|
|
typedef struct {
|
|
PubSubCallback cb;
|
|
void* ctx;
|
|
} PubSubItem;
|
|
|
|
typedef struct {
|
|
PubSub* self;
|
|
PubSubItem* item;
|
|
} PubSubId;
|
|
|
|
typedef struct {
|
|
PubSubItem items[NUM_OF_CALLBACKS];
|
|
PubSubId ids[NUM_OF_CALLBACKS]; ///< permanent links to item
|
|
size_t count; ///< count of callbacks
|
|
} PubSub;
|
|
|
|
/*
|
|
To create PubSub you should create PubSub instance and call `init_pubsub`.
|
|
*/
|
|
void init_pubsub(PubSub* pubsub);
|
|
|
|
/*
|
|
Use `subscribe_pubsub` to register your callback.
|
|
*/
|
|
PubSubId* subscribe_pubsub(PubSub* pubsub, PubSubCallback cb, void* ctx);
|
|
|
|
/*
|
|
Use `unsubscribe_pubsub` to unregister callback.
|
|
*/
|
|
void unsubscribe_pubsub(PubSubId* pubsub_id);
|
|
|
|
/*
|
|
Use `notify_pubsub` to notify subscribers.
|
|
*/
|
|
void notify_pubsub(PubSub* pubsub, void* arg);
|
|
|
|
/*
|
|
|
|
```C
|
|
// MANIFEST
|
|
// name="test"
|
|
// stack=128
|
|
|
|
void example_pubsub_handler(void* arg, void* ctx) {
|
|
printf("get %d from %s\n", *(uint32_t*)arg, (const char*)ctx);
|
|
}
|
|
|
|
void pubsub_test() {
|
|
const char* app_name = "test app";
|
|
|
|
PubSub example_pubsub;
|
|
init_pubsub(&example_pubsub);
|
|
|
|
if(!subscribe_pubsub(&example_pubsub, example_pubsub_handler, (void*)app_name)) {
|
|
printf("critical error\n");
|
|
flapp_exit(NULL);
|
|
}
|
|
|
|
uint32_t counter = 0;
|
|
while(1) {
|
|
notify_pubsub(&example_pubsub, (void*)&counter);
|
|
counter++;
|
|
|
|
osDelay(100);
|
|
}
|
|
}
|
|
```
|
|
*/ |