Han-Wen Nienhuys | 3b34f63 | 2021-10-07 20:25:10 +0000 | [diff] [blame] | 1 | /* |
| 2 | Copyright 2020 Google LLC |
| 3 | |
| 4 | Use of this source code is governed by a BSD-style |
| 5 | license that can be found in the LICENSE file or at |
| 6 | https://developers.google.com/open-source/licenses/bsd |
| 7 | */ |
| 8 | |
| 9 | #ifndef PQ_H |
| 10 | #define PQ_H |
| 11 | |
| 12 | #include "record.h" |
| 13 | |
| 14 | struct pq_entry { |
Patrick Steinhardt | 5c11529 | 2024-03-04 11:48:47 +0100 | [diff] [blame] | 15 | size_t index; |
Patrick Steinhardt | bb2d6be | 2024-03-04 11:48:59 +0100 | [diff] [blame] | 16 | struct reftable_record *rec; |
Han-Wen Nienhuys | 3b34f63 | 2021-10-07 20:25:10 +0000 | [diff] [blame] | 17 | }; |
| 18 | |
| 19 | struct merged_iter_pqueue { |
| 20 | struct pq_entry *heap; |
| 21 | size_t len; |
| 22 | size_t cap; |
| 23 | }; |
| 24 | |
Han-Wen Nienhuys | 3b34f63 | 2021-10-07 20:25:10 +0000 | [diff] [blame] | 25 | void merged_iter_pqueue_check(struct merged_iter_pqueue pq); |
| 26 | struct pq_entry merged_iter_pqueue_remove(struct merged_iter_pqueue *pq); |
Elijah Conners | c18eecb | 2022-09-14 20:37:34 -0700 | [diff] [blame] | 27 | void merged_iter_pqueue_add(struct merged_iter_pqueue *pq, const struct pq_entry *e); |
Han-Wen Nienhuys | 3b34f63 | 2021-10-07 20:25:10 +0000 | [diff] [blame] | 28 | void merged_iter_pqueue_release(struct merged_iter_pqueue *pq); |
| 29 | int pq_less(struct pq_entry *a, struct pq_entry *b); |
| 30 | |
Patrick Steinhardt | f1bf54a | 2024-03-04 11:49:35 +0100 | [diff] [blame] | 31 | static inline struct pq_entry merged_iter_pqueue_top(struct merged_iter_pqueue pq) |
| 32 | { |
| 33 | return pq.heap[0]; |
| 34 | } |
| 35 | |
| 36 | static inline int merged_iter_pqueue_is_empty(struct merged_iter_pqueue pq) |
| 37 | { |
| 38 | return pq.len == 0; |
| 39 | } |
| 40 | |
Han-Wen Nienhuys | 3b34f63 | 2021-10-07 20:25:10 +0000 | [diff] [blame] | 41 | #endif |