ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/include/player.h
(Generate patch)

Comparing deliantra/server/include/player.h (file contents):
Revision 1.12 by root, Mon Sep 4 11:07:59 2006 UTC vs.
Revision 1.43 by root, Sun Jan 7 02:39:14 2007 UTC

1/* 1/*
2 CrossFire, A Multiplayer game for X-windows 2 CrossFire, A Multiplayer game for X-windows
3 3
4 Copyright (C) 2005, 2006, 2007 Marc Lehmann & Crossfire+ Development Team
4 Copyright (C) 2002 Mark Wedel & Crossfire Development Team 5 Copyright (C) 2002 Mark Wedel & Crossfire Development Team
5 Copyright (C) 1992 Frank Tore Johansen 6 Copyright (C) 1992 Frank Tore Johansen
6 7
7 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
8 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
16 17
17 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
18 along with this program; if not, write to the Free Software 19 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 21
21 The authors can be reached via e-mail at crossfire-devel@real-time.com 22 The authors can be reached via e-mail at crossfire@schmorp.de
22*/ 23*/
23 24
24#define NUM_OUTPUT_BUFS 5 25#define NUM_OUTPUT_BUFS 5
25typedef struct { 26struct Output_Buf
27{
26 shstr buf; /* Actual string pointer */ 28 shstr buf; /* Actual string pointer */
27 uint32 first_update; /* First time this message was stored */ 29 uint32 first_update; /* First time this message was stored */
28 uint16 count; /* How many times we got this message */ 30 uint16 count; /* How many times we got this message */
29} Output_Buf; 31};
30
31 32
32/* wand/rod/horn rolled into range_misc. They all use the same body location 33/* wand/rod/horn rolled into range_misc. They all use the same body location
33 * anyways. 34 * anyways.
34 */ 35 */
35enum rangetype { 36enum rangetype
37{
36 range_bottom = -1, 38 range_bottom = -1,
37 range_none = 0, 39 range_none = 0,
38 range_bow = 1, 40 range_bow = 1,
39 range_magic = 2, 41 range_magic = 2,
40 range_misc = 3, 42 range_misc = 3,
41 range_golem = 4, 43 range_golem = 4,
42 range_skill = 5, 44 range_skill = 5,
43 range_builder = 6, 45 range_builder = 6,
44 range_size = 7 46 range_size = 7
45}; 47};
46 48
47enum bowtype_t { 49enum bowtype_t
50{
48 bow_normal = 0, 51 bow_normal = 0,
49 bow_threewide = 1, 52 bow_threewide = 1,
50 bow_spreadshot = 2, 53 bow_spreadshot = 2,
51 bow_n = 3, /* must stay at 3 */ 54 bow_n = 3, /* must stay at 3 */
52 bow_ne = 4, 55 bow_ne = 4,
53 bow_e = 5, 56 bow_e = 5,
54 bow_se = 6, 57 bow_se = 6,
55 bow_s = 7, 58 bow_s = 7,
56 bow_sw = 8, 59 bow_sw = 8,
57 bow_w = 9, 60 bow_w = 9,
58 bow_nw = 10, /* must stay at 10 */ 61 bow_nw = 10, /* must stay at 10 */
59 bow_bestarrow = 11 62 bow_bestarrow = 11
60}; 63};
61 64
62typedef enum _petmode { 65enum petmode_t
66{
63 pet_normal = 0, 67 pet_normal = 0,
64 pet_sad = 1, 68 pet_sad = 1,
65 pet_defend = 2, 69 pet_defend = 2,
66 pet_arena = 3 70 pet_arena = 3
67} petmode_t; 71};
68 72
69typedef enum usekeytype { 73enum usekeytype
74{
70 key_inventory=0, 75 key_inventory = 0,
71 keyrings=1, 76 keyrings = 1,
72 containers=2 77 containers = 2
73} usekeytype; 78};
74 79
75/* This is used to control what to do when we need to unapply 80/* This is used to control what to do when we need to unapply
76 * an object before we can apply another one. 81 * an object before we can apply another one.
77 */ 82 */
78typedef enum unapplymode { 83enum unapplymode
84{
79 unapply_nochoice=0, /* Will unapply objects when there no choice to unapply */ 85 unapply_nochoice = 0, /* Will unapply objects when there no choice to unapply */
80 unapply_never=1, /* will not unapply objects automatically */ 86 unapply_never = 1, /* will not unapply objects automatically */
81 unapply_always=2 /* Will unapply whatever is necessary - this goes beyond */ 87 unapply_always = 2 /* Will unapply whatever is necessary - this goes beyond */
82 /* no choice - if there are multiple ojbect of the same type */ 88 /* no choice - if there are multiple ojbect of the same type */
83 /* that need to be unapplied, there is no way for the player */ 89 /* that need to be unapplied, there is no way for the player */
84 /* to control which of these will be unapplied. */ 90 /* to control which of these will be unapplied. */
85} unapplymode; 91};
86 92
87/* not really the player, but tied pretty closely */ 93/* not really the player, but tied pretty closely */
88typedef struct party_struct { 94INTERFACE_CLASS (partylist)
95struct partylist
96{
89 char * partyleader; 97 char *ACC (RW, partyleader);
90 char passwd[9]; 98 char ACC (RW, passwd)[9];
91 struct party_struct *next; 99 partylist *ACC (RW, next);
92 char *partyname; 100 char *ACC (RW, partyname);
93 101
94#ifdef PARTY_KILL_LOG
95 struct party_kill { 102 struct party_kill
103 {
96 char killer[MAX_NAME+1],dead[MAX_NAME+1]; 104 char killer[MAX_NAME + 1], dead[MAX_NAME + 1];
97 sint64 exp; 105 sint64 exp;
98 } party_kills[PARTY_KILL_LOG]; 106 } party_kills[PARTY_KILL_LOG];
99#endif 107
100 sint64 total_exp; 108 sint64 ACC (RW, total_exp);
101 uint32 kills; 109 uint32 ACC (RW, kills);
102} partylist; 110};
103 111
104// memsettable part of player 112INTERFACE_CLASS (player)
105struct player_pod 113struct player : zero_initialised, attachable
106{ 114{
115 client *ACC (RO, ns); /* Socket information for this player */
107 object *ob; /* The object representing the player */ 116 object *ACC (RW, ob); /* The object representing the player */
108 mapstruct *loading; /* When entering a map in progress of loading, not really used */ 117 int ACC (RO, active);
118
109 rangetype shoottype; /* Which range-attack is being used by player */ 119 rangetype ACC (RW, shoottype); /* Which range-attack is being used by player */
110 bowtype_t bowtype; /* which firemode? */ 120 bowtype_t ACC (RW, bowtype); /* which firemode? */
111 petmode_t petmode; /* which petmode? */ 121 petmode_t ACC (RW, petmode); /* which petmode? */
112 object *ranges[range_size];/* object for each range. Set up in fix player. Note */ 122 object_ptr ACC (RW, ranges[range_size]); /* object for each range. Set up in fix player. Note */
113 /* That not all are used, it is just nice to map this 1:1 */ 123 /* That not all are used, it is just nice to map this 1:1 */
114 /* With the range names */ 124 /* With the range names */
115 uint32 golem_count; /* To track the golem */
116 usekeytype usekeys; /* Method for finding keys for doors */ 125 usekeytype ACC (RW, usekeys); /* Method for finding keys for doors */
117 unapplymode unapply; /* Method for auto unapply */ 126 unapplymode ACC (RW, unapply); /* Method for auto unapply */
118 uint32 count; /* Any numbers typed before a command */ 127 uint32 ACC (RW, count); /* Any numbers typed before a command */
119 uint32 mode; /* Mode of player for pickup. */ 128 uint32 ACC (RW, mode); /* Mode of player for pickup. */
120 129
121 sint8 digestion; /* Any bonuses/penalties to digestion */ 130 sint8 ACC (RW, digestion); /* Any bonuses/penalties to digestion */
122 sint8 gen_hp; /* Bonuses to regeneration speed of hp */ 131 sint8 ACC (RW, gen_hp); /* Bonuses to regeneration speed of hp */
123 sint8 gen_sp; /* Bonuses to regeneration speed of sp */ 132 sint8 ACC (RW, gen_sp); /* Bonuses to regeneration speed of sp */
124 sint8 gen_sp_armour; /* Penalty to sp regen from armour */ 133 sint8 ACC (RW, gen_sp_armour); /* Penalty to sp regen from armour */
125 sint8 gen_grace; /* Bonuses to regeneration speed of grace */ 134 sint8 ACC (RW, gen_grace); /* Bonuses to regeneration speed of grace */
126 sint16 item_power; /* Total item power of objects equipped */ 135 sint16 ACC (RW, item_power); /* Total item power of objects equipped */
127 uint8 state; /* Input state of the player (name, password, etc */
128 uint8 listening; /* Which priority will be used in info_all */ 136 uint8 ACC (RW, listening); /* Which priority will be used in info_all */
129 sint8 last_level; /* Last level we sent to client */ 137 sint8 ACC (RW, last_level); /* Last level we sent to client */
130 138
131 /* Try to put all the bitfields together - saves some small amount of memory */ 139 /* Try to put all the bitfields together - saves some small amount of memory */
132 uint32 braced:1; /* Will not move if braced, only attack */ 140 bool ACC (RW, braced); /* Will not move if braced, only attack */
133 uint32 tmp_invis:1; /* Will invis go away when we attack ? */ 141 bool ACC (RW, tmp_invis); /* Will invis go away when we attack ? */
134 shstr invis_race; /* What race invisible to? */
135 uint32 do_los:1; /* If true, need to call update_los() in draw(), and clear */ 142 bool ACC (RW, do_los); /* If true, need to call update_los() in draw(), and clear */
136 uint32 fire_on:1; /* Player should fire object, not move */ 143 bool ACC (RW, fire_on); /* Player should fire object, not move */
137 uint32 run_on:1; /* Player should keep moving in dir until run is off */ 144 bool ACC (RW, run_on); /* Player should keep moving in dir until run is off */
138 uint32 has_hit:1; /* If set, weapon_sp instead of speed will count */ 145 bool ACC (RW, has_hit); /* If set, weapon_sp instead of speed will count */
139 uint32 name_changed:1; /* If true, the player has set a name. */
140 uint32 peaceful:1; /* If set, won't attack friendly creatures */ 146 bool ACC (RW, peaceful); /* If set, won't attack friendly creatures */
141 uint32 hidden:1; /* If True, player (DM) is hidden from view */ 147 bool ACC (RW, hidden); /* If True, player (DM) is hidden from view */
142 uint32 explore:1; /* if True, player is in explore mode */
143 uint32 no_shout:1; /* if True, player is *not* able to use shout command */
144 148
145 object *last_skill_ob[NUM_SKILLS]; /* the exp object */ 149 object_ptr last_skill_ob[NUM_SKILLS]; /* the exp object */
146 sint64 last_skill_exp[NUM_SKILLS]; /* shadow register. if != exp. obj update client */ 150 sint64 last_skill_exp[NUM_SKILLS]; /* shadow register. if != exp. obj update client */
147 151
148 float weapon_sp; /* Penalties to speed when fighting w speed >ws/10*/ 152 float ACC (RW, weapon_sp); /* Penalties to speed when fighting w speed >ws/10 */
149 float last_weapon_sp; /* if diff than weapon_sp, update client */ 153 float ACC (RW, last_weapon_sp); /* if diff than weapon_sp, update client */
150 uint16 last_flags; /* fire/run on flags for last tick */ 154 uint16 ACC (RW, last_flags); /* fire/run on flags for last tick */
151 sint32 last_weight; /* Last weight as sent to client; -1 means do not send weight */ 155 sint32 ACC (RW, last_weight); /* Last weight as sent to client; -1 means do not send weight */
152 sint32 last_weight_limit; /* Last weight limit transmitted to client */ 156 sint32 ACC (RW, last_weight_limit); /* Last weight limit transmitted to client */
153 uint32 last_path_attuned; /* Last spell attunment sent to client */ 157 uint32 ACC (RW, last_path_attuned); /* Last spell attunment sent to client */
154 uint32 last_path_repelled; /* Last spell repelled sent to client */ 158 uint32 ACC (RW, last_path_repelled); /* Last spell repelled sent to client */
155 uint32 last_path_denied; /* Last spell denied sent to client */ 159 uint32 ACC (RW, last_path_denied); /* Last spell denied sent to client */
156 living orig_stats; /* Permanent real stats of player */ 160 living ACC (RO, orig_stats); /* Permanent real stats of player */
157 living last_stats; /* Last stats as sent to client */ 161 living ACC (RO, last_stats); /* Last stats as sent to client */
158 float last_speed; /* Last speed as sent to client */ 162 float ACC (RW, last_speed); /* Last speed as sent to client */
159 sint16 last_resist[NROFATTACKS]; /* last resist values sent to client */ 163 sint16 ACC (RW, last_resist[NROFATTACKS]); /* last resist values sent to client */
160 int Swap_First; /* First stat player has selected to swap */
161 object *last_used; /* Pointer to object last picked or applied */ 164 object_ptr ACC (RW, last_used); /* Pointer to object last picked or applied */
162 uint32 last_used_id; /* Safety measures to be sure it's the same */ 165
166 sint16 ACC (RW, bed_x), ACC (RW, bed_y); /* x,y - coordinates of respawn (savebed) */
167 shstr ACC (RW, savebed_map); /* map where player will respawn after death */
168 shstr ACC (RW, maplevel); /* On which level is the player? */
169 char ACC (RW, spellparam)[MAX_BUF]; /* What param to add to spells */
170
171 char ACC (RW, own_title)[MAX_NAME]; /* Title the player has chosen for themself */
172 /* Note that for dragon players, this is filled in for them */
173 char ACC (RW, title)[64]; /* Default title, like fighter, wizard, etc */
174
175 sint8 ACC (RW, levhp[11]); /* What the player gained on that level */
176 sint8 ACC (RW, levsp[11]); /* Same for sp */
177 sint8 ACC (RW, levgrace[11]); /* And same for grace */
178
179 char ACC (RW, killer)[64]; /* Who killed this player. */
180
181 char write_buf[MAX_BUF]; /* Holds arbitrary input from client */ /* should go */
182 char ACC (RW, password)[16]; /* 2 (seed) + 11 (crypted) + 1 (EOS) + 2 (safety) = 16 */
183
184 time_t ACC (RW, last_save_time);
185 uint32 ACC (RW, last_save_tick);
186 partylist *ACC (RW, party); /* Party this player is part of */
187 partylist *ACC (RW, party_to_join); /* used when player wants to join a party */
188 /* but we will have to get password first */
189 /* so we have to remember which party to */
190 /* join */
191 char ACC (RW, search_str)[MAX_BUF]; /* Item we are looking for */
192 sint16 ACC (RW, encumbrance); /* How much our player is encumbered */
193 uint16 ACC (RW, outputs_sync); /* How often to print, no matter what */
194 uint16 ACC (RW, outputs_count); /* Print if this count is exceeded */
195 object_ptr ACC (RW, mark); /* marked object */
196 /* Special DM fields */
197 tag_t *stack_items; /* Item stack for patch/dump/... commands */
198 int ACC (RW, stack_position); /* Current stack position, 0 for no item */
163 sint8 blocked_los[MAP_CLIENT_X][MAP_CLIENT_Y]; /* array showing what spaces */ 199 sint8 blocked_los[MAP_CLIENT_X][MAP_CLIENT_Y]; /* array showing what spaces */
164 /* the player can see. For maps smaller than */ 200 /* the player can see. For maps smaller than */
165 /* MAP_CLIENT_.., the upper left is used */ 201 /* MAP_CLIENT_.., the upper left is used */
166 202
167 sint16 bed_x, bed_y; /* x,y - coordinates of respawn (savebed) */ 203 shstr ACC (RW, invis_race); /* What race invisible to? */
168 char savebed_map[MAX_BUF]; /* map where player will respawn after death */
169 char maplevel[MAX_BUF]; /* On which level is the player? */
170 char spellparam[MAX_BUF]; /* What param to add to spells */
171
172 char own_title[MAX_NAME]; /* Title the player has chosen for themself */
173 /* Note that for dragon players, this is filled in for them */
174 char title[BIG_NAME]; /* Default title, like fighter, wizard, etc */
175
176 sint8 levhp[11]; /* What the player gained on that level */
177 sint8 levsp[11]; /* Same for sp */
178 sint8 levgrace[11]; /* And same for grace */
179
180 char killer[BIG_NAME]; /* Who killed this player. */
181 char last_tell[MAX_NAME]; /* last player that told you something [mids 01/14/2002] */
182
183 char write_buf[MAX_BUF]; /* Holds arbitrary input from client */
184 char input_buf[MAX_BUF]; /* Holds command to run */
185 char password[16]; /* 2 (seed) + 11 (crypted) + 1 (EOS) + 2 (safety) = 16 */
186
187#ifdef SAVE_INTERVAL
188 time_t last_save_time;
189#endif /* SAVE_INTERVAL */
190#ifdef AUTOSAVE
191 uint32 last_save_tick;
192#endif
193 partylist *party; /* Party this player is part of */
194 partylist *party_to_join; /* used when player wants to join a party */
195 /* but we will have to get password first */
196 /* so we have to remember which party to */
197 /* join */
198 char search_str[MAX_BUF]; /* Item we are looking for */
199 sint16 encumbrance; /* How much our player is encumbered */
200 Output_Buf outputs[NUM_OUTPUT_BUFS]; /* holds output strings to client */ 204 Output_Buf outputs[NUM_OUTPUT_BUFS]; /* holds output strings to client */
201 uint16 outputs_sync; /* How often to print, no matter what */
202 uint16 outputs_count; /* Print if this count is exceeded */
203 object *mark; /* marked object */
204 uint32 mark_count; /* count of mark object */
205 /* Special DM fields */
206 tag_t* stack_items; /* Item stack for patch/dump/... commands */
207 int stack_position; /* Current stack position, 0 for no item */
208};
209 205
210typedef struct pl : zero_initialised, attachable<struct pl>, player_pod 206 MTH static player *create ();
211{ 207
212 struct pl *next; /* Pointer to next player, NULL if this is last */ 208 static player *load_pl (object_thawer &thawer);
213 NewSocket socket; /* Socket information for this player */ 209 MTH static player *load_pl (const char *path);
210
211 bool save_pl (object_freezer &freezer);
212 MTH bool save_pl (const char *path);
213
214 void do_destroy ();
215 void gather_callbacks (AV *&callbacks, event_type event) const;
216
217 MTH void connect (client *ns);
218 MTH void disconnect ();
219
220 MTH void activate ();
221 MTH void deactivate ();
222
223 // enters the initial map, after login or creation
224 MTH void enter_map ();
225
226 ~player ();
227
228private:
229 void set_object (object *op);
214} player; 230 player ();
231};
215 232
233typedef object_vector<player, &player::active> playervec;
234
235extern playervec players;
236
237#define for_all_players(var) \
238 for (int _i = 0; _i < players.size (); ++_i) \
239 declvar (player *, var, players [_i])
240

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines