2022-11-30 18:02:00 +08:00
|
|
|
/**
|
|
|
|
* @file message_center.h
|
|
|
|
* @author NeoZeng neozng1@hnu.edu.cn
|
|
|
|
* @brief 这是一个伪pubsub机制,仅对应用之间的通信进行了隔离
|
|
|
|
* @todo 实现基于链表-队列的pubsub机制
|
|
|
|
* @version 0.1
|
|
|
|
* @date 2022-11-30
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 18:02:00 +08:00
|
|
|
* @copyright Copyright (c) 2022
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 18:02:00 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PUBSUB_H
|
|
|
|
#define PUBSUB_H
|
|
|
|
|
2022-12-12 22:29:51 +08:00
|
|
|
#include "stdint.h"
|
2022-11-30 18:02:00 +08:00
|
|
|
|
2023-01-01 17:32:22 +08:00
|
|
|
#define MAX_EVENT_NAME_LEN 32 // 最大的事件名长度,每个事件都有字符串来命名
|
|
|
|
#define MAX_EVENT_COUNT 12 // 最多支持的事件数量
|
2022-11-30 22:10:57 +08:00
|
|
|
#define QUEUE_SIZE 1
|
2022-11-30 18:02:00 +08:00
|
|
|
|
2022-11-30 22:10:57 +08:00
|
|
|
typedef struct mqt
|
|
|
|
{
|
|
|
|
/* 用数组模拟FIFO队列 */
|
2023-01-01 17:32:22 +08:00
|
|
|
void *queue[QUEUE_SIZE];
|
2022-11-30 22:10:57 +08:00
|
|
|
uint8_t data_len;
|
|
|
|
uint8_t front_idx;
|
|
|
|
uint8_t back_idx;
|
|
|
|
uint8_t temp_size; // 当前队列长度
|
|
|
|
|
|
|
|
/* 指向下一个订阅了相同的事件的订阅者的指针 */
|
2023-01-01 17:32:22 +08:00
|
|
|
struct mqt *next_subs_queue; // 使得发布者可以通过链表访问所有订阅了相同事件的订阅者
|
2022-11-30 22:10:57 +08:00
|
|
|
} Subscriber_t;
|
|
|
|
|
|
|
|
/**
|
2023-01-01 17:32:22 +08:00
|
|
|
* @brief 发布者类型.每个发布者拥有发布者实例,并且可以通过链表访问所有订阅了自己发布的事件的订阅者
|
|
|
|
*
|
2022-11-30 22:10:57 +08:00
|
|
|
*/
|
2023-01-01 17:32:22 +08:00
|
|
|
typedef struct ent
|
|
|
|
{
|
2022-11-30 22:10:57 +08:00
|
|
|
/* 事件名称 */
|
2023-01-01 17:32:22 +08:00
|
|
|
char event_name[MAX_EVENT_NAME_LEN + 1]; // 1个字节用于存放字符串结束符 '\0'
|
|
|
|
uint8_t data_len; // 该事件的数据长度
|
2022-11-30 22:10:57 +08:00
|
|
|
/* 指向第一个订阅了该事件的订阅者,通过链表访问所有订阅者 */
|
2023-01-01 17:32:22 +08:00
|
|
|
Subscriber_t *first_subs;
|
2022-11-30 22:10:57 +08:00
|
|
|
/* 指向下一个Publisher的指针 */
|
2023-01-01 17:32:22 +08:00
|
|
|
struct ent *next_event_node;
|
2023-03-06 18:52:24 +08:00
|
|
|
uint8_t pub_registered_flag; // 用于标记该发布者是否已经注册
|
2022-11-30 22:10:57 +08:00
|
|
|
} Publisher_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 订阅name的事件消息
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 22:10:57 +08:00
|
|
|
* @param name 事件名称
|
|
|
|
* @param data_len 消息长度,通过sizeof()获取
|
|
|
|
* @return Subscriber_t* 返回订阅者实例
|
|
|
|
*/
|
2023-01-01 17:32:22 +08:00
|
|
|
Subscriber_t *SubRegister(char *name, uint8_t data_len);
|
2022-11-30 22:10:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 注册成为消息发布者
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 22:10:57 +08:00
|
|
|
* @param name 发布者发布的话题名称(事件)
|
|
|
|
* @return Publisher_t* 返回发布者实例
|
|
|
|
*/
|
2023-01-01 17:32:22 +08:00
|
|
|
Publisher_t *PubRegister(char *name, uint8_t data_len);
|
2022-11-30 22:10:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取消息
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 22:10:57 +08:00
|
|
|
* @param sub 订阅者实例指针
|
|
|
|
* @param data_ptr 数据指针,接收的消息将会放到此处
|
|
|
|
* @return uint8_t 返回值为0说明没有新的消息(消息队列为空),为1说明获取到了新的消息
|
|
|
|
*/
|
2023-01-01 17:32:22 +08:00
|
|
|
uint8_t SubGetMessage(Subscriber_t *sub, void *data_ptr);
|
2022-11-30 22:10:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 发布者给所有订阅了事件的订阅者推送消息
|
2023-01-01 17:32:22 +08:00
|
|
|
*
|
2022-11-30 22:10:57 +08:00
|
|
|
* @param pub 发布者实例指针
|
|
|
|
* @param data_ptr 指向要发布的数据的指针
|
2022-12-03 21:39:31 +08:00
|
|
|
* @return uint8_t 新消息成功推送给几个订阅者
|
2022-11-30 22:10:57 +08:00
|
|
|
*/
|
2023-01-01 17:32:22 +08:00
|
|
|
uint8_t PubPushMessage(Publisher_t *pub, void *data_ptr);
|
2023-03-06 18:52:24 +08:00
|
|
|
|
|
|
|
#endif // !PUBSUB_H
|