X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=progs.h;h=fedd19e554cd66501557b61766a0b29b1c8bf5d2;hb=045f7768d970a449ecde1c762d141d83535170c1;hp=d5e59dbfa6acff2e0d611a1a1f23accb18b0cd8e;hpb=5aba57f18381d282c8a1be1dd5784bd94ec9f7f2;p=xonotic%2Fdarkplaces.git diff --git a/progs.h b/progs.h index d5e59dbf..fedd19e5 100644 --- a/progs.h +++ b/progs.h @@ -25,6 +25,13 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #define ENTITYGRIDAREAS 16 #define MAX_ENTITYCLUSTERS 16 +#define JOINTTYPE_POINT 1 +#define JOINTTYPE_HINGE 2 +#define JOINTTYPE_SLIDER 3 +#define JOINTTYPE_UNIVERSAL 4 +#define JOINTTYPE_HINGE2 5 +#define JOINTTYPE_FIXED -1 + typedef struct edict_engineprivate_s { // true if this edict is unused @@ -33,7 +40,7 @@ typedef struct edict_engineprivate_s // mess up client interpolation or obscure severe QuakeC bugs) float freetime; // mark for the leak detector - qboolean marked; + int mark; // place in the code where it was allocated (for the leak detector) const char *allocation_origin; // initially false to prevent projectiles from moving on their first frame @@ -68,6 +75,40 @@ typedef struct edict_engineprivate_s // moved, in case they need to be moved back vec3_t moved_from; vec3_t moved_fromangles; + + framegroupblend_t framegroupblend[MAX_FRAMEGROUPBLENDS]; + frameblend_t frameblend[MAX_FRAMEBLENDS]; + skeleton_t skeleton; + + // physics parameters + qboolean ode_physics; + void *ode_body; + void *ode_geom; + void *ode_joint; + float *ode_vertex3f; + int *ode_element3i; + int ode_numvertices; + int ode_numtriangles; + vec3_t ode_mins; + vec3_t ode_maxs; + vec_t ode_mass; + vec3_t ode_origin; + vec3_t ode_velocity; + vec3_t ode_angles; + vec3_t ode_avelocity; + qboolean ode_gravity; + int ode_modelindex; + vec_t ode_movelimit; // smallest component of (maxs[]-mins[]) + matrix4x4_t ode_offsetmatrix; + matrix4x4_t ode_offsetimatrix; + int ode_joint_type; + int ode_joint_enemy; + int ode_joint_aiment; + vec3_t ode_joint_origin; // joint anchor + vec3_t ode_joint_angles; // joint axis + vec3_t ode_joint_velocity; // second joint axis + vec3_t ode_joint_movedir; // parameters + void *ode_massbuf; } edict_engineprivate_t;