ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/include/attack.h
Revision: 1.21
Committed: Sun Apr 4 20:00:05 2010 UTC (14 years, 1 month ago) by root
Content type: text/plain
Branch: MAIN
CVS Tags: rel-3_0
Changes since 1.20: +4 -2 lines
Log Message:
more const autogen

File Contents

# Content
1 /*
2 * This file is part of Deliantra, the Roguelike Realtime MMORPG.
3 *
4 * Copyright (©) 2005,2006,2007,2008,2009,2010 Marc Alexander Lehmann / Robin Redeker / the Deliantra team
5 * Copyright (©) 2002 Mark Wedel & Crossfire Development Team
6 * Copyright (©) 1992 Frank Tore Johansen
7 *
8 * Deliantra is free software: you can redistribute it and/or modify it under
9 * the terms of the Affero GNU General Public License as published by the
10 * Free Software Foundation, either version 3 of the License, or (at your
11 * option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the Affero GNU General Public License
19 * and the GNU General Public License along with this program. If not, see
20 * <http://www.gnu.org/licenses/>.
21 *
22 * The authors can be reached via e-mail to <support@deliantra.net>
23 */
24
25 #ifndef ATTACK_H
26 #define ATTACK_H
27
28 /*
29 * Attacktypes:
30 * ATNR_... is the attack number that is indexed into the
31 * the resist array in the object structure.
32 */
33
34 #define NROFATTACKMESS 20
35 #define MAXATTACKMESS 20
36
37 /* attack message numbers must be less than NROFATTACKMESS */
38
39 #define ATM_ARROW 0
40 #define ATM_DRAIN 1
41 #define ATM_ELEC 2
42 #define ATM_COLD 3
43 #define ATM_FIRE 4
44 #define ATM_BASIC 5
45 #define ATM_KARATE 6
46 #define ATM_CLAW 7
47 #define ATM_PUNCH 8
48 #define ATM_SLASH 9
49 #define ATM_PIERCE 10
50 #define ATM_CLEAVE 11
51 #define ATM_SLICE 12
52 #define ATM_STAB 13
53 #define ATM_WHIP 14
54 #define ATM_CRUSH 15
55 #define ATM_BLUD 16
56 #define ATM_DOOR 17
57 #define ATM_SUFFER 18
58
59 /* attack messages structure */
60 typedef struct attackmess {
61 int level;
62 char *buf1;
63 char *buf2;
64 char *buf3;
65 } attackmess_t;
66
67 EXTERN attackmess_t attack_mess[NROFATTACKMESS][MAXATTACKMESS];
68
69 enum
70 {
71 # define def(uc, lc, name, plus, change) ATNR_ ## uc,
72 # include "attackinc.h"
73 # undef def
74 NROFATTACKS
75 };
76
77 enum
78 {
79 # define def(uc, lc, name, plus, change) AT_ ## uc = 1UL << ATNR_ ## uc,
80 # include "attackinc.h"
81 # undef def
82 };
83
84 /* Short description of names of the attacktypes */
85 extern const char* const attacktype_desc[NROFATTACKS];
86
87 /* Note that internal should not ever be referenced in the last two
88 * tables. however, other resisttypes may be added, and if through some
89 * bug these do get used somehow, might as well make it more easier to notice
90 * and not have mystery values appear.
91 */
92
93 /* This is the array that is what the player sees. */
94 extern const char* const resist_plus[NROFATTACKS];
95
96 /* These are the descriptions of the resistances displayed when a
97 * player puts on/takes off an item. See change_abil() in living.c.
98 */
99 extern const char* const change_resist_msg[NROFATTACKS];
100
101 /* If you want to weight things so certain resistances show up more often than
102 * others, just add more entries in the table for the protections you want to
103 * show up.
104 */
105 extern int resist_table[NROFATTACKS];
106
107 #define num_resist_table 19
108
109 #endif
110