summaryrefslogtreecommitdiff
path: root/src/game/bg_local.h
blob: 603d57a79395a75ec91323e52bb620ef376871cb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
// Copyright (C) 1999-2000 Id Software, Inc.
//
// bg_local.h -- local definitions for the bg (both games) files

/*
 *  Portions Copyright (C) 2000-2001 Tim Angus
 *
 *  This program is free software; you can redistribute it and/or modify it
 *  under the terms of the OSML - Open Source Modification License v1.0 as
 *  described in the file COPYING which is distributed with this source
 *  code.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 */

#define MIN_WALK_NORMAL 0.7f   // can't walk on very steep slopes

#define STEPSIZE    18

#define TIMER_LAND        130
#define TIMER_GESTURE     (34*66+50)
#define TIMER_ATTACK      500 //nonsegmented models

#define OVERCLIP    1.001f

// all of the locals will be zeroed before each
// pmove, just to make damn sure we don't have
// any differences when running on client or server
typedef struct
{
  vec3_t    forward, right, up;
  float     frametime;

  int       msec;

  qboolean  walking;
  qboolean  groundPlane;
  qboolean  ladder;
  trace_t   groundTrace;

  float     impactSpeed;

  vec3_t    previous_origin;
  vec3_t    previous_velocity;
  int       previous_waterlevel;
} pml_t;

extern  pmove_t       *pm;
extern  pml_t         pml;

// movement parameters
extern  float pm_stopspeed;
extern  float pm_duckScale;
extern  float pm_swimScale;
extern  float pm_wadeScale;

extern  float pm_accelerate;
extern  float pm_airaccelerate;
extern  float pm_wateraccelerate;
extern  float pm_flyaccelerate;

extern  float pm_friction;
extern  float pm_waterfriction;
extern  float pm_flightfriction;

extern  int   c_pmove;

void PM_ClipVelocity( vec3_t in, vec3_t normal, vec3_t out, float overbounce );
void PM_AddTouchEnt( int entityNum );
void PM_AddEvent( int newEvent );

qboolean  PM_SlideMove( qboolean gravity );
void      PM_StepEvent( vec3_t from, vec3_t to, vec3_t normal );
qboolean  PM_StepSlideMove( qboolean gravity, qboolean predictive );
qboolean  PM_PredictStepMove( void );