mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-10 07:37:05 +01:00
8375857116
Also, we split the more sophisticated json_add helpers to avoid pulling in everything into lightning-cli, and unify the routines to print struct short_channel_id (it's ':', not '/' too). Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
41 lines
1.1 KiB
C
41 lines
1.1 KiB
C
#ifndef LIGHTNING_DAEMON_BROADCAST_H
|
|
#define LIGHTNING_DAEMON_BROADCAST_H
|
|
#include "config.h"
|
|
|
|
#include <ccan/intmap/intmap.h>
|
|
#include <ccan/list/list.h>
|
|
#include <ccan/short_types/short_types.h>
|
|
#include <ccan/tal/tal.h>
|
|
|
|
/* Common functionality to implement staggered broadcasts with replacement. */
|
|
|
|
struct queued_message {
|
|
int type;
|
|
|
|
/* Unique tag specifying the msg origin */
|
|
void *tag;
|
|
|
|
/* Serialized payload */
|
|
u8 *payload;
|
|
};
|
|
|
|
struct broadcast_state {
|
|
u32 next_index;
|
|
UINTMAP(struct queued_message *) broadcasts;
|
|
};
|
|
|
|
struct broadcast_state *new_broadcast_state(tal_t *ctx);
|
|
|
|
/* Queue a new message to be broadcast and replace any outdated
|
|
* broadcast. Replacement is done by comparing the `type` and the
|
|
* `tag`, if both match the old message is dropped from the queue. The
|
|
* new message is added to the top of the broadcast queue. */
|
|
void queue_broadcast(struct broadcast_state *bstate,
|
|
const int type,
|
|
const u8 *tag,
|
|
const u8 *payload);
|
|
|
|
struct queued_message *next_broadcast_message(struct broadcast_state *bstate, u64 *last_index);
|
|
|
|
#endif /* LIGHTNING_DAEMON_BROADCAST_H */
|