X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fserver%2Fantilag.qc;h=68ec68324d78f785ff84fde5167d7a44a0b1493a;hb=25d4fae5eb2e4b1f85ef90f7d99b9d2200d1c0bc;hp=69d291a4ed69018848e0ebccb7c897b250b922d1;hpb=3f7cf41d0713c7f5af9f123b40016585eb210be6;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/antilag.qc b/qcsrc/server/antilag.qc index 69d291a4e..68ec68324 100644 --- a/qcsrc/server/antilag.qc +++ b/qcsrc/server/antilag.qc @@ -3,6 +3,7 @@ .float antilag_times[ANTILAG_MAX_ORIGINS]; .float antilag_index; .vector antilag_saved_origin; +.float antilag_takenback; .float antilag_debug; @@ -65,9 +66,11 @@ vector antilag_takebackorigin(entity e, float t) i0 = antilag_find(e, t); if(i0 < 0) { - i0 = e.antilag_index - 1; - if(i0 < 0) - i0 = ANTILAG_MAX_ORIGINS - 1; + // IN THE PRESENT + if(e.antilag_takenback) + return e.antilag_saved_origin; + else + return e.origin; } i1 = i0 + 1; if(i1 >= ANTILAG_MAX_ORIGINS) @@ -89,17 +92,37 @@ vector antilag_takebackavgvelocity(entity e, float t0, float t1) void antilag_takeback(entity e, float t) { - if(e.vehicle) - antilag_takeback(e.vehicle, t); + if(e.vehicle) + antilag_takeback(e.vehicle, t); + + if(!e.antilag_takenback) + e.antilag_saved_origin = e.origin; - e.antilag_saved_origin = e.origin; setorigin(e, antilag_takebackorigin(e, t)); + e.antilag_takenback = TRUE; } void antilag_restore(entity e) { - if(e.vehicle) - antilag_restore(e.vehicle); + if(e.vehicle) + antilag_restore(e.vehicle); + + if(!e.antilag_takenback) + return; setorigin(e, e.antilag_saved_origin); + e.antilag_takenback = FALSE; +} + +void antilag_clear(entity e) +{ + float i; + + antilag_restore(e); + for(i = 0; i < ANTILAG_MAX_ORIGINS; ++i) + { + e.(antilag_times[i]) = -2342; + e.(antilag_origins[i]) = self.origin; + } + e.antilag_index = ANTILAG_MAX_ORIGINS - 1; // next one is 0 }