/work/toxcore/events/group_topic_lock.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* SPDX-License-Identifier: GPL-3.0-or-later |
2 | | * Copyright © 2023-2024 The TokTok team. |
3 | | */ |
4 | | |
5 | | #include "events_alloc.h" |
6 | | |
7 | | #include <assert.h> |
8 | | |
9 | | #include "../bin_pack.h" |
10 | | #include "../bin_unpack.h" |
11 | | #include "../ccompat.h" |
12 | | #include "../mem.h" |
13 | | #include "../tox.h" |
14 | | #include "../tox_events.h" |
15 | | #include "../tox_pack.h" |
16 | | #include "../tox_unpack.h" |
17 | | |
18 | | |
19 | | /***************************************************** |
20 | | * |
21 | | * :: struct and accessors |
22 | | * |
23 | | *****************************************************/ |
24 | | |
25 | | |
26 | | struct Tox_Event_Group_Topic_Lock { |
27 | | uint32_t group_number; |
28 | | Tox_Group_Topic_Lock topic_lock; |
29 | | }; |
30 | | |
31 | | non_null() |
32 | | static void tox_event_group_topic_lock_set_group_number(Tox_Event_Group_Topic_Lock *group_topic_lock, |
33 | | uint32_t group_number) |
34 | 56 | { |
35 | 56 | assert(group_topic_lock != nullptr); |
36 | 56 | group_topic_lock->group_number = group_number; |
37 | 56 | } |
38 | | uint32_t tox_event_group_topic_lock_get_group_number(const Tox_Event_Group_Topic_Lock *group_topic_lock) |
39 | 8 | { |
40 | 8 | assert(group_topic_lock != nullptr); |
41 | 8 | return group_topic_lock->group_number; |
42 | 8 | } |
43 | | |
44 | | non_null() |
45 | | static void tox_event_group_topic_lock_set_topic_lock(Tox_Event_Group_Topic_Lock *group_topic_lock, |
46 | | Tox_Group_Topic_Lock topic_lock) |
47 | 56 | { |
48 | 56 | assert(group_topic_lock != nullptr); |
49 | 56 | group_topic_lock->topic_lock = topic_lock; |
50 | 56 | } |
51 | | Tox_Group_Topic_Lock tox_event_group_topic_lock_get_topic_lock(const Tox_Event_Group_Topic_Lock *group_topic_lock) |
52 | 8 | { |
53 | 8 | assert(group_topic_lock != nullptr); |
54 | 8 | return group_topic_lock->topic_lock; |
55 | 8 | } |
56 | | |
57 | | non_null() |
58 | | static void tox_event_group_topic_lock_construct(Tox_Event_Group_Topic_Lock *group_topic_lock) |
59 | 96 | { |
60 | 96 | *group_topic_lock = (Tox_Event_Group_Topic_Lock) { |
61 | 96 | 0 |
62 | 96 | }; |
63 | 96 | } |
64 | | non_null() |
65 | | static void tox_event_group_topic_lock_destruct(Tox_Event_Group_Topic_Lock *group_topic_lock, const Memory *mem) |
66 | 95 | { |
67 | 95 | return; |
68 | 95 | } |
69 | | |
70 | | bool tox_event_group_topic_lock_pack( |
71 | | const Tox_Event_Group_Topic_Lock *event, Bin_Pack *bp) |
72 | 50 | { |
73 | 50 | return bin_pack_array(bp, 2) |
74 | 50 | && bin_pack_u32(bp, event->group_number) |
75 | 50 | && tox_group_topic_lock_pack(event->topic_lock, bp); |
76 | 50 | } |
77 | | |
78 | | non_null() |
79 | | static bool tox_event_group_topic_lock_unpack_into( |
80 | | Tox_Event_Group_Topic_Lock *event, Bin_Unpack *bu) |
81 | 40 | { |
82 | 40 | assert(event != nullptr); |
83 | 40 | if (!bin_unpack_array_fixed(bu, 2, nullptr)) { |
84 | 1 | return false; |
85 | 1 | } |
86 | | |
87 | 39 | return bin_unpack_u32(bu, &event->group_number) |
88 | 39 | && tox_group_topic_lock_unpack(&event->topic_lock, bu); |
89 | 40 | } |
90 | | |
91 | | |
92 | | /***************************************************** |
93 | | * |
94 | | * :: new/free/add/get/size/unpack |
95 | | * |
96 | | *****************************************************/ |
97 | | |
98 | | const Tox_Event_Group_Topic_Lock *tox_event_get_group_topic_lock(const Tox_Event *event) |
99 | 0 | { |
100 | 0 | return event->type == TOX_EVENT_GROUP_TOPIC_LOCK ? event->data.group_topic_lock : nullptr; |
101 | 0 | } |
102 | | |
103 | | Tox_Event_Group_Topic_Lock *tox_event_group_topic_lock_new(const Memory *mem) |
104 | 98 | { |
105 | 98 | Tox_Event_Group_Topic_Lock *const group_topic_lock = |
106 | 98 | (Tox_Event_Group_Topic_Lock *)mem_alloc(mem, sizeof(Tox_Event_Group_Topic_Lock)); |
107 | | |
108 | 98 | if (group_topic_lock == nullptr) { |
109 | 2 | return nullptr; |
110 | 2 | } |
111 | | |
112 | 96 | tox_event_group_topic_lock_construct(group_topic_lock); |
113 | 96 | return group_topic_lock; |
114 | 98 | } |
115 | | |
116 | | void tox_event_group_topic_lock_free(Tox_Event_Group_Topic_Lock *group_topic_lock, const Memory *mem) |
117 | 96 | { |
118 | 96 | if (group_topic_lock != nullptr) { |
119 | 95 | tox_event_group_topic_lock_destruct(group_topic_lock, mem); |
120 | 95 | } |
121 | 96 | mem_delete(mem, group_topic_lock); |
122 | 96 | } |
123 | | |
124 | | non_null() |
125 | | static Tox_Event_Group_Topic_Lock *tox_events_add_group_topic_lock(Tox_Events *events, const Memory *mem) |
126 | 57 | { |
127 | 57 | Tox_Event_Group_Topic_Lock *const group_topic_lock = tox_event_group_topic_lock_new(mem); |
128 | | |
129 | 57 | if (group_topic_lock == nullptr) { |
130 | 1 | return nullptr; |
131 | 1 | } |
132 | | |
133 | 56 | Tox_Event event; |
134 | 56 | event.type = TOX_EVENT_GROUP_TOPIC_LOCK; |
135 | 56 | event.data.group_topic_lock = group_topic_lock; |
136 | | |
137 | 56 | tox_events_add(events, &event); |
138 | 56 | return group_topic_lock; |
139 | 57 | } |
140 | | |
141 | | bool tox_event_group_topic_lock_unpack( |
142 | | Tox_Event_Group_Topic_Lock **event, Bin_Unpack *bu, const Memory *mem) |
143 | 41 | { |
144 | 41 | assert(event != nullptr); |
145 | 41 | assert(*event == nullptr); |
146 | 41 | *event = tox_event_group_topic_lock_new(mem); |
147 | | |
148 | 41 | if (*event == nullptr) { |
149 | 1 | return false; |
150 | 1 | } |
151 | | |
152 | 40 | return tox_event_group_topic_lock_unpack_into(*event, bu); |
153 | 41 | } |
154 | | |
155 | | non_null() |
156 | | static Tox_Event_Group_Topic_Lock *tox_event_group_topic_lock_alloc(void *user_data) |
157 | 58 | { |
158 | 58 | Tox_Events_State *state = tox_events_alloc(user_data); |
159 | 58 | assert(state != nullptr); |
160 | | |
161 | 58 | if (state->events == nullptr) { |
162 | 1 | return nullptr; |
163 | 1 | } |
164 | | |
165 | 57 | Tox_Event_Group_Topic_Lock *group_topic_lock = tox_events_add_group_topic_lock(state->events, state->mem); |
166 | | |
167 | 57 | if (group_topic_lock == nullptr) { |
168 | 1 | state->error = TOX_ERR_EVENTS_ITERATE_MALLOC; |
169 | 1 | return nullptr; |
170 | 1 | } |
171 | | |
172 | 56 | return group_topic_lock; |
173 | 57 | } |
174 | | |
175 | | |
176 | | /***************************************************** |
177 | | * |
178 | | * :: event handler |
179 | | * |
180 | | *****************************************************/ |
181 | | |
182 | | |
183 | | void tox_events_handle_group_topic_lock(Tox *tox, uint32_t group_number, Tox_Group_Topic_Lock topic_lock, |
184 | | void *user_data) |
185 | 58 | { |
186 | 58 | Tox_Event_Group_Topic_Lock *group_topic_lock = tox_event_group_topic_lock_alloc(user_data); |
187 | | |
188 | 58 | if (group_topic_lock == nullptr) { |
189 | 2 | return; |
190 | 2 | } |
191 | | |
192 | 56 | tox_event_group_topic_lock_set_group_number(group_topic_lock, group_number); |
193 | 56 | tox_event_group_topic_lock_set_topic_lock(group_topic_lock, topic_lock); |
194 | 56 | } |