Coverage Report

Created: 2024-01-26 01:52

/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
}