+
+vec3 newlight_compute_spot( vec3 wnormal, vec3 halfview,
+ vec3 light_colour, vec3 light_pos,
+ vec4 light_dir )
+{
+ vec3 light_delta = (light_pos-aWorldCo) * 10.0;
+
+ float quadratic = dot(light_delta,light_delta);
+ float attenuation = 1.0f/( 1.0f + quadratic );
+
+ light_delta = normalize( light_delta );
+ attenuation *= max( 0.0, dot( light_delta, wnormal ) );
+
+ float spot_theta = max( 0.0, dot( light_delta, -light_dir.xyz ) ),
+ falloff = max( 0.0,( spot_theta - light_dir.w ) / (1.0-light_dir.w) );
+
+ return light_colour*attenuation*falloff;
+}