]>
git.ipfire.org Git - location/libloc.git/blob - src/as-list.c
2 libloc - A library to determine the location of someone on the Internet
4 Copyright (C) 2020 IPFire Development Team <info@ipfire.org>
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
21 #include <loc/as-list.h>
22 #include <loc/private.h>
28 struct loc_as
** elements
;
34 static int loc_as_list_grow(struct loc_as_list
* list
, size_t size
) {
35 DEBUG(list
->ctx
, "Growing AS list %p by %zu to %zu\n",
36 list
, size
, list
->elements_size
+ size
);
38 struct loc_as
** elements
= reallocarray(list
->elements
,
39 list
->elements_size
+ size
, sizeof(*list
->elements
));
43 list
->elements
= elements
;
44 list
->elements_size
+= size
;
49 LOC_EXPORT
int loc_as_list_new(struct loc_ctx
* ctx
,
50 struct loc_as_list
** list
) {
51 struct loc_as_list
* l
= calloc(1, sizeof(*l
));
55 l
->ctx
= loc_ref(ctx
);
58 DEBUG(l
->ctx
, "AS list allocated at %p\n", l
);
64 LOC_EXPORT
struct loc_as_list
* loc_as_list_ref(struct loc_as_list
* list
) {
70 static void loc_as_list_free(struct loc_as_list
* list
) {
71 DEBUG(list
->ctx
, "Releasing AS list at %p\n", list
);
73 loc_as_list_clear(list
);
79 LOC_EXPORT
struct loc_as_list
* loc_as_list_unref(struct loc_as_list
* list
) {
83 if (--list
->refcount
> 0)
86 loc_as_list_free(list
);
90 LOC_EXPORT
size_t loc_as_list_size(struct loc_as_list
* list
) {
94 LOC_EXPORT
int loc_as_list_empty(struct loc_as_list
* list
) {
95 return list
->size
== 0;
98 LOC_EXPORT
void loc_as_list_clear(struct loc_as_list
* list
) {
102 for (unsigned int i
= 0; i
< list
->size
; i
++)
103 loc_as_unref(list
->elements
[i
]);
105 free(list
->elements
);
106 list
->elements
= NULL
;
107 list
->elements_size
= 0;
112 LOC_EXPORT
struct loc_as
* loc_as_list_get(struct loc_as_list
* list
, size_t index
) {
114 if (index
>= list
->size
)
117 return loc_as_ref(list
->elements
[index
]);
120 LOC_EXPORT
int loc_as_list_append(
121 struct loc_as_list
* list
, struct loc_as
* as
) {
122 if (loc_as_list_contains(list
, as
))
125 // Check if we have space left
126 if (list
->size
>= list
->elements_size
) {
127 int r
= loc_as_list_grow(list
, 64);
132 DEBUG(list
->ctx
, "%p: Appending AS %p to list\n", list
, as
);
134 list
->elements
[list
->size
++] = loc_as_ref(as
);
139 LOC_EXPORT
int loc_as_list_contains(
140 struct loc_as_list
* list
, struct loc_as
* as
) {
141 for (unsigned int i
= 0; i
< list
->size
; i
++) {
142 if (loc_as_cmp(as
, list
->elements
[i
]) == 0)
149 LOC_EXPORT
int loc_as_list_contains_number(
150 struct loc_as_list
* list
, uint32_t number
) {
153 int r
= loc_as_new(list
->ctx
, &as
, number
);
157 r
= loc_as_list_contains(list
, as
);