]>
git.scottworley.com Git - tattlekey/blob - client/press.c
1c8ce9f1ae2cb4e2318a90192ccbe0ec0150e245
4 static uint32_t next_send(press_t
*s
) {
5 return s
->timestamp
+ (1 << s
->send_count
) - 1;
8 static bool next_send_less_than(void *user_data
, pheap_node_id_t a
,
10 press_t
*presses
= (press_t
*)user_data
;
11 return next_send(&presses
[a
]) < next_send(&presses
[b
]);
14 static void *xcalloc(size_t nmemb
, size_t size
) {
15 void *p
= calloc(nmemb
, size
);
17 signal_error_by_blinking();
21 press_pile_t
*create_press_pile() {
22 press_pile_t
*pp
= (press_pile_t
*)xcalloc(1, sizeof(press_pile_t
));
23 pp
->presses
= (press_t
*)xcalloc(PICO_PHEAP_MAX_ENTRIES
, sizeof(press_t
));
25 ph_create(PICO_PHEAP_MAX_ENTRIES
, next_send_less_than
, pp
->presses
);
26 if (pp
->sleeps_heap
== NULL
)
27 signal_error_by_blinking();
31 void add_press(press_pile_t
*pp
, press_t
*press
) {
32 pheap_node_id_t i
= ph_new_node(pp
->sleeps_heap
);
34 /* TODO: Don't drop new presses just because sleeps_heap is full of old
38 pp
->presses
[i
] = *press
;
39 ph_insert_node(pp
->sleeps_heap
, i
);
42 int32_t next_scheduled_send(press_pile_t
*pp
) {
43 pheap_node_id_t i
= ph_peek_head(pp
->sleeps_heap
);
46 return next_send(&pp
->presses
[i
]);
49 bool get_press_due_for_resend(press_pile_t
*pp
, uint32_t now
, press_t
*press
) {
50 pheap_node_id_t i
= ph_peek_head(pp
->sleeps_heap
);
51 if (i
== 0 || next_send(&pp
->presses
[i
]) > now
)
53 if (ph_remove_head(pp
->sleeps_heap
, true) != i
)
54 signal_error_by_blinking();
55 *press
= pp
->presses
[i
];