UFO: Alien Invasion
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
e_event_actorreactionfireabortshot.cpp
Go to the documentation of this file.
1 
5 /*
6 Copyright (C) 2002-2020 UFO: Alien Invasion.
7 
8 This program is free software; you can redistribute it and/or
9 modify it under the terms of the GNU General Public License
10 as published by the Free Software Foundation; either version 2
11 of the License, or (at your 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.
16 
17 See the GNU General Public License for more details.
18 
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 
23 */
24 
25 #include "../../../../client.h"
26 #include "../../../cl_localentity.h"
27 #include "../../../cl_actor.h"
28 #include "../../../cl_hud.h"
29 #include "../../../../ui/ui_main.h"
31 
33 {
34  int targetEntNum;
35  int unused;
36  int step;
37 
38  NET_ReadFormat(msg, self->formatString, &unused, &targetEntNum, &step);
39 
40  const le_t* target = LE_Get(targetEntNum);
41  if (!target)
42  LE_NotFoundError(targetEntNum);
43  if (step >= MAX_ROUTE)
44  return eventTiming->nextTime;
45 
46  return CL_GetStepTime(eventTiming, target, step);
47 }
48 
56 {
57  int shooterEntNum;
58  int targetEntNum;
59  int unused;
60 
61  NET_ReadFormat(msg, self->formatString, &shooterEntNum, &targetEntNum, &unused);
62 
63  const le_t* shooter = LE_Get(shooterEntNum);
64  if (!shooter)
65  LE_NotFoundError(shooterEntNum);
66 
67  const le_t* target = LE_Get(targetEntNum);
68  if (!target)
69  LE_NotFoundError(targetEntNum);
70 
71  UI_ExecuteConfunc("reactionfire_shotaborted %i %i", shooterEntNum, target->entnum);
72 }
int entnum
void NET_ReadFormat(dbuffer *buf, const char *format,...)
The user-friendly version of NET_ReadFormat that reads variable arguments from a buffer according to ...
Definition: netpack.cpp:533
CL_ParseEvent timers and vars.
Definition: e_main.h:30
le_t * LE_Get(int entnum)
Searches all local entities for the one with the searched entnum.
#define MAX_ROUTE
Definition: defines.h:84
int CL_ActorReactionFireAbortShotTime(const eventRegister_t *self, dbuffer *msg, eventTiming_t *eventTiming)
Struct that defines one particular event with all its callbacks and data.
Definition: e_main.h:42
int CL_GetStepTime(const eventTiming_t *eventTiming, const le_t *le, int step)
Calculates the time when the given step was executed in the event chain.
Definition: e_main.cpp:177
a local entity
void CL_ActorReactionFireAbortShot(const eventRegister_t *self, dbuffer *msg)
Network event function for reaction fire target handling. Responsible for updating the HUD with the i...
int nextTime
Definition: e_main.h:31
void UI_ExecuteConfunc(const char *fmt,...)
Executes confunc - just to identify those confuncs in the code - in this frame.
Definition: ui_main.cpp:110
#define LE_NotFoundError(entnum)