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.5 by root, Sun Sep 10 16:00:23 2006 UTC vs.
Revision 1.30 by root, Sat Nov 17 23:40:00 2018 UTC

1/*
2 * This file is part of Deliantra, the Roguelike Realtime MMORPG.
3 *
4 * Copyright (©) 2017,2018 Marc Alexander Lehmann / the Deliantra team
5 * Copyright (©) 2005,2006,2007,2008,2009,2010,2011,2012,2013,2014,2015,2016 Marc Alexander Lehmann / Robin Redeker / the Deliantra team
6 * Copyright (©) 2002 Mark Wedel & Crossfire Development Team
7 * Copyright (©) 1992 Frank Tore Johansen
8 *
9 * Deliantra is free software: you can redistribute it and/or modify it under
10 * the terms of the Affero GNU General Public License as published by the
11 * Free Software Foundation, either version 3 of the License, or (at your
12 * option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the Affero GNU General Public License
20 * and the GNU General Public License along with this program. If not, see
21 * <http://www.gnu.org/licenses/>.
22 *
23 * The authors can be reached via e-mail to <support@deliantra.net>
24 */
1 25
2/* Started file Sept 1996 - initialization of gods in form of a 26/* Started file Sept 1996 - initialization of gods in form of a
3 * linked list -b.t. 27 * linked list -b.t.
4 */ 28 */
5 29
6#include <global.h> 30#include <global.h>
7#include <living.h> 31#include <living.h>
8#include <spells.h> 32#include <spells.h>
9 33
10//TODO: make a constructor
11static godlink *
12init_godslist (void)
13{
14 godlink *gl = new godlink;
15
16 // name=NULL; /* how to describe the god to the player */
17 // arch=NULL; /* pointer to the archetype of this god */
18 // id=0; /* id of the god */
19 // pantheon=NULL; /* the group to which the god belongs (not implemented) */
20 // next=NULL; /* next god in this linked list */
21
22 return gl;
23}
24
25/* init_gods() - this takes a look at all of the archetypes to find
26 * the objects which correspond to the GODS (type GOD) */
27
28void
29init_gods (void)
30{
31 archetype *at = NULL;
32
33 LOG (llevDebug, "Initializing gods...");
34 for (at = first_archetype; at != NULL; at = at->next)
35 if (at->clone.type == GOD)
36 add_god_to_list (at);
37
38 LOG (llevDebug, "done.\n");
39}
40
41/* add_god_to_list()- called only from init_gods */ 34/* add_god_to_list()- called only from init_gods */
42void 35static void
43add_god_to_list (archetype *god_arch) 36add_god_to_list (archetype *god_arch)
44{ 37{
45 godlink *god;
46
47 if (!god_arch) 38 if (!god_arch)
48 { 39 {
49 LOG (llevError, "ERROR: Tried to add null god to list!\n"); 40 LOG (llevError, "ERROR: Tried to add null god to list!\n");
50 return; 41 return;
51 } 42 }
52 43
53 god = init_godslist (); 44 godlink *god = new godlink;
45
46 // name=NULL; /* how to describe the god to the player */
47 // arch=NULL; /* pointer to the archetype of this god */
48 // id=0; /* id of the god */
49 // pantheon=NULL; /* the group to which the god belongs (not implemented) */
50 // next=NULL; /* next god in this linked list */
54 51
55 god->arch = god_arch; 52 god->arch = god_arch;
56 god->name = god_arch->clone.name; 53 god->name = god_arch->object::name;
54
55 // first_god->id MUST be the highest god number for other code to work currently
57 if (!first_god) 56 if (!first_god)
58 god->id = 1; 57 god->id = 1;
59 else 58 else
60 { 59 {
61 god->id = first_god->id + 1; 60 god->id = first_god->id + 1;
62 god->next = first_god; 61 god->next = first_god;
63 } 62 }
63
64 first_god = god; 64 first_god = god;
65 65
66#ifdef DEBUG_GODS 66#ifdef DEBUG_GODS
67 LOG (llevDebug, "Adding god %s (%d) to list\n", &god->name, god->id); 67 LOG (llevDebug, "Adding god %s (%d) to list\n", &god->name, god->id);
68#endif 68#endif
69} 69}
70 70
71/* baptize_altar() - (cosmetically) change the name to that of the
72 * god in question, then set the title for later use. -b.t.
73 */
74
75int
76baptize_altar (object *op)
77{
78 char buf[MAX_BUF];
79
80 /* if the title field is pre-set, then that altar is
81 * already dedicated. */
82 if (!op->title)
83 {
84 godlink *god = get_rand_god ();
85
86 if (!god || !god->name)
87 {
88 LOG (llevError, "baptise_altar(): bizarre nameless god!\n");
89 return 0;
90 }
91 /* if the object name hasnt' been changed, we tack on the gods name */
92 if (!strcmp (op->name, op->arch->clone.name))
93 {
94 sprintf (buf, "%s of %s", &op->name, &god->name);
95 op->name = buf;
96 }
97 op->title = god->name;
98 return 1;
99 }
100 return 0;
101}
102
103godlink * 71godlink *
104get_rand_god (void) 72get_rand_god ()
105{ 73{
106 godlink *god = first_god; 74 godlink *god = first_god;
107 int i; 75 int i;
108 76
109 if (god) 77 if (god)
110 for (i = RANDOM () % (god->id) + 1; god; god = god->next) 78 for (i = rndm (god->id) + 1; god; god = god->next)
111 if (god->id == i) 79 if (god->id == i)
112 break; 80 break;
113 81
114 if (!god) 82 if (!god)
115 LOG (llevError, "get_rand_god(): can't find a random god!\n"); 83 LOG (llevError, "get_rand_god(): can't find a random god!\n");
84
116 return god; 85 return god;
117} 86}
118 87
119/* pntr_to_god_obj() - returns a pointer to the object 88/* pntr_to_god_obj() - returns a pointer to the object
120 * We need to be VERY carefull about using this, as we 89 * We need to be VERY carefull about using this, as we
121 * are returning a pointer to the CLONE object. -b.t. 90 * are returning a pointer to the CLONE object. -b.t.
122 */ 91 */
123object * 92object *
124pntr_to_god_obj (godlink *godlnk) 93pntr_to_god_obj (godlink *godlnk)
125{ 94{
126 object *god = NULL;
127
128 if (godlnk && godlnk->arch) 95 return godlnk && godlnk->arch
129 god = &godlnk->arch->clone; 96 ? godlnk->arch
130 return god; 97 : 0;
131} 98}
132 99
100/* init_gods() - this takes a look at all of the archetypes to find
101 * the objects which correspond to the GODS (type GOD) */
133void 102void
134free_all_god (void) 103init_gods ()
135{ 104{
136 godlink *god, *godnext; 105 LOG (llevDebug, "Initialising gods...\n");
137 106
138 LOG (llevDebug, "Freeing god information\n"); 107 for_all_archetypes (at)
139 for (god = first_god; god; god = godnext) 108 if (at->type == GOD)
140 { 109 add_god_to_list (at);
141 godnext = god->next; 110
142 delete god; 111 LOG (llevDebug, "done.\n");
143 }
144} 112}
113

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines