1 | /* |
1 | /* |
2 | * static char *rcsid_global_h = |
|
|
3 | * "$Id: global.h,v 1.11 2006/09/03 07:57:56 root Exp $"; |
|
|
4 | */ |
|
|
5 | |
|
|
6 | /* |
|
|
7 | CrossFire, A Multiplayer game for X-windows |
2 | * CrossFire, A Multiplayer game for X-windows |
8 | |
3 | * |
|
|
4 | * Copyright (C) 2005, 2006, 2007 Marc Lehmann & Crossfire+ Development Team |
9 | Copyright (C) 2002 Mark Wedel & Crossfire Development Team |
5 | * Copyright (C) 2002 Mark Wedel & Crossfire Development Team |
10 | Copyright (C) 1992 Frank Tore Johansen |
6 | * Copyright (C) 1992 Frank Tore Johansen |
11 | |
7 | * |
12 | This program is free software; you can redistribute it and/or modify |
8 | * This program is free software; you can redistribute it and/or modify |
13 | it under the terms of the GNU General Public License as published by |
9 | * it under the terms of the GNU General Public License as published by |
14 | the Free Software Foundation; either version 2 of the License, or |
10 | * the Free Software Foundation; either version 2 of the License, or |
15 | (at your option) any later version. |
11 | * (at your option) any later version. |
16 | |
12 | * |
17 | This program is distributed in the hope that it will be useful, |
13 | * This program is distributed in the hope that it will be useful, |
18 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
19 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
20 | GNU General Public License for more details. |
16 | * GNU General Public License for more details. |
21 | |
17 | * |
22 | You should have received a copy of the GNU General Public License |
18 | * You should have received a copy of the GNU General Public License |
23 | along with this program; if not, write to the Free Software |
19 | * along with this program; if not, write to the Free Software |
24 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
20 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
25 | |
21 | * |
26 | The author can be reached via e-mail to crossfire-devel@real-time.com |
22 | * The author can be reached via e-mail to crossfire@schmorp.de |
27 | */ |
23 | */ |
28 | |
24 | |
29 | #ifndef GLOBAL_H |
25 | #ifndef GLOBAL_H |
30 | #define GLOBAL_H |
26 | #define GLOBAL_H |
|
|
27 | |
|
|
28 | //#define _GLIBCXX_CONCEPT_CHECKS |
31 | |
29 | |
32 | #ifndef EXTERN |
30 | #ifndef EXTERN |
33 | #define EXTERN extern |
31 | #define EXTERN extern |
34 | #endif |
32 | #endif |
35 | |
33 | |
36 | #include "includes.h" |
34 | #include "includes.h" |
37 | |
35 | |
|
|
36 | #include "config.h" |
|
|
37 | #include "define.h" |
|
|
38 | #include "logger.h" |
38 | |
39 | |
39 | /* Type defines for specific signed/unsigned variables of a certain number |
40 | #ifndef TRUE |
40 | * of bits. Not really used anyplace, but if a certain number of bits |
41 | #define TRUE 1 |
41 | * is required, these type defines should then be used. This will make |
|
|
42 | * porting to systems that have different sized data types easier. |
|
|
43 | * |
|
|
44 | * Note: The type defines should just mean that the data type has at |
|
|
45 | * least that many bits. if a uint16 is actually 32 bits, no big deal, |
|
|
46 | * it is just a waste of space. |
|
|
47 | * |
|
|
48 | * Note2: When using something that is normally stored in a character |
|
|
49 | * (ie strings), don't use the uint8/sint8 typdefs, use 'char' instead. |
|
|
50 | * The signedness for char is probably not universal, and using char |
|
|
51 | * will probably be more portable than sint8/unit8 |
|
|
52 | */ |
|
|
53 | |
|
|
54 | |
|
|
55 | typedef unsigned int uint32; |
|
|
56 | |
|
|
57 | #ifndef UINT32_MAX |
|
|
58 | #define UINT32_MAX 4294967295U |
|
|
59 | #endif |
42 | #endif |
60 | |
43 | |
61 | typedef signed int sint32; |
44 | #ifndef FALSE |
62 | #define SINT32_MAX 2147483647 |
45 | #define FALSE 0 |
63 | |
|
|
64 | typedef unsigned short uint16; |
|
|
65 | #ifndef UINT16_MAX |
|
|
66 | #define UINT16_MAX 65535 |
|
|
67 | #endif |
46 | #endif |
68 | |
47 | |
69 | typedef signed short sint16; |
48 | // used only for tagging structure members so scripting languages |
70 | #define SINT16_MAX 32767 |
49 | // can easily parse the include files. |
71 | |
50 | #define INTERFACE_CLASS(name) |
72 | typedef unsigned char uint8; |
51 | #define ACC(meta,member) member |
73 | #ifndef UINT8_MAX |
52 | #define MTH |
74 | #define UINT8_MAX 255 |
|
|
75 | #endif |
|
|
76 | |
|
|
77 | typedef signed char sint8; |
|
|
78 | #define SINT8_MAX 127 |
|
|
79 | |
|
|
80 | |
|
|
81 | typedef unsigned short Fontindex; |
|
|
82 | |
|
|
83 | #ifdef WIN32 |
|
|
84 | /* Python plugin stuff defines SIZEOF_LONG_LONG as 8, and besides __int64 is a 64b type on MSVC... |
|
|
85 | * So let's force the typedef */ |
|
|
86 | typedef unsigned __int64 uint64; |
|
|
87 | typedef signed __int64 sint64; |
|
|
88 | /* Needed for experience */ |
|
|
89 | #define atoll _atoi64 |
|
|
90 | |
|
|
91 | /* To reduce number of warnings */ |
|
|
92 | #pragma warning( disable: 4244 ) /* conversion from 'xxx' to 'yyy', possible loss of data */ |
|
|
93 | #pragma warning( disable: 4305 ) /* initializing float f = 0.05; instead of f = 0.05f; */ |
|
|
94 | |
|
|
95 | #else /* WIN32 */ |
|
|
96 | |
|
|
97 | #if SIZEOF_LONG == 8 |
|
|
98 | typedef unsigned long uint64; |
|
|
99 | typedef signed long sint64; |
|
|
100 | #elif SIZEOF_LONG_LONG == 8 |
|
|
101 | typedef unsigned long long uint64; |
|
|
102 | typedef signed long long sint64; |
|
|
103 | #else |
|
|
104 | #error do not know how to get a 64 bit value on this system. |
|
|
105 | #error correct and send mail to crossfire-devel on how to do this |
|
|
106 | #endif |
|
|
107 | |
|
|
108 | #endif |
|
|
109 | |
|
|
110 | #include <vector> |
|
|
111 | |
53 | |
112 | #include "keyword.h" |
54 | #include "keyword.h" |
113 | #include "traits.h" |
55 | #include "traits.h" |
114 | #include "dynbuf.h" |
56 | #include "dynbuf.h" |
|
|
57 | #include "util.h" |
115 | #include "shstr.h" |
58 | #include "shstr.h" |
116 | #include "util.h" |
|
|
117 | |
59 | |
118 | /* This blob, in this order, is needed to actually define maps */ |
60 | /* This blob, in this order, is needed to actually define maps */ |
119 | #include "face.h" |
61 | #include "face.h" |
120 | /* Include the basic defines from spells.h */ |
62 | |
|
|
63 | #include "spells.h" |
|
|
64 | |
121 | #include "attack.h" /* needs to be before material.h */ |
65 | #include "attack.h" /* needs to be before material.h */ |
122 | #include "material.h" |
66 | #include "material.h" |
123 | #include "living.h" |
67 | #include "living.h" |
124 | #include "object.h" |
68 | #include "object.h" |
125 | #include "map.h" |
69 | #include "map.h" |
126 | #include "tod.h" |
70 | #include "tod.h" |
127 | |
71 | |
128 | #include "skills.h" |
72 | #include "skills.h" |
129 | |
73 | |
130 | /* Pull in the socket structure - used in the player structure */ |
74 | /* Pull in the socket structure - used in the player structure */ |
131 | #include "newserver.h" |
75 | #include "network.h" |
|
|
76 | #include "client.h" |
132 | |
77 | |
133 | /* Pull in the player structure */ |
78 | /* Pull in the player structure */ |
134 | #include "player.h" |
79 | #include "player.h" |
135 | |
80 | |
136 | /* pull in treasure structure */ |
81 | /* pull in treasure structure */ |
… | |
… | |
142 | #include "book.h" |
87 | #include "book.h" |
143 | /* |
88 | /* |
144 | * So far only used when dealing with artifacts. |
89 | * So far only used when dealing with artifacts. |
145 | * (now used by alchemy and other code too. Nov 95 b.t). |
90 | * (now used by alchemy and other code too. Nov 95 b.t). |
146 | */ |
91 | */ |
147 | typedef struct linked_char { |
92 | struct linked_char |
|
|
93 | { |
148 | shstr name; |
94 | shstr name; |
149 | struct linked_char *next; |
95 | struct linked_char *next; |
150 | } linked_char; |
96 | }; |
151 | |
|
|
152 | |
97 | |
153 | /* Pull in artifacts */ |
98 | /* Pull in artifacts */ |
154 | #include "artifact.h" |
99 | #include "artifact.h" |
155 | |
100 | |
156 | /* Now for gods */ |
101 | /* Now for gods */ |
… | |
… | |
159 | /* Now for races */ |
104 | /* Now for races */ |
160 | #include "race.h" |
105 | #include "race.h" |
161 | |
106 | |
162 | /* Now for recipe/alchemy */ |
107 | /* Now for recipe/alchemy */ |
163 | #include "recipe.h" |
108 | #include "recipe.h" |
164 | |
|
|
165 | /* Now for spells */ |
|
|
166 | #include "spells.h" |
|
|
167 | |
109 | |
168 | #include "funcpoint.h" |
110 | #include "funcpoint.h" |
169 | |
111 | |
170 | /***************************************************************************** |
112 | /***************************************************************************** |
171 | * GLOBAL VARIABLES: * |
113 | * GLOBAL VARIABLES: * |
172 | *****************************************************************************/ |
114 | *****************************************************************************/ |
173 | |
115 | |
174 | extern New_Face *new_faces; |
|
|
175 | |
|
|
176 | /* |
116 | /* |
177 | * These are the beginnings of linked lists: |
117 | * These are the beginnings of linked lists: |
178 | */ |
118 | */ |
179 | EXTERN player *first_player; |
|
|
180 | EXTERN mapstruct *first_map; |
|
|
181 | EXTERN region *first_region; |
|
|
182 | EXTERN treasurelist *first_treasurelist; |
|
|
183 | EXTERN artifactlist *first_artifactlist; |
119 | EXTERN artifactlist *first_artifactlist; |
184 | EXTERN archetype *first_archetype; |
120 | EXTERN archetype *first_archetype; |
185 | EXTERN objectlink *first_friendly_object; /* Objects monsters will go after */ |
121 | EXTERN objectlink *first_friendly_object; /* Objects monsters will go after */ |
186 | EXTERN godlink *first_god; |
122 | EXTERN godlink *first_god; |
187 | EXTERN racelink *first_race; |
123 | EXTERN racelink *first_race; |
188 | |
124 | |
189 | /* |
125 | /* |
190 | * The editor uses these (will get them out of here later): |
|
|
191 | */ |
|
|
192 | |
|
|
193 | EXTERN long editor; /* if true, edit maps instead of playing (almost obsolete) */ |
|
|
194 | |
|
|
195 | /* |
|
|
196 | * Variables set by different flags (see init.c): |
126 | * Variables set by different flags (see init.c): |
197 | */ |
127 | */ |
198 | |
128 | |
199 | EXTERN long warn_archetypes; /* If true, write warnings when failing */ |
|
|
200 | /* to find archetypes when loading from file */ |
|
|
201 | EXTERN long init_done; /* Ignores signals until init_done is true */ |
129 | EXTERN bool init_done; /* Ignores signals until init_done is true */ |
202 | EXTERN long trying_emergency_save; /* True when emergency_save() is reached */ |
130 | EXTERN bool in_cleanup; /* True when cleanup() is reached */ |
203 | EXTERN long nroferrors; /* If it exceeds MAX_ERRORS, call fatal() */ |
|
|
204 | |
131 | |
205 | extern long pticks; /* used by various function to determine */ |
132 | extern long pticks; /* used by various function to determine */ |
206 | /* how often to save the character */ |
133 | /* how often to save the character */ |
207 | /* |
134 | /* |
208 | * Misc global variables: |
135 | * Misc global variables: |
209 | */ |
136 | */ |
210 | EXTERN FILE *logfile; /* Used by server/daemon.c */ |
137 | EXTERN FILE *logfile; /* Used by server/daemon.c */ |
211 | EXTERN int exiting; /* True if the game is about to exit */ |
|
|
212 | EXTERN long nroftreasures; /* Only used in malloc_info() */ |
|
|
213 | EXTERN long nrofartifacts; /* Only used in malloc_info() */ |
|
|
214 | EXTERN long nrofallowedstr; /* Only used in malloc_info() */ |
|
|
215 | |
138 | |
216 | EXTERN archetype *empty_archetype; /* Nice to have fast access to it */ |
139 | EXTERN archetype *empty_archetype; /* Nice to have fast access to it */ |
217 | EXTERN archetype *map_archeytpe; |
140 | EXTERN archetype *map_archeytpe; |
218 | EXTERN char first_map_path[MAX_BUF]; /* The start-level */ |
141 | EXTERN shstr first_map_path; /* The start-level */ |
219 | EXTERN char first_map_ext_path[MAX_BUF]; /* Path used for per-race start maps */ |
142 | EXTERN shstr first_map_ext_path; /* Path used for per-race start maps */ |
220 | |
143 | |
221 | EXTERN char errmsg[HUGE_BUF]; |
144 | EXTERN char errmsg[HUGE_BUF]; |
222 | EXTERN long ob_count; |
145 | EXTERN long ob_count; |
223 | /* |
146 | /* |
224 | * Used in treasure.c |
147 | * Used in treasure.c |
225 | */ |
148 | */ |
226 | EXTERN archetype *ring_arch,*amulet_arch,*staff_arch,*crown_arch; |
149 | EXTERN archetype *ring_arch, *amulet_arch, *staff_arch, *crown_arch; |
227 | extern shstr undead_name; /* Used in hit_player() in main.c */ |
|
|
228 | |
150 | |
229 | extern std::vector<Animations> animations; |
|
|
230 | EXTERN int num_animations,animations_allocated, bmaps_checksum; |
|
|
231 | |
|
|
232 | /* Rotate right from bsd sum. This is used in various places for checksumming */ |
|
|
233 | #define ROTATE_RIGHT(c) if ((c) & 01) (c) = ((c) >>1) + 0x80000000; else (c) >>= 1; |
|
|
234 | |
|
|
235 | |
|
|
236 | #define SET_ANIMATION(ob,newanim) ob->face=&new_faces[animations[ob->animation_id].faces[newanim]] |
151 | #define SET_ANIMATION(ob,newanim) ob->face = animations [ob->animation_id].faces [newanim] |
237 | #define GET_ANIMATION(ob,anim) (animations[ob->animation_id].faces[anim]) |
152 | #define GET_ANIMATION(ob,anim) animations [ob->animation_id].faces [anim] |
238 | #define GET_ANIM_ID(ob) (ob->animation_id) |
153 | #define GET_ANIM_ID(ob) (ob->animation_id) |
239 | /* NUM_ANIMATIONS returns the number of animations allocated. The last |
154 | /* NUM_ANIMATIONS returns the number of animations allocated. The last |
240 | * usuable animation will be NUM_ANIMATIONS-1 (for example, if an object |
155 | * usuable animation will be NUM_ANIMATIONS-1 (for example, if an object |
241 | * has 8 animations, NUM_ANIMATIONS will return 8, but the values will |
156 | * has 8 animations, NUM_ANIMATIONS will return 8, but the values will |
242 | * range from 0 through 7. |
157 | * range from 0 through 7. |
… | |
… | |
247 | extern short freearr_x[SIZEOFFREE], freearr_y[SIZEOFFREE]; |
162 | extern short freearr_x[SIZEOFFREE], freearr_y[SIZEOFFREE]; |
248 | extern int maxfree[SIZEOFFREE], freedir[SIZEOFFREE]; |
163 | extern int maxfree[SIZEOFFREE], freedir[SIZEOFFREE]; |
249 | extern int rightof_x[9], rightof_y[9]; |
164 | extern int rightof_x[9], rightof_y[9]; |
250 | extern int leftof_x[9], leftof_y[9]; |
165 | extern int leftof_x[9], leftof_y[9]; |
251 | |
166 | |
252 | extern New_Face *blank_face, *empty_face; |
167 | extern void emergency_save (); |
253 | extern New_Face *dark_faces[]; |
168 | extern void cleanup (const char *cause, bool make_core = false); |
254 | extern New_Face *smooth_face; |
|
|
255 | |
169 | |
256 | |
|
|
257 | extern long max_time; /* loop time */ |
|
|
258 | extern NewSocket *init_sockets; |
|
|
259 | |
|
|
260 | |
|
|
261 | EXTERN char *font_graphic; |
|
|
262 | |
|
|
263 | #ifndef __CEXTRACT__ |
|
|
264 | #include "libproto.h" |
170 | #include "libproto.h" |
265 | #include "sockproto.h" |
171 | #include "sockproto.h" |
266 | #endif |
|
|
267 | |
|
|
268 | |
172 | |
269 | #define decrease_ob(xyz) decrease_ob_nr(xyz,1) |
173 | #define decrease_ob(xyz) decrease_ob_nr(xyz,1) |
270 | |
174 | |
271 | /* FREE_AND_CLEAR frees the pointer and then sets it to NULL. |
175 | INTERFACE_CLASS (Settings) |
272 | * This is generally done as a safety, and having this macro |
|
|
273 | * makes the code a bit cleaner when doing so. |
|
|
274 | */ |
|
|
275 | #define FREE_AND_CLEAR(xyz) {free(xyz); xyz=NULL; } |
|
|
276 | |
|
|
277 | #ifdef CALLOC |
|
|
278 | #undef CALLOC |
|
|
279 | #endif |
|
|
280 | |
|
|
281 | #ifdef USE_CALLOC |
|
|
282 | # define CALLOC(x,y) calloc(x,y) |
|
|
283 | # define CFREE(x) free(x) |
|
|
284 | #else |
|
|
285 | # define CALLOC(x,y) malloc(x*y) |
|
|
286 | # define CFREE(x) free(x) |
|
|
287 | #endif |
|
|
288 | |
|
|
289 | #ifndef WIN32 /* ---win32 we define this stuff in win32.h */ |
|
|
290 | #if HAVE_DIRENT_H |
|
|
291 | # include <dirent.h> |
|
|
292 | # define NAMLEN(dirent) strlen((dirent)->d_name) |
|
|
293 | #else |
|
|
294 | # define dirent direct |
|
|
295 | # define NAMLEN(dirent) (dirnet)->d_namlen |
|
|
296 | # if HAVE_SYS_NDIR_H |
|
|
297 | # include <sys/ndir.h> |
|
|
298 | # endif |
|
|
299 | # if HAVE_SYS_DIR_H |
|
|
300 | # include <sys/dir.h> |
|
|
301 | # endif |
|
|
302 | # if HAVE_NDIR_H |
|
|
303 | # include <ndir.h> |
|
|
304 | # endif |
|
|
305 | #endif |
|
|
306 | #endif |
|
|
307 | |
|
|
308 | typedef struct Settings { |
176 | struct Settings { |
309 | char *logfilename; /* logfile to use */ |
177 | const char *ACC (RO, logfilename); /* logfile to use */ |
310 | uint16 csport; /* port for new client/server */ |
178 | int ACC (RW, csport); /* port for new client/server */ |
311 | LogLevel debug; /* Default debugging level */ |
179 | int ACC (RW, debug); /* Default debugging level */ |
312 | uint8 dumpvalues; /* Set to dump various values/tables */ |
180 | uint8 dumpvalues; /* Set to dump various values/tables */ |
313 | char *dumparg; /* additional argument for some dump functions */ |
181 | const char *dumparg; /* additional argument for some dump functions */ |
314 | uint8 daemonmode; /* If true, detach and become daemon */ |
182 | uint8 daemonmode; /* If true, detach and become daemon */ |
315 | int argc; /* parameters that were passed to the program */ |
183 | int argc; /* parameters that were passed to the program */ |
316 | char **argv; /* Only used by xio.c, so will go away at some time */ |
184 | char **argv; /* Only used by xio.c, so will go away at some time */ |
317 | char *confdir; /* configuration files */ |
185 | const char *ACC (RO, confdir); /* configuration files */ |
318 | char *datadir; /* read only data files */ |
186 | const char *ACC (RO, datadir); /* read only data files */ |
319 | char *localdir; /* read/write data files */ |
187 | const char *ACC (RO, localdir); /* read/write data files */ |
320 | char *playerdir; /* Where the player files are */ |
188 | const char *ACC (RO, playerdir); /* Where the player files are */ |
321 | char *mapdir; /* Where the map files are */ |
189 | const char *ACC (RO, mapdir); /* Where the map files are */ |
322 | char *archetypes; /* name of the archetypes file - libdir is prepended */ |
190 | const char *ACC (RO, archetypes); /* name of the archetypes file - libdir is prepended */ |
323 | char *regions; /* name of the regions file - libdir is prepended */ |
191 | const char *ACC (RO, regions); /* name of the regions file - libdir is prepended */ |
324 | char *treasures; /* location of the treasures file. */ |
192 | const char *ACC (RO, treasures); /* location of the treasures file. */ |
325 | char *uniquedir; /* directory for the unique items */ |
193 | const char *ACC (RO, uniquedir); /* directory for the unique items */ |
326 | char *templatedir; /* directory for the template map */ |
194 | const char *ACC (RO, templatedir); /* directory for the template map */ |
327 | char *tmpdir; /* Directory to use for temporary files */ |
195 | const char *ACC (RO, tmpdir); /* Directory to use for temporary files */ |
328 | uint8 stat_loss_on_death; /* If true, chars lose a random stat when they die */ |
|
|
329 | sint16 pk_luck_penalty; /* Amount by which player luck is reduced if they PK */ |
196 | sint16 ACC (RW, pk_luck_penalty); /* Amount by which player luck is reduced if they PK */ |
|
|
197 | uint8 ACC (RW, stat_loss_on_death); /* If true, chars lose a random stat when they die */ |
330 | uint8 permanent_exp_ratio; /* how much exp should be 'permenant' and unable to be lost*/ |
198 | uint8 ACC (RW, permanent_exp_ratio); /* how much exp should be 'permenant' and unable to be lost*/ |
331 | uint8 death_penalty_ratio; /* how much exp should be lost at death */ |
199 | uint8 ACC (RW, death_penalty_ratio); /* how much exp should be lost at death */ |
332 | uint8 death_penalty_level; /* how many levels worth of exp may be lost on one death */ |
200 | uint8 ACC (RW, death_penalty_level); /* how many levels worth of exp may be lost on one death */ |
333 | uint8 balanced_stat_loss; /* If true, Death stat depletion based on level etc */ |
201 | uint8 ACC (RW, balanced_stat_loss); /* If true, Death stat depletion based on level etc */ |
334 | uint8 not_permadeth; /* if true, death is non-permament */ |
202 | uint8 ACC (RW, not_permadeth); /* if true, death is non-permament */ |
335 | uint8 simple_exp; /* If true, use the simple experience system */ |
203 | uint8 ACC (RW, simple_exp); /* If true, use the simple experience system */ |
336 | int reset_loc_time; /* Number of seconds to put player back at home */ |
|
|
337 | uint8 set_title; /* players can set thier title */ |
204 | uint8 ACC (RW, set_title); /* players can set thier title */ |
338 | uint8 resurrection; /* ressurection possible w/ permadeth on */ |
205 | uint8 ACC (RW, resurrection); /* ressurection possible w/ permadeth on */ |
339 | uint8 search_items; /* search_items command */ |
206 | uint8 ACC (RW, search_items); /* search_items command */ |
340 | uint8 spell_encumbrance; /* encumbrance effects spells */ |
207 | uint8 ACC (RW, spell_encumbrance); /* encumbrance effects spells */ |
341 | uint8 spell_failure_effects; /* nasty backlash to spell failures */ |
208 | uint8 ACC (RW, spell_failure_effects); /* nasty backlash to spell failures */ |
342 | uint16 set_friendly_fire; /* Percent of damage done by peaceful player vs player damage */ |
209 | uint16 ACC (RW, set_friendly_fire); /* Percent of damage done by peaceful player vs player damage */ |
343 | uint8 casting_time; /* it takes awhile to cast a spell */ |
210 | uint8 ACC (RW, casting_time); /* it takes awhile to cast a spell */ |
344 | uint8 real_wiz; /* use mud-like wizards */ |
211 | uint8 ACC (RW, real_wiz); /* use mud-like wizards */ |
345 | uint8 recycle_tmp_maps; /* re-use tmp maps. */ |
212 | uint8 dummy_000; |
346 | uint8 explore_mode; /* explore mode allowed? */ |
|
|
347 | uint8 spellpoint_level_depend; /* spell costs go up with level */ |
213 | uint8 ACC (RW, spellpoint_level_depend); /* spell costs go up with level */ |
348 | char who_format[MAX_BUF]; /* The format that the who command should use */ |
|
|
349 | char who_wiz_format[MAX_BUF]; /* The format that the who command should use when called by a dm*/ |
|
|
350 | char motd[MAX_BUF]; /* name of the motd file */ |
214 | char ACC (RW, motd)[MAX_BUF]; /* name of the motd file */ |
351 | char *rules; /* name of rules file*/ |
215 | const char *ACC (RO, rules); /* name of rules file*/ |
352 | char *news; /* name of news file*/ |
216 | const char *ACC (RO, news); /* name of news file*/ |
353 | char dm_mail[MAX_BUF]; /* DM's Email address */ |
217 | char ACC (RW, dm_mail)[MAX_BUF]; /* DM's Email address */ |
354 | |
218 | |
355 | /* The meta_ is information for the metaserver. These are set in |
|
|
356 | * the lib/settings file. |
|
|
357 | */ |
|
|
358 | uint8 meta_on:1; /* True if we should send updates */ |
|
|
359 | char meta_server[MAX_BUF]; /* Hostname/ip addr of the metaserver */ |
|
|
360 | char meta_host[MAX_BUF]; /* Hostname of this host */ |
|
|
361 | uint16 meta_port; /* Port number to use for updates */ |
|
|
362 | char meta_comment[MAX_BUF]; /* Comment we send to the metaserver */ |
|
|
363 | |
|
|
364 | uint32 worldmapstartx; /* starting x tile for the worldmap */ |
219 | uint32 ACC (RW, worldmapstartx); /* starting x tile for the worldmap */ |
365 | uint32 worldmapstarty; /* starting y tile for the worldmap */ |
220 | uint32 ACC (RW, worldmapstarty); /* starting y tile for the worldmap */ |
366 | uint32 worldmaptilesx; /* number of tiles wide the worldmap is */ |
221 | uint32 ACC (RW, worldmaptilesx); /* number of tiles wide the worldmap is */ |
367 | uint32 worldmaptilesy; /* number of tiles high the worldmap is */ |
222 | uint32 ACC (RW, worldmaptilesy); /* number of tiles high the worldmap is */ |
368 | uint32 worldmaptilesizex; /* number of squares wide in a wm tile */ |
223 | uint32 ACC (RW, worldmaptilesizex); /* number of squares wide in a wm tile */ |
369 | uint32 worldmaptilesizey; /* number of squares high in a wm tile */ |
224 | uint32 ACC (RW, worldmaptilesizey); /* number of squares high in a wm tile */ |
370 | uint16 dynamiclevel; /* how dynamic is the world? */ |
225 | uint16 ACC (RW, dynamiclevel); /* how dynamic is the world? */ |
371 | uint8 fastclock; /* if true, clock goes warp 9 */ |
226 | uint8 ACC (RW, fastclock); /* if true, clock goes warp 9 */ |
372 | |
227 | |
373 | char *emergency_mapname; /* map to return players to in emergency */ |
|
|
374 | uint16 emergency_x, emergency_y; /* coordinates to use on that map */ |
|
|
375 | |
|
|
376 | sint16 max_level; /* This is read out of exp_table */ |
228 | int ACC (RW, max_level); /* This is read out of exp_table */ |
377 | float item_power_factor; /* See note in setings file */ |
229 | float ACC (RW, item_power_factor); /* See note in setings file */ |
378 | |
230 | |
379 | int armor_max_enchant; /* Maximum number of times an armor can be enchanted */ |
231 | int ACC (RW, armor_max_enchant); /* Maximum number of times an armor can be enchanted */ |
380 | int armor_weight_reduction; /* Weight reduction per enchantment */ |
232 | int ACC (RW, armor_weight_reduction); /* Weight reduction per enchantment */ |
|
|
233 | int ACC (RW, armor_speed_improvement); /* Speed improvement */ |
381 | uint8 armor_weight_linear; /* If 1, weight reduction is linear, else exponantiel */ |
234 | uint8 ACC (RW, armor_weight_linear); /* If 1, weight reduction is linear, else exponantiel */ |
382 | int armor_speed_improvement; /* Speed improvement */ |
|
|
383 | uint8 armor_speed_linear; /* If 1, speed improvement is linear, else exponantiel */ |
235 | uint8 ACC (RW, armor_speed_linear); /* If 1, speed improvement is linear, else exponantiel */ |
384 | uint8 no_player_stealing; /* If 1, can not steal from other players */ |
236 | uint8 ACC (RW, no_player_stealing); /* If 1, can not steal from other players */ |
385 | uint8 create_home_portals; /* If 1, can create portals in personal maps */ |
237 | uint8 ACC (RW, create_home_portals); /* If 1, can create portals in personal maps */ |
386 | } Settings; |
238 | }; |
387 | |
239 | |
388 | extern Settings settings; |
240 | extern Settings settings; |
389 | |
|
|
390 | /* 0.94.1 - change to GETTIMEOFDAY macro - SNI systems only one one option. |
|
|
391 | * rather than have complex #ifdefs throughout the file, lets just figure |
|
|
392 | * it out once, here at the top. |
|
|
393 | * Have no idea if that is the right symbol to check on for NetBSD, |
|
|
394 | * but NetBSD does use 2 params. |
|
|
395 | * Move this to global.h from time.c since its also used in arch.c |
|
|
396 | */ |
|
|
397 | |
|
|
398 | #ifdef GETTIMEOFDAY_TWO_ARGS |
|
|
399 | #define GETTIMEOFDAY(last_time) gettimeofday(last_time, (struct timezone *) NULL); |
|
|
400 | #else |
|
|
401 | #define GETTIMEOFDAY(last_time) gettimeofday(last_time); |
|
|
402 | #endif |
|
|
403 | |
241 | |
404 | #include "plugin.h" |
242 | #include "plugin.h" |
405 | #include "cfperl.h" |
243 | #include "cfperl.h" |
406 | |
244 | |
407 | //TODO: various TEMPORARY link guards to avoid doing the wrong thing |
|
|
408 | void free (archetype *); |
|
|
409 | void free (recipe *); |
|
|
410 | void free (linked_char *); |
|
|
411 | void free (godlink *); |
|
|
412 | void free (mapstruct *); |
|
|
413 | void free (key_value *); |
|
|
414 | void free (treasure *); |
|
|
415 | void free (materialtype_t *); |
|
|
416 | void free (player *); |
|
|
417 | |
|
|
418 | #endif /* GLOBAL_H */ |
245 | #endif /* GLOBAL_H */ |
|
|
246 | |