]> jfr.im git - irc/evilnet/x3.git/blame - src/common.h
stage one, half ops support
[irc/evilnet/x3.git] / src / common.h
CommitLineData
d76ed9a9 1/* common.h - Common functions/includes
2 * Copyright 2000-2004 srvx Development Team
3 *
4 * This file is part of srvx.
5 *
6 * srvx is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program 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
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with srvx; if not, write to the Free Software Foundation,
18 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
19 */
20
21#ifndef COMMON_H
22#define COMMON_H
23
24#include "compat.h"
25#include "proto.h"
26
27#if !defined(HAVE_LOCALTIME_R) && !defined(__CYGWIN__)
28extern struct tm *localtime_r(const time_t *clock, struct tm *res);
29#elif defined(__CYGWIN__)
30# define localtime_r(clock, res) memcpy(res, localtime(clock), sizeof(struct tm));
31#endif
32
33#ifndef true
34#define true 1
35#endif
36
37#ifndef false
38#define false 0
39#endif
40
41#ifndef INADDR_NONE
42#define INADDR_NONE 0xffffffffL
43#endif
44#ifndef INADDR_LOOPBACK
45#define INADDR_LOOPBACK 0x7f000001L
46#endif
47
48#define ArrayLength(x) (sizeof(x)/sizeof(x[0]))
49#define safestrncpy(dest, src, len) do { char *d = (dest); const char *s = (src); size_t l = strlen(s)+1; if ((len) < l) l = (len); memmove(d, s, l); d[l-1] = 0; } while (0)
50
51#ifdef __GNUC__
52#define PRINTF_LIKE(M,N) __attribute__((format (printf, M, N)))
53#else
54#define PRINTF_LIKE(M,N)
55#endif
56
57#if __GNUC__ >= 2
58#define UNUSED_ARG(ARG) ARG __attribute__((unused))
59#elif defined(S_SPLINT_S)
60#define UNUSED_ARG(ARG) /*@unused@*/ ARG
61#define const /*@observer@*/ /*@temp@*/
62#else
63#define UNUSED_ARG(ARG) ARG
64#endif
65
66#if defined(WITH_MALLOC_DMALLOC)
67#define DMALLOC_FUNC_CHECK 1
68#include <string.h>
69#include <dmalloc.h>
70#elif defined(WITH_MALLOC_MPATROL)
71#include <string.h>
72#include <mpatrol.h>
73#elif defined(WITH_MALLOC_BOEHM_GC)
74#if !defined(NDEBUG)
75#define GC_DEBUG 1
76#endif
77#include <stdlib.h>
78#include <string.h>
79#include <gc/gc.h>
80#define malloc(n) GC_MALLOC(n)
81#define calloc(m,n) GC_MALLOC((m)*(n))
82#define realloc(p,n) GC_REALLOC((p),(n))
83#define free(p) GC_FREE(p)
84#undef HAVE_STRDUP
85#undef strdup
86#endif
87
88extern time_t now;
89extern int quit_services;
90extern struct log_type *MAIN_LOG;
91
92int create_socket_client(struct uplinkNode *target);
93void close_socket(void);
94
95typedef void (*exit_func_t)(void);
96void reg_exit_func(exit_func_t handler);
97void call_exit_funcs(void);
98
99const char *inttobase64(char *buf, unsigned int v, unsigned int count);
100unsigned long base64toint(const char *s, int count);
101int split_line(char *line, int irc_colon, int argv_size, char *argv[]);
102
103/* match_ircglobs(oldglob, newglob) returns non-zero if oldglob is a superset of newglob */
104#define match_ircglobs !mmatch
105int mmatch(const char *glob, const char *newglob);
106int match_ircglob(const char *text, const char *glob);
107int user_matches_glob(struct userNode *user, const char *glob, int include_nick);
108
109int is_ircmask(const char *text);
110int is_gline(const char *text);
111
112char *sanitize_ircmask(char *text);
113
114unsigned long ParseInterval(const char *interval);
115unsigned long ParseVolume(const char *volume);
116int parse_ipmask(const char *str, struct in_addr *addr, unsigned long *mask);
117#define MATCH_IPMASK(test, addr, mask) (((ntohl(test.s_addr) & mask) ^ (ntohl(addr.s_addr) & mask)) == 0)
118
119#define MD5_CRYPT_LENGTH 42
120/* buffer[] must be at least MD5_CRYPT_LENGTH bytes long */
121const char *cryptpass(const char *pass, char buffer[]);
122int checkpass(const char *pass, const char *crypt);
123
124int split_ircmask(char *text, char **nick, char **ident, char **host);
125char *unsplit_string(char *set[], unsigned int max, char *dest);
126
127#define DECLARE_LIST(STRUCTNAME,ITEMTYPE) struct STRUCTNAME {\
128 unsigned int used, size;\
129 ITEMTYPE *list;\
130};\
131void STRUCTNAME##_init(struct STRUCTNAME *list);\
132void STRUCTNAME##_append(struct STRUCTNAME *list, ITEMTYPE new_item);\
133int STRUCTNAME##_remove(struct STRUCTNAME *list, ITEMTYPE new_item);\
134void STRUCTNAME##_clean(struct STRUCTNAME *list)
135
136#define DEFINE_LIST(STRUCTNAME,ITEMTYPE) \
137void STRUCTNAME##_init(struct STRUCTNAME *list) {\
138 list->used = 0;\
139 list->size = 8;\
140 list->list = malloc(list->size*sizeof(list->list[0]));\
141}\
142void STRUCTNAME##_append(struct STRUCTNAME *list, ITEMTYPE new_item) {\
143 if (list->used == list->size) {\
144 list->size = list->size ? (list->size << 1) : 4;\
145 list->list = realloc(list->list, list->size*sizeof(list->list[0]));\
146 }\
147 list->list[list->used++] = new_item;\
148}\
149int STRUCTNAME##_remove(struct STRUCTNAME *list, ITEMTYPE new_item) {\
150 unsigned int n, found;\
151 for (found=n=0; n<list->used; n++) {\
152 if (list->list[n] == new_item) {\
153 memmove(list->list+n, list->list+n+1, (list->used-n-1)*sizeof(list->list[n]));\
154 found = 1;\
155 list->used--;\
156 }\
157 }\
158 return found;\
159}\
160void STRUCTNAME##_clean(struct STRUCTNAME *list) {\
161 list->used = list->size = 0;\
162 free(list->list);\
163}
164
165/* The longest string that is likely to be produced in English is "10
166 * minutes, and 10 seconds" (27 characters). Other languages will
167 * vary, so there's plenty of leeway.
168 */
169#define INTERVALLEN 50
170
171struct handle_info;
172char *intervalString(char *output, time_t interval, struct handle_info *hi);
173int getipbyname(const char *name, unsigned long *ip);
174int set_policer_param(const char *param, void *data, void *extra);
175const char *strtab(unsigned int ii);
176
177void tools_init(void);
178void tools_cleanup(void);
179
180int irccasecmp(const char *stra, const char *strb);
181int ircncasecmp(const char *stra, const char *strb, unsigned int len);
182const char *irccasestr(const char *haystack, const char *needle);
183
184DECLARE_LIST(string_buffer, char);
185void string_buffer_append_string(struct string_buffer *buf, const char *tail);
186void string_buffer_append_substring(struct string_buffer *buf, const char *tail, unsigned int len);
187void string_buffer_append_vprintf(struct string_buffer *buf, const char *fmt, va_list args);
188void string_buffer_append_printf(struct string_buffer *buf, const char *fmt, ...);
189void string_buffer_replace(struct string_buffer *buf, unsigned int from, unsigned int len, const char *repl);
190
191#define enabled_string(string) (!irccasecmp((string), "on") || !strcmp((string), "1") || !irccasecmp((string), "enabled"))
192#define disabled_string(string) (!irccasecmp((string), "off") || !strcmp((string), "0") || !irccasecmp((string), "disabled"))
193#define true_string(string) (!irccasecmp((string), "true") || !strcmp((string), "1") || !irccasecmp((string), "yes"))
194#define false_string(string) (!irccasecmp((string), "false") || !strcmp((string), "0") || !irccasecmp((string), "no"))
195
196#endif /* ifdef COMMON_H */