/[cvs]/eggdrop1.4/src/eggdrop.h
ViewVC logotype

Annotation of /eggdrop1.4/src/eggdrop.h

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.6 - (hide annotations) (download) (as text)
Sun Sep 26 23:14:24 1999 UTC (20 years ago) by guppy
Branch: MAIN
Changes since 1.5: +3 -0 lines
File MIME type: text/x-csrc
lots more patches

1 segfault 1.1 /*
2     * EGGDROP compile-time settings
3     *
4     * IF YOU ALTER THIS FILE, YOU NEED TO RECOMPILE THE BOT.
5     */
6     /*
7     * This file is part of the eggdrop source code
8     * copyright (c) 1997 Robey Pointer
9     * and is distributed according to the GNU general public license.
10     * For full details, read the top of 'main.c' or the file called
11     * COPYING that was distributed with this code.
12     */
13    
14     #ifndef _H_EGGDROP
15     #define _H_EGGDROP
16    
17     /*
18     * if you're *only* going to link to new version bots (1.3.0 or higher)
19     * then you can safely define this
20     */
21    
22     #undef NO_OLD_BOTNET
23    
24     /***********************************************************************/
25     /***** the 'configure' script should make this next part automatic *****/
26     /***********************************************************************/
27    
28     /*
29     * define the maximum length a handle on the bot can be.
30     * (standard is 9 characters long)
31     * (DO NOT MAKE THIS VALUE LESS THAN 9 UNLESS YOU WANT TROUBLE!)
32     * (beware that using lengths over 9 chars is 'non-standard' and if you
33     * wish to link to other bots, they _must_ both have the same maximum
34     * handle length)
35     */
36    
37     #define HANDLEN 9 /* valid values 9->NICKMAX */
38    
39     /* handy maximum string lengths */
40     #define NICKMAX 15 /* valid values HANDLEN->32 */
41     #define UHOSTLEN 161 /* reasonable, i think? */
42     #define DIRLEN 256 /* paranoia */
43     #define MAX_LOG_LINE (767) /* for misc.c/putlog() <cybah> */
44    
45     #define NICKLEN NICKMAX + 1
46     #define NOTENAMELEN ((HANDLEN * 2) + 1)
47 guppy 1.3
48     #define LANGDIR "./language" /* language file directory */
49    
50 segfault 1.1 /* have to use a weird way to make the compiler error out cos not all
51     * compilers support #error or error */
52     #if !HAVE_VSPRINTF
53     #include "error_you_need_vsprintf_to_compile_eggdrop"
54     #endif
55    
56     #if HAVE_UNISTD_H
57     #include <unistd.h>
58     #endif
59    
60     #ifndef STATIC
61     #if (!defined(MODULES_OK) || !defined(HAVE_DLOPEN)) && !defined(HPUX_HACKS)
62     #include "you_can't_compile_with_module_support_on_this_system_try_make_static"
63     #endif
64     #endif
65    
66     #if !defined(STDC_HEADERS)
67     #include "you_need_to_upgrade_your_compiler_to_a_standard_c_one_mate!"
68     #endif
69    
70     #if (NICKMAX < 9) || (NICKMAX > 32)
71     #include "invalid NIXMAX value"
72     #endif
73    
74     #if (HANDLEN < 9) || (HANDLEN > 32)
75     #include "invalid HANDLEN value"
76     #endif
77    
78     #if HANDLEN > NICKMAX
79     #include "HANDLEN MUST BE <= NICKMAX"
80     #endif
81    
82     /* almost every module needs some sort of time thingy, so... */
83     #if TIME_WITH_SYS_TIME
84     #include <sys/time.h>
85     #include <time.h>
86     #else
87     #if HAVE_SYS_TIME_H
88     #include <sys/time.h>
89     #else
90     #include <time.h>
91     #endif
92     #endif
93    
94     #if !HAVE_SRANDOM
95     #define srandom(x) srand(x)
96     #endif
97    
98     #if !HAVE_RANDOM
99     #define random() (rand()/16)
100     #endif
101    
102     #if !HAVE_SIGACTION /* old "weird signals" */
103     #define sigaction sigvec
104     #ifndef sa_handler
105     #define sa_handler sv_handler
106     #define sa_mask sv_mask
107     #define sa_flags sv_flags
108     #endif
109     #endif
110    
111     #if !HAVE_SIGEMPTYSET
112     /* and they probably won't have sigemptyset, dammit */
113     #define sigemptyset(x) ((*(int *)(x))=0)
114     #endif
115    
116     /* handy aliases for memory tracking and core dumps */
117    
118     #define nmalloc(x) n_malloc((x),__FILE__,__LINE__)
119     #define nrealloc(x,y) n_realloc((x),(y),__FILE__,__LINE__)
120     #define nfree(x) n_free((x),__FILE__,__LINE__)
121    
122     #define context { cx_ptr=((cx_ptr + 1) & 15); \
123     strcpy(cx_file[cx_ptr],__FILE__); \
124     cx_line[cx_ptr]=__LINE__; \
125     cx_note[cx_ptr][0] = 0; }
126     /* It's usefull to track variables too <cybah> */
127     #define contextnote(string) { cx_ptr=((cx_ptr + 1) & 15); \
128     strncpy(cx_file[cx_ptr],__FILE__,29); \
129     cx_file[cx_ptr][29] = 0; \
130     cx_line[cx_ptr]=__LINE__; \
131     strncpy(cx_note[cx_ptr],string,255); \
132     cx_note[cx_ptr][255] = 0; }
133     /* move these here, makes more sense to me :) */
134     extern int cx_line[16];
135     extern char cx_file[16][30];
136     extern char cx_note[16][256];
137     extern int cx_ptr;
138    
139     #undef malloc
140     #undef free
141     #define malloc(x) dont_use_old_malloc(x)
142     #define free(x) dont_use_old_free(x)
143    
144     /* IP type */
145     #if SIZEOF_INT==4
146     typedef unsigned int IP;
147    
148     #else
149     #if SIZEOF_LONG==4
150     typedef unsigned long IP;
151    
152     #else
153     #include "cant/find/32bit/type"
154     #endif
155     #endif
156    
157     /* macro for simplifying patches */
158     #define PATCH(str) { \
159     char *p=strchr(egg_version,'+'); \
160     if (p==NULL) p=&egg_version[strlen(egg_version)]; \
161     sprintf(p,"+%s",str); \
162     egg_numver++; \
163     sprintf(&egg_xtra[strlen(egg_xtra)]," %s",str); \
164     }
165    
166     #define debug0(x) putlog(LOG_DEBUG,"*",x)
167     #define debug1(x,a1) putlog(LOG_DEBUG,"*",x,a1)
168     #define debug2(x,a1,a2) putlog(LOG_DEBUG,"*",x,a1,a2)
169     #define debug3(x,a1,a2,a3) putlog(LOG_DEBUG,"*",x,a1,a2,a3)
170     #define debug4(x,a1,a2,a3,a4) putlog(LOG_DEBUG,"*",x,a1,a2,a3,a4)
171    
172     /***********************************************************************/
173    
174     /* public structure for the listening port map */
175     struct portmap {
176     int realport;
177     int mappedto;
178     struct portmap *next;
179     };
180    
181     /* public structure of all the dcc connections */
182     struct dcc_table {
183     char *name;
184     int flags;
185     void (*eof) (int);
186     void (*activity) (int, char *, int);
187     int *timeout_val;
188     void (*timeout) ();
189     void (*display) (int, char *);
190     int (*expmem) (void *);
191     void (*kill) (int, void *);
192     void (*output) (int, char *, void *);
193     };
194    
195     struct userrec;
196    
197     struct dcc_t {
198     long sock; /* this should be a long to keep 64-bit machines sane */
199     IP addr;
200     unsigned int port;
201     struct userrec *user;
202     char nick[NICKLEN];
203     char host[UHOSTLEN + 1]; /* extra safety char ;) */
204     struct dcc_table *type;
205     time_t timeval; /* use for any timing stuff
206     * - this is used for timeout checking */
207     unsigned long status; /* A LOT of dcc types have status thingos, this
208     * makes it more avaliabe */
209     union {
210     struct chat_info *chat;
211     struct file_info *file;
212     struct edit_info *edit;
213     struct xfer_info *xfer;
214     struct bot_info *bot;
215     struct relay_info *relay;
216     struct script_info *script;
217     int ident_sock;
218     void *other;
219     } u; /* special use depending on type */
220     };
221    
222     struct chat_info {
223     char *away; /* non-NULL if user is away */
224     int msgs_per_sec; /* used to stop flooding */
225     int con_flags; /* with console: what to show */
226     int strip_flags; /* what codes to strip (b,r,u,c,a,g,*) */
227     char con_chan[81]; /* with console: what channel to view */
228     int channel; /* 0=party line, -1=off */
229     struct msgq *buffer; /* a buffer of outgoing lines (for .page cmd) */
230     int max_line; /* maximum lines at once */
231     int line_count; /* number of lines sent since last page */
232     int current_lines; /* number of lines total stored */
233     char *su_nick;
234     };
235    
236     struct file_info {
237     struct chat_info *chat;
238     char dir[161];
239     };
240    
241     struct xfer_info {
242     char filename[121];
243     char dir[121]; /* used when uploads go to the current dir */
244     unsigned long length;
245     unsigned long acked;
246     char buf[4]; /* you only need 5 bytes! */
247     unsigned char sofar; /* how much of the byte count received */
248     char from[NICKLEN]; /* [GET] user who offered the file */
249     FILE *f; /* pointer to file being sent/received */
250     };
251    
252     struct bot_info {
253     char version[121]; /* channel/version info */
254     char linker[NOTENAMELEN + 1]; /* who requested this link */
255     int numver;
256     int port; /* base port */
257     };
258    
259     struct relay_info {
260     struct chat_info *chat;
261     int sock;
262     int port;
263     int old_status;
264     };
265    
266     struct script_info {
267     struct dcc_table *type;
268     union {
269     struct chat_info *chat;
270     struct file_info *file;
271     void *other;
272     } u;
273     char command[121];
274     };
275    
276     /* flags about dcc types */
277     #define DCT_CHAT 0x00000001 /* this dcc type receives botnet chatter */
278     #define DCT_MASTER 0x00000002 /* received master chatter */
279     #define DCT_SHOWWHO 0x00000004 /* show the user in .who */
280     #define DCT_REMOTEWHO 0x00000008 /* show in remote who */
281     #define DCT_VALIDIDX 0x00000010 /* valid idx for outputting to in tcl */
282     #define DCT_SIMUL 0x00000020 /* can be tcl_simul'd */
283     #define DCT_CANBOOT 0x00000040 /* can be booted */
284     #define DCT_GETNOTES DCT_CHAT /* can receive notes */
285     #define DCT_FILES 0x00000080 /* gratuitous hack ;) */
286     #define DCT_FORKTYPE 0x00000100 /* a forking type */
287     #define DCT_BOT 0x00000200 /* a bot connection of some sort... */
288     #define DCT_FILETRAN 0x00000400 /* a file transfer of some sort */
289     #define DCT_FILESEND 0x00000800 /* a sending file transfer, getting = !this */
290     #define DCT_LISTEN 0x00001000 /* a listening port of some sort */
291    
292     /* for dcc chat & files: */
293     #define STAT_ECHO 1 /* echo commands back? */
294     #define STAT_DENY 2 /* bad username (ignore password & deny access) */
295     /*#define STAT_XFER 4 has 'x' flag on chat line */
296     #define STAT_CHAT 8 /* in file-system but may return */
297     #define STAT_TELNET 16 /* connected via telnet */
298     #define STAT_PARTY 32 /* only on party line via 'p' flag */
299     #define STAT_BOTONLY 64 /* telnet on bots-only connect */
300     #define STAT_USRONLY 128 /* telnet on users-only connect */
301     #define STAT_PAGE 256 /* page output to the user */
302    
303     /* for stripping out mIRC codes */
304     #define STRIP_COLOR 1 /* remove mIRC color codes */
305     #define STRIP_BOLD 2 /* remove bold codes */
306     #define STRIP_REV 4 /* remove reverse video codes */
307     #define STRIP_UNDER 8 /* remove underline codes */
308     #define STRIP_ANSI 16 /* remove ALL ansi codes */
309     #define STRIP_BELLS 32 /* remote ctrl-g's */
310     #define STRIP_ALL 63 /* remove every damn thing! */
311    
312     /* for dcc bot links: */
313     #define STAT_PINGED 0x01 /* waiting for ping to return */
314     #define STAT_SHARE 0x02 /* sharing user data with the bot */
315     #define STAT_CALLED 0x04 /* this bot called me */
316     #define STAT_OFFERED 0x08 /* offered her the user file */
317     #define STAT_SENDING 0x10 /* in the process of sending a user list */
318     #define STAT_GETTING 0x20 /* in the process of getting a user list */
319     #define STAT_WARNED 0x40 /* warned him about unleaflike behavior */
320     #define STAT_LEAF 0x80 /* this bot is a leaf only */
321     #define STAT_LINKING 0x100 /* the bot is currently going through the
322     * linking stage */
323     #define STAT_AGGRESSIVE 0x200 /* aggressively sharing with this bot */
324    
325     /* chan & global */
326     #define FLOOD_PRIVMSG 0
327     #define FLOOD_NOTICE 1
328     #define FLOOD_CTCP 2
329     #define FLOOD_NICK 3
330     #define FLOOD_JOIN 4
331     #define FLOOD_KICK 5
332     #define FLOOD_DEOP 6
333     #define FLOOD_CHAN_MAX 7
334     #define FLOOD_GLOBAL_MAX 3
335    
336     /* for local console: */
337     #define STDIN 0
338     #define STDOUT 1
339     #define STDERR 2
340    
341     /* structure for internal logs */
342     typedef struct {
343     char *filename;
344     unsigned int mask; /* what to send to this log */
345     char *chname; /* which channel */
346     char szLast[MAX_LOG_LINE + 1]; /* for 'Last message repeated n times'
347     * stuff in misc.c/putlog() <cybah> */
348     int Repeats; /* number of times szLast has been repeated */
349 guppy 1.6 unsigned int flags; /* other flags <rtc> */
350 segfault 1.1 FILE *f; /* existing file */
351     } log_t;
352    
353     /* logfile display flags */
354     #define LOG_MSGS 0x000001 /* m msgs/notice/ctcps */
355     #define LOG_PUBLIC 0x000002 /* p public msg/notice/ctcps */
356     #define LOG_JOIN 0x000004 /* j channel joins/parts/etc */
357     #define LOG_MODES 0x000008 /* k mode changes/kicks/bans */
358     #define LOG_CMDS 0x000010 /* c user dcc or msg commands */
359     #define LOG_MISC 0x000020 /* o other misc bot things */
360     #define LOG_BOTS 0x000040 /* b bot notices */
361     #define LOG_RAW 0x000080 /* r raw server stuff coming in */
362     #define LOG_FILES 0x000100 /* x file transfer commands and stats */
363     #define LOG_LEV1 0x000200 /* 1 user log level */
364     #define LOG_LEV2 0x000400 /* 2 user log level */
365     #define LOG_LEV3 0x000800 /* 3 user log level */
366     #define LOG_LEV4 0x001000 /* 4 user log level */
367     #define LOG_LEV5 0x002000 /* 5 user log level */
368     #define LOG_LEV6 0x004000 /* 6 user log level */
369     #define LOG_LEV7 0x008000 /* 7 user log level */
370     #define LOG_LEV8 0x010000 /* 8 user log level */
371     #define LOG_SERV 0x020000 /* s server information */
372     #define LOG_DEBUG 0x040000 /* d debug */
373     #define LOG_WALL 0x080000 /* w wallops */
374     #define LOG_SRVOUT 0x100000 /* v server output */
375     #define LOG_BOTNET 0x200000 /* t botnet traffic */
376     #define LOG_BOTSHARE 0x400000 /* h share traffic */
377     #define LOG_ALL 0x7fffff /* (dump to all logfiles) */
378 guppy 1.6 /* internal logfile flags */
379     #define LF_EXPIRING 0x000001 /* Logfile will be closed soon */
380 segfault 1.1
381     #define FILEDB_HIDE 1
382     #define FILEDB_UNHIDE 2
383     #define FILEDB_SHARE 3
384     #define FILEDB_UNSHARE 4
385    
386     /* socket flags: */
387     #define SOCK_UNUSED 0x01 /* empty socket */
388     #define SOCK_BINARY 0x02 /* do not buffer input */
389     #define SOCK_LISTEN 0x04 /* listening port */
390     #define SOCK_CONNECT 0x08 /* connection attempt */
391     #define SOCK_NONSOCK 0x10 /* used for file i/o on debug */
392     #define SOCK_STRONGCONN 0x20 /* don't report success until sure */
393     #define SOCK_EOFD 0x40 /* it EOF'd recently during a write */
394 poptix 1.2 #define SOCK_PROXYWAIT 0x80 /* waiting for SOCKS traversal */
395 segfault 1.1
396     /* fake idx's for dprintf - these should be ridiculously large +ve nums */
397     #define DP_STDOUT 0x7FF1
398     #define DP_LOG 0x7FF2
399     #define DP_SERVER 0x7FF3
400     #define DP_HELP 0x7FF4
401     #define DP_STDERR 0x7FF5
402     #define DP_MODE 0x7FF6
403    
404     #define NORMAL 0
405     #define QUICK 1
406    
407     /* return codes for add_note */
408     #define NOTE_ERROR 0 /* error */
409     #define NOTE_OK 1 /* success */
410     #define NOTE_STORED 2 /* not online; stored */
411     #define NOTE_FULL 3 /* too many notes stored */
412     #define NOTE_TCL 4 /* tcl binding caught it */
413     #define NOTE_AWAY 5 /* away; stored */
414     #define NOTE_FWD 6 /* away; forwarded */
415 poptix 1.4 #define NOTE_REJECT 7 /* ignore mask matched */
416 segfault 1.1
417     #define STR_PROTECT 2
418     #define STR_DIR 1
419    
420     #define HELP_DCC 1
421     #define HELP_TEXT 2
422     #define HELP_IRC 16
423    
424     /* it's used in so many places, let's put it here */
425     typedef int (*Function) ();
426    
427     /* this is used by the net module to keep track of sockets and what's
428     * queued on them */
429     typedef struct {
430     int sock;
431     char flags;
432     char *inbuf;
433     char *outbuf;
434     unsigned long outbuflen; /* outbuf could be binary data */
435     } sock_list;
436    
437     #endif

webmaster@eggheads.org
ViewVC Help
Powered by ViewVC 1.1.23