+#include "cl_collision.h"
+
+void CL_UpdatePrydonCursor(void)
+{
+ vec3_t temp, scale;
+
+ if (!cl_prydoncursor.integer)
+ VectorClear(cl.cmd.cursor_screen);
+
+ /*
+ if (cl.cmd.cursor_screen[0] < -1)
+ {
+ cl.viewangles[YAW] -= m_yaw.value * (cl.cmd.cursor_screen[0] - -1) * vid.realwidth * sensitivity.value * cl.viewzoom;
+ cl.cmd.cursor_screen[0] = -1;
+ }
+ if (cl.cmd.cursor_screen[0] > 1)
+ {
+ cl.viewangles[YAW] -= m_yaw.value * (cl.cmd.cursor_screen[0] - 1) * vid.realwidth * sensitivity.value * cl.viewzoom;
+ cl.cmd.cursor_screen[0] = 1;
+ }
+ if (cl.cmd.cursor_screen[1] < -1)
+ {
+ cl.viewangles[PITCH] += m_pitch.value * (cl.cmd.cursor_screen[1] - -1) * vid.realheight * sensitivity.value * cl.viewzoom;
+ cl.cmd.cursor_screen[1] = -1;
+ }
+ if (cl.cmd.cursor_screen[1] > 1)
+ {
+ cl.viewangles[PITCH] += m_pitch.value * (cl.cmd.cursor_screen[1] - 1) * vid.realheight * sensitivity.value * cl.viewzoom;
+ cl.cmd.cursor_screen[1] = 1;
+ }
+ */
+ cl.cmd.cursor_screen[0] = bound(-1, cl.cmd.cursor_screen[0], 1);
+ cl.cmd.cursor_screen[1] = bound(-1, cl.cmd.cursor_screen[1], 1);
+ cl.cmd.cursor_screen[2] = 1;
+
+ scale[0] = -tan(r_refdef.fov_x * M_PI / 360.0);
+ scale[1] = -tan(r_refdef.fov_y * M_PI / 360.0);
+ scale[2] = 1;
+
+ // trace distance
+ VectorScale(scale, 1000000, scale);
+
+ // FIXME: use something other than renderer variables here
+ // (but they need to match)
+ VectorCopy(r_vieworigin, cl.cmd.cursor_start);
+ VectorSet(temp, cl.cmd.cursor_screen[2] * scale[2], cl.cmd.cursor_screen[0] * scale[0], cl.cmd.cursor_screen[1] * scale[1]);
+ Matrix4x4_Transform(&r_view_matrix, temp, cl.cmd.cursor_end);
+ cl.cmd.cursor_fraction = CL_SelectTraceLine(cl.cmd.cursor_start, cl.cmd.cursor_end, cl.cmd.cursor_impact, cl.cmd.cursor_normal, &cl.cmd.cursor_entitynumber);
+ // makes sparks where cursor is
+ //CL_SparkShower(cl.cmd.cursor_impact, cl.cmd.cursor_normal, 5, 0);
+}