ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/holy.C
(Generate patch)

Comparing deliantra/server/common/holy.C (file contents):
Revision 1.4 by root, Sun Sep 3 00:18:39 2006 UTC vs.
Revision 1.20 by root, Fri Nov 6 12:49:19 2009 UTC

1 1/*
2 * This file is part of Deliantra, the Roguelike Realtime MMORPG.
3 *
4 * Copyright (©) 2005,2006,2007,2008 Marc Alexander Lehmann / Robin Redeker / the Deliantra team
5 * Copyright (©) 2002,2007 Mark Wedel & Crossfire Development Team
6 * Copyright (©) 1992,2007 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
2/* Started file Sept 1996 - initialization of gods in form of a 25/* Started file Sept 1996 - initialization of gods in form of a
3 * linked list -b.t. 26 * linked list -b.t.
4 */ 27 */
5 28
6#include <global.h> 29#include <global.h>
7#include <living.h> 30#include <living.h>
8#include <spells.h> 31#include <spells.h>
9 32
10//TODO: make a constructor 33/* add_god_to_list()- called only from init_gods */
11static godlink *init_godslist(void) { 34static void
12 godlink *gl = new godlink; 35add_god_to_list (archetype *god_arch)
36{
37 if (!god_arch)
38 {
39 LOG (llevError, "ERROR: Tried to add null god to list!\n");
40 return;
41 }
13 42
43 godlink *god = new godlink;
44
14 // name=NULL; /* how to describe the god to the player */ 45 // name=NULL; /* how to describe the god to the player */
15 // arch=NULL; /* pointer to the archetype of this god */ 46 // arch=NULL; /* pointer to the archetype of this god */
16 // id=0; /* id of the god */ 47 // id=0; /* id of the god */
17 // pantheon=NULL; /* the group to which the god belongs (not implemented) */ 48 // pantheon=NULL; /* the group to which the god belongs (not implemented) */
18 // next=NULL; /* next god in this linked list */ 49 // next=NULL; /* next god in this linked list */
19 50
20 return gl;
21}
22
23/* init_gods() - this takes a look at all of the archetypes to find
24 * the objects which correspond to the GODS (type GOD) */
25
26void init_gods (void) {
27 archetype *at=NULL;
28
29 LOG(llevDebug, "Initializing gods...");
30 for(at=first_archetype;at!=NULL;at=at->next)
31 if(at->clone.type==GOD) add_god_to_list(at);
32
33 LOG(llevDebug,"done.\n");
34}
35
36/* add_god_to_list()- called only from init_gods */
37void add_god_to_list (archetype *god_arch) {
38 godlink *god;
39
40 if(!god_arch) {
41 LOG(llevError,"ERROR: Tried to add null god to list!\n");
42 return;
43 }
44
45 god = init_godslist();
46
47 god->arch = god_arch; 51 god->arch = god_arch;
48 god->name = god_arch->clone.name; 52 god->name = god_arch->object::name;
53
54 // first_god->id MUST be the highest god number for other code to work currently
49 if(!first_god) 55 if (!first_god)
50 god->id = 1; 56 god->id = 1;
51 else { 57 else
58 {
52 god->id = first_god->id + 1; 59 god->id = first_god->id + 1;
53 god->next = first_god; 60 god->next = first_god;
54 } 61 }
62
55 first_god = god; 63 first_god = god;
56 64
57#ifdef DEBUG_GODS 65#ifdef DEBUG_GODS
58 LOG(llevDebug,"Adding god %s (%d) to list\n",&god->name,god->id); 66 LOG (llevDebug, "Adding god %s (%d) to list\n", &god->name, god->id);
59#endif 67#endif
60} 68}
61 69
62/* baptize_altar() - (cosmetically) change the name to that of the 70/* baptize_altar() - (cosmetically) change the name to that of the
63 * god in question, then set the title for later use. -b.t. 71 * god in question, then set the title for later use. -b.t.
64 */ 72 */
65 73static int
66int baptize_altar(object *op) { 74baptize_altar (object *op)
75{
67 char buf[MAX_BUF]; 76 char buf[MAX_BUF];
68 77
69 /* if the title field is pre-set, then that altar is 78 /* if the title field is pre-set, then that altar is
70 * already dedicated. */ 79 * already dedicated. */
71 if(!op->title) { 80 if (!op->title)
81 {
72 godlink *god=get_rand_god(); 82 godlink *god = get_rand_god ();
83
73 if(!god||!god->name) { 84 if (!god || !god->name)
85 {
74 LOG(llevError,"baptise_altar(): bizarre nameless god!\n"); 86 LOG (llevError, "baptise_altar(): bizarre nameless god!\n");
75 return 0; 87 return 0;
76 } 88 }
77 /* if the object name hasnt' been changed, we tack on the gods name */ 89 /* if the object name hasnt' been changed, we tack on the gods name */
78 if(!strcmp(op->name,op->arch->clone.name)) { 90 if (op->name == op->arch->object::name)
91 {
79 sprintf(buf,"%s of %s",&op->name,&god->name); 92 sprintf (buf, "%s of %s", &op->name, &god->name);
80 op->name = buf; 93 op->name = buf;
81 } 94 }
82 op->title = god->name; 95 op->title = god->name;
83 return 1; 96 return 1;
84 } 97 }
85 return 0; 98 return 0;
86} 99}
87 100
88godlink * get_rand_god ( void ) { 101godlink *
102get_rand_god (void)
103{
89 godlink *god=first_god; 104 godlink *god = first_god;
90 int i; 105 int i;
91 106
92 if(god) 107 if (god)
93 for(i=RANDOM()%(god->id)+1;god;god=god->next) 108 for (i = rndm (god->id) + 1; god; god = god->next)
94 if(god->id==i) break; 109 if (god->id == i)
95 110 break;
111
112 if (!god)
96 if(!god) LOG(llevError,"get_rand_god(): can't find a random god!\n"); 113 LOG (llevError, "get_rand_god(): can't find a random god!\n");
114
97 return god; 115 return god;
98} 116}
99 117
100/* pntr_to_god_obj() - returns a pointer to the object 118/* pntr_to_god_obj() - returns a pointer to the object
101 * We need to be VERY carefull about using this, as we 119 * We need to be VERY carefull about using this, as we
102 * are returning a pointer to the CLONE object. -b.t. 120 * are returning a pointer to the CLONE object. -b.t.
103 */ 121 */
122object *
104object *pntr_to_god_obj(godlink *godlnk) { 123pntr_to_god_obj (godlink *godlnk)
105 object *god=NULL; 124{
106
107 if(godlnk && godlnk->arch) 125 return godlnk && godlnk->arch
108 god=&godlnk->arch->clone; 126 ? godlnk->arch
109 return god; 127 : 0;
110} 128}
111 129
130void
112void free_all_god(void) { 131free_all_god (void)
132{
113 godlink *god, *godnext; 133 godlink *god, *godnext;
114 134
115 LOG(llevDebug,"Freeing god information\n"); 135 LOG (llevDebug, "Freeing god information\n");
116 for (god=first_god; god; god=godnext) { 136 for (god = first_god; god; god = godnext)
137 {
117 godnext=god->next; 138 godnext = god->next;
118 delete god; 139 delete god;
119 } 140 }
120} 141}
121 142
143/* init_gods() - this takes a look at all of the archetypes to find
144 * the objects which correspond to the GODS (type GOD) */
145void
146init_gods (void)
147{
148 LOG (llevDebug, "Initialising gods...\n");
122 149
150 for_all_archetypes (at)
151 if (at->type == GOD)
152 add_god_to_list (at);
153
154 LOG (llevDebug, "done.\n");
155}
156

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines