2 * Empire - A multi-player, client/server Internet based war game.
3 * Copyright (C) 1986-2000, 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 the "LEGAL", "LICENSE", "CREDITS" and "README" files for all the
23 * related information and legal notices. It is expected that any future
24 * projects/authors will amend these files as needed.
30 * Known contributors to this file:
61 s_char flightpath[MAX_PATH_LEN];
64 struct nstr_item ni_bomb;
65 struct nstr_item ni_esc;
68 struct emp_qelem bomb_list;
69 struct emp_qelem esc_list;
71 struct sctstr ap_sect;
77 if (!snxtitem(&ni_bomb, EF_PLANE, player->argp[1]))
79 if (!snxtitem(&ni_esc, EF_PLANE,
80 getstarg(player->argp[2], "escort(s)? ", buf)))
81 pr("No escorts...\n");
82 if ((p = getstarg(player->argp[3], "assembly point? ", buf)) == 0
85 if (!sarg_xy(p, &x, &y) || !getsect(x, y, &ap_sect))
87 if (ap_sect.sct_own && ap_sect.sct_own != player->cnum &&
88 getrel(getnatp(ap_sect.sct_own), player->cnum) != ALLIED) {
89 pr("Assembly point not owned by you or an ally!\n");
94 if (getpath(flightpath, player->argp[4], ax, ay, 0, 0, 0, P_FLYING) == 0
99 (void)pathtoxy(flightpath, &tx, &ty, fcost);
100 pr("Ending sector is %s\n", xyas(tx, ty, player->cnum));
101 getsect(tx, ty, &target);
103 ip = whatitem(player->argp[5], "transport what? ");
105 if (pln_onewaymission(&target, &cno, &wantflags) < 0)
108 dst_ptr = (s_char *)⌖
109 dst_type = EF_SECTOR;
112 dst_ptr = (s_char *)&ship;
115 ap_to_target = strlen(flightpath);
116 if (*(flightpath + strlen(flightpath) - 1) == 'h')
118 pr("range to target is %d\n", ap_to_target);
120 * select planes within range
122 pln_sel(&ni_bomb, &bomb_list, &ap_sect, ap_to_target,
123 1, wantflags, P_M | P_O);
124 if (QEMPTY(&bomb_list)) {
125 pr("No planes could be equipped for the mission.\n");
130 pln_sel(&ni_esc, &esc_list, &ap_sect, ap_to_target,
131 1, wantflags, P_M | P_O);
132 if (cno >= 0 && !pln_oneway_to_carrier_ok(&bomb_list, &esc_list, cno)) {
133 pr("Not enough room on ship #%d!\n", cno);
137 * now arm and equip the bombers, transports, whatever.
138 * tech is stored in high 16 bits of mission_flags.
142 mission_flags |= P_X; /* stealth (shhh) */
143 mission_flags |= P_H; /* gets turned off if not all choppers */
145 pln_arm(&bomb_list, ap_to_target, 't', ip, 0, mission_flags,
147 if (QEMPTY(&bomb_list)) {
148 pr("No planes could be equipped for the mission.\n");
152 pln_arm(&esc_list, ap_to_target, 't', ip, P_ESC | P_F,
153 mission_flags, &tech);
154 ac_encounter(&bomb_list, &esc_list, ax, ay, flightpath, mission_flags,
156 if (QEMPTY(&bomb_list)) {
157 pr("No planes got through fighter defenses\n");
159 getsect(tx, ty, &target);
160 pln_dropoff(&bomb_list, ip, tx, ty, dst_ptr, dst_type);
161 pln_newlanding(&bomb_list, tx, ty, cno);
162 pln_newlanding(&esc_list, tx, ty, cno);