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