+
+#include "pathlib.qh"
+#include "utility.qh"
+
+.vector pos1, pos2;
+
vector pathlib_wateroutnode(vector start,vector end, float doedge)
-{
+{SELFPARAM();
vector surface;
pathlib_movenode_goodnode = 0;
- end_x = fsnap(end.x, pathlib_gridsize);
- end_y = fsnap(end.y, pathlib_gridsize);
+ end.x = fsnap(end.x, pathlib_gridsize);
+ end.y = fsnap(end.y, pathlib_gridsize);
traceline(end + ('0 0 0.25' * pathlib_gridsize),end - ('0 0 1' * pathlib_gridsize),MOVE_WORLDONLY,self);
end = trace_endpos;
}
vector pathlib_swimnode(vector start,vector end, float doedge)
-{
+{SELFPARAM();
pathlib_movenode_goodnode = 0;
if(pointcontents(start) != CONTENT_WATER)
return end;
- end_x = fsnap(end.x, pathlib_gridsize);
- end_y = fsnap(end.y, pathlib_gridsize);
+ end.x = fsnap(end.x, pathlib_gridsize);
+ end.y = fsnap(end.y, pathlib_gridsize);
if(pointcontents(end) == CONTENT_EMPTY)
return pathlib_wateroutnode( start, end, doedge);
}
vector pathlib_flynode(vector start,vector end, float doedge)
-{
+{SELFPARAM();
pathlib_movenode_goodnode = 0;
- end_x = fsnap(end.x, pathlib_gridsize);
- end_y = fsnap(end.y, pathlib_gridsize);
+ end.x = fsnap(end.x, pathlib_gridsize);
+ end.y = fsnap(end.y, pathlib_gridsize);
tracebox(start, movenode_boxmin,movenode_boxmax, end, MOVE_WORLDONLY, self);
if(trace_fraction == 1)
}
void a_think()
-{
+{SELFPARAM();
te_lightning1(self,self.origin, self.pos1);
if(self.cnt < time)
remove(self);
}
vector pathlib_walknode(vector start,vector end,float doedge)
-{
+{SELFPARAM();
vector direction,point,last_point,s,e;
float steps, distance, i;
- dprint("Walking node from ", vtos(start), " to ", vtos(end), "\n");
+ LOG_TRACE("Walking node from ", vtos(start), " to ", vtos(end), "\n");
pathlib_movenode_goodnode = 0;
- end_x = fsnap(end.x,pathlib_gridsize);
- end_y = fsnap(end.y,pathlib_gridsize);
- start_x = fsnap(start.x,pathlib_gridsize);
- start_y = fsnap(start.y,pathlib_gridsize);
+ end.x = fsnap(end.x,pathlib_gridsize);
+ end.y = fsnap(end.y,pathlib_gridsize);
+ start.x = fsnap(start.x,pathlib_gridsize);
+ start.y = fsnap(start.y,pathlib_gridsize);
// Find the floor
traceline(start + movenode_stepup, start - movenode_maxdrop, MOVE_WORLDONLY, self);
//start - movenode_maxdrop
a.cnt = time + 10;
- dprint("I cant walk on air!\n");
+ LOG_TRACE("I cant walk on air!\n");
return trace_endpos;
}
}
point = last_point + (direction * movenode_stepsize);
- point_x = fsnap(point.x,pathlib_gridsize);
- point_y = fsnap(point.y,pathlib_gridsize);
+ point.x = fsnap(point.x,pathlib_gridsize);
+ point.y = fsnap(point.y,pathlib_gridsize);
//dprint("end_x: ",ftos(end_x), " end_y: ",ftos(end_y),"\n");
//dprint("point_x:",ftos(point_x)," point_y:",ftos(point_y),"\n\n");