GNUnet 0.22.2
gnunet-service-messenger_basement.c
Go to the documentation of this file.
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2020--2024 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
27
28size_t
30{
31 const struct GNUNET_MESSENGER_ListTunnel *element;
32 size_t count;
33
34 GNUNET_assert (tunnels);
35
36 count = 0;
37
38 for (element = tunnels->head; element; element = element->next)
39 count++;
40
41 return count;
42}
43
44
47 size_t src,
48 size_t dst)
49{
50 if ((src + 1) % count == dst % count)
51 return GNUNET_YES;
52
53 return GNUNET_NO;
54}
55
56
59 size_t src,
60 size_t dst)
61{
62 if (GNUNET_YES == should_connect_tunnel_to (count, src, dst))
63 return GNUNET_YES;
64 if (GNUNET_YES == should_connect_tunnel_to (count, dst, src))
65 return GNUNET_YES;
66
67 return GNUNET_NO;
68}
enum GNUNET_GenericReturnValue should_connect_tunnel_to(size_t count, size_t src, size_t dst)
Returns GNUNET_YES or GNUNET_NO to determine if the peer at index src should or should not connect ou...
enum GNUNET_GenericReturnValue required_connection_between(size_t count, size_t src, size_t dst)
Returns GNUNET_YES or GNUNET_NO to determine if the peers of index src and index dst should be connec...
size_t count_of_tunnels(const struct GNUNET_MESSENGER_ListTunnels *tunnels)
Returns the count of peers in a list (typically from the basement of a room).
GNUNET_GenericReturnValue
Named constants for return values.
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
struct GNUNET_MESSENGER_ListTunnel * next
struct GNUNET_MESSENGER_ListTunnel * head