From: terencehill Date: Thu, 27 Jul 2017 11:15:41 +0000 (+0200) Subject: Dynamically cache submerged state for waypoints and static items X-Git-Tag: xonotic-v0.8.5~2378^2~116 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=ea9b5cb05be578ab46ca4847e89b62c160edddd1;p=xonotic%2Fxonotic-data.pk3dir.git Dynamically cache submerged state for waypoints and static items --- diff --git a/qcsrc/server/bot/default/navigation.qc b/qcsrc/server/bot/default/navigation.qc index 37b1acf543..ebf2f6e165 100644 --- a/qcsrc/server/bot/default/navigation.qc +++ b/qcsrc/server/bot/default/navigation.qc @@ -37,6 +37,26 @@ void navigation_dynamicgoal_unset(entity this) this.nearestwaypointtimeout = -1; } +bool navigation_check_submerged_state(entity ent, vector pos) +{ + bool submerged; + if(IS_PLAYER(ent)) + submerged = (ent.waterlevel == WATERLEVEL_SUBMERGED); + else if(ent.nav_submerged_state != SUBMERGED_UNDEFINED) + submerged = (ent.nav_submerged_state == SUBMERGED_YES); + else + { + submerged = SUBMERGED(pos); + // NOTE: SUBMERGED check of box waypoint origin may fail even if origin + // is actually submerged because often they are inside some solid. + // That's why submerged state is saved now that we know current pos is + // not stuck in solid (previous tracewalk call to this pos was successfully) + if(!ent.navigation_dynamicgoal) + ent.nav_submerged_state = (submerged) ? SUBMERGED_YES : SUBMERGED_NO; + } + return submerged; +} + bool navigation_checkladders(entity e, vector org, vector m1, vector m2, vector end, vector end2, int movemode) { IL_EACH(g_ladders, it.classname == "func_ladder", diff --git a/qcsrc/server/bot/default/navigation.qh b/qcsrc/server/bot/default/navigation.qh index 4731e67bab..c188f53ac0 100644 --- a/qcsrc/server/bot/default/navigation.qh +++ b/qcsrc/server/bot/default/navigation.qh @@ -125,6 +125,12 @@ void navigation_dynamicgoal_init(entity this, bool initially_static); void navigation_dynamicgoal_set(entity this); void navigation_dynamicgoal_unset(entity this); +.int nav_submerged_state; +#define SUBMERGED_UNDEFINED 0 +#define SUBMERGED_NO 1 +#define SUBMERGED_YES 2 +bool navigation_check_submerged_state(entity ent, vector pos); + /* * Functions diff --git a/qcsrc/server/bot/default/waypoints.qc b/qcsrc/server/bot/default/waypoints.qc index 9e37d82593..f08c326916 100644 --- a/qcsrc/server/bot/default/waypoints.qc +++ b/qcsrc/server/bot/default/waypoints.qc @@ -227,11 +227,6 @@ entity waypoint_spawn(vector m1, vector m2, float f) } } setsize(w, '0 0 0', '0 0 0'); - - // can't apply the same logic to box waypoints because often they are - // inside some solid and SUBMERGED check would fail even if submerged - if(SUBMERGED(w.origin)) - w.waterlevel = WATERLEVEL_SUBMERGED; } waypoint_clearlinks(w); @@ -457,17 +452,8 @@ float waypoint_getlinearcost_underwater(float dist) float waypoint_gettravelcost(vector from, vector to, entity from_ent, entity to_ent) { - bool submerged_from; - if((from_ent.classname == "waypoint" && !from_ent.wpisbox) || from_ent.classname == "player") - submerged_from = (from_ent.waterlevel == WATERLEVEL_SUBMERGED); - else - submerged_from = SUBMERGED(from); - - bool submerged_to; - if((to_ent.classname == "waypoint" && !to_ent.wpisbox) || to_ent.classname == "player") - submerged_to = (to_ent.waterlevel == WATERLEVEL_SUBMERGED); - else - submerged_to = SUBMERGED(to); + bool submerged_from = navigation_check_submerged_state(from_ent, from); + bool submerged_to = navigation_check_submerged_state(to_ent, to); if (submerged_from && submerged_to) return waypoint_getlinearcost_underwater(vlen(to - from));