2 * Empire - A multi-player, client/server Internet based war game.
3 * Copyright (C) 1986-2013, Dave Pare, Jeff Bailey, Thomas Ruschak,
4 * Ken Stevens, Steve McClure, Markus Armbruster
6 * Empire 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 3 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, see <http://www.gnu.org/licenses/>.
21 * See files README, COPYING and CREDITS in the root of the source
22 * tree for related information and legal notices. It is expected
23 * that future projects/authors will amend these files as needed.
27 * satmap.c: Do a satellite map given an x,y location, effic and other
29 * Known contributors to this file:
31 * Markus Armbruster, 2004-2011
47 #include "prototypes.h"
56 satmap(int x, int y, int eff, int range, int flags, int type)
69 signed char noise[100];
75 radbuf = malloc(WORLD_Y * MAPWIDTH(1));
77 rad = malloc(WORLD_Y * sizeof(char *));
79 for (rx = 0; rx < WORLD_Y; rx++)
80 rad[rx] = &radbuf[(WORLD_X + 1) * rx];
84 if (!radbuf || !rad) {
85 pr("Memory error in satmap, tell the deity.\n");
89 range = range * (eff / 100.0);
90 pr("%s efficiency %d%%, max range %d\n",
91 xyas(x, y, player->cnum), eff, range);
92 memset(noise, 0, sizeof(noise));
94 pr("Some noise on the transmission...\n");
95 for (n = 0; n < (100 - eff); ++n)
96 noise[100 * n / (100 - eff)] = 1;
99 if (type == EF_BAD || type == EF_SECTOR) {
100 snxtsct_dist(&ns, x, y, range);
101 if (type == EF_SECTOR && !snxtsct_use_condarg(&ns))
105 blankfill(radbuf, &ns.range, 1);
107 pr("Satellite sector report\n");
112 while (nxtsct(&ns, §)) {
113 if (++crackle == 100)
118 if (sect.sct_own && sect.sct_own != player->cnum) {
119 satdisp_sect(§, (flags & P_I) ? 5 : 50);
120 changed += map_set(player->cnum, sect.sct_x, sect.sct_y,
121 dchr[sect.sct_type].d_mnem, 0);
124 setcont(player->cnum, sect.sct_own, FOUND_FLY);
128 sect.sct_type == SCT_WATER || sect.sct_type == SCT_MOUNT) {
129 rad[ns.dy][ns.dx] = dchr[sect.sct_type].d_mnem;
131 rad[ns.dy][ns.dx] = '?';
133 map_set(player->cnum, ns.x, ns.y, rad[ns.dy][ns.dx], 0);
136 writemap(player->cnum);
138 pr(" %d sectors\n\n", count);
141 if ((type == EF_BAD || type == EF_SHIP) &&
142 (flags & P_S || flags & P_I)) {
143 snxtitem_dist(&ni, EF_SHIP, x, y, range);
144 if (type == EF_SHIP && !snxtitem_use_condarg(&ni))
149 pr("Satellite ship report\n");
151 pr(" own shp# ship type sector eff\n");
153 while (nxtitem(&ni, &ship)) {
154 if (ship.shp_own == 0)
156 if ((mchr[(int)ship.shp_type].m_flags & M_SUB) &&
157 ((flags & (P_S | P_I)) != (P_S | P_I)))
159 if (++crackle == 100)
164 pr("%4d %4d %-16.16s %-25.25s ",
165 ship.shp_own, ship.shp_uid,
166 mchr[(int)ship.shp_type].m_name, ship.shp_name);
167 prxy("%4d,%-4d ", ship.shp_x, ship.shp_y);
168 pr("%3d%%\n", ship.shp_effic);
171 setcont(player->cnum, ship.shp_own, FOUND_FLY);
173 /* If we are imaging *and* drawing the map */
174 if ((flags & P_I) && (type == EF_BAD)) {
175 rx = deltx(&ns.range, ship.shp_x);
176 ry = delty(&ns.range, ship.shp_y);
177 /* &~0x20 makes it a cap letter */
178 rad[ry][rx] = (*mchr[(int)ship.shp_type].m_name) & ~0x20;
182 pr(" %d ships\n\n", count);
185 if ((type == EF_BAD || type == EF_LAND) &&
186 (flags & P_S || flags & P_I)) {
187 snxtitem_dist(&ni, EF_LAND, x, y, range);
188 if (type == EF_LAND && !snxtitem_use_condarg(&ni))
193 pr("Satellite unit report\n");
195 pr(" own lnd# unit type sector eff\n");
197 while (nxtitem(&ni, &land)) {
198 if (land.lnd_own == 0)
200 if (lchr[(int)land.lnd_type].l_flags & L_SPY)
202 if (!chance(land.lnd_effic / 20.0))
204 if (++crackle == 100)
209 pr("%4d %4d %-16.16s ",
210 land.lnd_own, land.lnd_uid,
211 lchr[(int)land.lnd_type].l_name);
212 prxy("%4d,%-4d", land.lnd_x, land.lnd_y);
213 pr("%3d%%\n", land.lnd_effic);
216 setcont(player->cnum, land.lnd_own, FOUND_FLY);
218 /* If we are imaging *and* drawing the map */
219 if ((flags & P_I) && (type == EF_BAD)) {
220 rx = deltx(&ns.range, land.lnd_x);
221 ry = delty(&ns.range, land.lnd_y);
222 /* &~0x20 makes it a cap letter */
223 rad[ry][rx] = (*lchr[(int)land.lnd_type].l_name) & ~0x20;
227 pr(" %d units\n\n", count);
230 /* Ok, have we made the map? If so, display it */
231 if (type == EF_BAD) {
234 * We have to make the center a '0' for ve
235 * ve needs a garbage line to terminate the map
237 rad[delty(&ns.range, y)][deltx(&ns.range, y)] = '0';
239 pr("Satellite radar report\n");
241 for (row = 0; row < n; row++)
242 pr("%s\n", rad[row]);
243 pr("\n(c) 1989 Imaginative Images Inc.\n");
251 pr(" sct rd rl def\n");
252 pr(" sect type own eff eff eff eff civ mil shl gun iron pet food\n");
256 satdisp_sect(struct sctstr *sp, int acc)
258 prxy("%4d,%-4d ", sp->sct_x, sp->sct_y);
259 pr("%c %3d %3d %3d %3d %3d %4d %4d %4d %4d %4d %4d %5d\n",
260 dchr[sp->sct_type].d_mnem,
261 sp->sct_own, roundintby((int)sp->sct_effic, acc / 2),
262 roundintby((int)sp->sct_road, acc / 2),
263 opt_RAILWAYS ? !!sct_rail_track(sp) : roundintby(sp->sct_rail, acc / 2),
264 roundintby((int)sp->sct_defense, acc / 2),
265 roundintby(sp->sct_item[I_CIVIL], acc),
266 roundintby(sp->sct_item[I_MILIT], acc),
267 roundintby(sp->sct_item[I_SHELL], acc),
268 roundintby(sp->sct_item[I_GUN], acc),
269 roundintby(sp->sct_item[I_IRON], acc),
270 roundintby(sp->sct_item[I_PETROL], acc),
271 roundintby(sp->sct_item[I_FOOD], acc));
275 satdisp_units(coord x, coord y)
282 snxtitem_xy(&ni, EF_SHIP, x, y);
284 while (nxtitem(&ni, &ship)) {
285 if (ship.shp_own == 0)
287 if (mchr[(int)ship.shp_type].m_flags & M_SUB)
290 pr("\t own shp# ship type sector eff\n");
293 pr("\t%4d %4d %-16.16s %-25.25s ",
294 ship.shp_own, ship.shp_uid,
295 mchr[(int)ship.shp_type].m_name, ship.shp_name);
296 prxy("%4d,%-4d ", ship.shp_x, ship.shp_y);
297 pr("%3d%%\n", ship.shp_effic);
303 snxtitem_xy(&ni, EF_LAND, x, y);
306 while (nxtitem(&ni, &land)) {
307 if (land.lnd_own == 0)
309 if (land.lnd_ship >= 0 || land.lnd_land >= 0)
311 if (lchr[(int)land.lnd_type].l_flags & L_SPY)
313 if (!chance(land.lnd_effic / 20.0))
317 pr("\t own lnd# unit type sector eff\n");
321 pr("\t%4d %4d %-16.16s ",
322 land.lnd_own, land.lnd_uid, lchr[(int)land.lnd_type].l_name);
323 prxy("%4d,%-4d ", land.lnd_x, land.lnd_y);
324 pr("%3d%%\n", land.lnd_effic);