mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-23 05:14:16 +03:00
acc39a4bc0
* Api Symbols: replace asserts with checks * Api Symbols: replace asserts with checks part 2 * Update no args function signatures with void, to help compiler to track incorrect usage * More unavoidable void * Update PVS config and code to make it happy * Format sources * nfc: fix checks * dead code cleanup & include fixes Co-authored-by: gornekich <n.gorbadey@gmail.com> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: hedger <hedger@nanode.su>
69 lines
1.7 KiB
C
69 lines
1.7 KiB
C
/**
|
|
* @file pubsub.h
|
|
* FuriPubSub
|
|
*/
|
|
#pragma once
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** FuriPubSub Callback type */
|
|
typedef void (*FuriPubSubCallback)(const void* message, void* context);
|
|
|
|
/** FuriPubSub type */
|
|
typedef struct FuriPubSub FuriPubSub;
|
|
|
|
/** FuriPubSubSubscription type */
|
|
typedef struct FuriPubSubSubscription FuriPubSubSubscription;
|
|
|
|
/** Allocate FuriPubSub
|
|
*
|
|
* Reentrable, Not threadsafe, one owner
|
|
*
|
|
* @return pointer to FuriPubSub instance
|
|
*/
|
|
FuriPubSub* furi_pubsub_alloc(void);
|
|
|
|
/** Free FuriPubSub
|
|
*
|
|
* @param pubsub FuriPubSub instance
|
|
*/
|
|
void furi_pubsub_free(FuriPubSub* pubsub);
|
|
|
|
/** Subscribe to FuriPubSub
|
|
*
|
|
* Threadsafe, Reentrable
|
|
*
|
|
* @param pubsub pointer to FuriPubSub instance
|
|
* @param[in] callback The callback
|
|
* @param callback_context The callback context
|
|
*
|
|
* @return pointer to FuriPubSubSubscription instance
|
|
*/
|
|
FuriPubSubSubscription*
|
|
furi_pubsub_subscribe(FuriPubSub* pubsub, FuriPubSubCallback callback, void* callback_context);
|
|
|
|
/** Unsubscribe from FuriPubSub
|
|
*
|
|
* No use of `pubsub_subscription` allowed after call of this method
|
|
* Threadsafe, Reentrable.
|
|
*
|
|
* @param pubsub pointer to FuriPubSub instance
|
|
* @param pubsub_subscription pointer to FuriPubSubSubscription instance
|
|
*/
|
|
void furi_pubsub_unsubscribe(FuriPubSub* pubsub, FuriPubSubSubscription* pubsub_subscription);
|
|
|
|
/** Publish message to FuriPubSub
|
|
*
|
|
* Threadsafe, Reentrable.
|
|
*
|
|
* @param pubsub pointer to FuriPubSub instance
|
|
* @param message message pointer to publish
|
|
*/
|
|
void furi_pubsub_publish(FuriPubSub* pubsub, void* message);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|