2 * Empire - A multi-player, client/server Internet based war game.
3 * Copyright (C) 1986-2006, Dave Pare, Jeff Bailey, Thomas Ruschak,
4 * Ken Stevens, Steve McClure
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 * See files README, COPYING and CREDITS in the root of the source
23 * tree for related information and legal notices. It is expected
24 * that future projects/authors will amend these files as needed.
28 * empobj.c: Common functions on struct empobj and
29 * union empobj_storage
31 * Known contributors to this file:
32 * Ron Koenderink, 2006
33 * Markus Armbruster, 2006
41 #include "prototypes.h"
44 obj_nameof(struct empobj *gp)
46 switch (gp->ef_type) {
48 return prship((struct shpstr *)gp);
50 return prplane((struct plnstr *)gp);
52 return prland((struct lndstr *)gp);
54 return prnuke((struct nukstr *)gp);
56 CANT_HAPPEN("unsupported TYPE");
61 get_empobjp(int type, int id)
63 if (CANT_HAPPEN(type == EF_SECTOR || type == EF_BAD))
66 return (struct empobj *)ef_ptr(type, id);
70 put_empobj(struct empobj *gp)
75 return ef_write(gp->ef_type, sctoff(gp->x, gp->y), gp);
79 return ef_write(gp->ef_type, gp->own, gp);
81 return ef_write(gp->ef_type, gp->uid, gp);
86 get_empobj_chr(struct empobj *gp)
88 switch (gp->ef_type) {
90 return &lchr[(int)gp->type];
92 return &mchr[(int)gp->type];
94 return &plchr[(int)gp->type];
96 return &nchr[(int)gp->type];
98 return &dchr[(int)gp->type];
100 CANT_HAPPEN("unsupported TYPE");
106 emp_obj_chr_name(struct empobj *gp)
108 switch (gp->ef_type) {
110 return lchr[(int)gp->type].l_name;
112 return mchr[(int)gp->type].m_name;
114 return plchr[(int)gp->type].pl_name;
116 return nchr[(int)gp->type].n_name;
118 return dchr[(int)gp->type].d_name;
126 get_empobj_mob_max(int type)
134 return plane_mob_max;