--- deliantra/server/socket/item.C 2007/05/28 21:22:26 1.45 +++ deliantra/server/socket/item.C 2007/06/03 17:05:36 1.46 @@ -333,40 +333,42 @@ * because object ordering would otherwise be inconsistent. */ void -esrv_draw_look (object *pl) +esrv_draw_look (player *pl) { int got_one = 0, start_look = 0, end_look = 0; - if (!pl->contr->ns->update_look) + object *ob = pl->ob; + + if (!pl->ns->update_look) { - LOG (llevDebug, "esrv_draw_look called when update_look was not set (player %s)\n", &pl->name); + LOG (llevDebug, "esrv_draw_look called when update_look was not set (player %s)\n", &ob->name); return; } else - pl->contr->ns->update_look = 0; + pl->ns->update_look = 0; - if (QUERY_FLAG (pl, FLAG_REMOVED) - || !pl->map - || pl->map->in_memory != MAP_IN_MEMORY - || out_of_map (pl->map, pl->x, pl->y)) + if (QUERY_FLAG (ob, FLAG_REMOVED) + || !ob->map + || ob->map->in_memory != MAP_IN_MEMORY + || out_of_map (ob->map, ob->x, ob->y)) return; - pl->contr->ns->send_packet ("delinv 0"); + pl->ns->send_packet ("delinv 0"); packet sl; - sl.printf ("item%d ", pl->contr->ns->itemcmd); + sl.printf ("item%d ", pl->ns->itemcmd); sl << uint32 (0); - pl->contr->ns->send_face (empty_face); - pl->contr->ns->flush_fx (); + pl->ns->send_face (empty_face); + pl->ns->flush_fx (); - if (pl->contr->ns->look_position) + if (pl->ns->look_position) { char buf[80]; snprintf (buf, 80, "Apply this to see %d previous items", FLOORBOX_PAGESIZE); - sl << uint32 (0x80000000 | (pl->contr->ns->look_position - FLOORBOX_PAGESIZE)) + sl << uint32 (0x80000000 | (pl->ns->look_position - FLOORBOX_PAGESIZE)) << uint32 (0) << sint32 (-1) << uint32 (empty_face) @@ -375,11 +377,11 @@ << uint8 (0) << uint32 (0); - if (pl->contr->ns->itemcmd == 2) + if (pl->ns->itemcmd == 2) sl << uint16 (0); } - object *tmp = pl->ms ().top; + object *tmp = ob->ms ().top; for (object *last = 0; tmp != last; tmp = tmp->below) { object *head; @@ -393,7 +395,7 @@ if (tmp->client_visible ()) { - if (++start_look < pl->contr->ns->look_position) + if (++start_look < pl->ns->look_position) continue; end_look++; @@ -403,7 +405,7 @@ /* What we basically do is make a 'fake' object - when the user applies it, * we notice the special tag the object has, and act accordingly. */ - sl << uint32 (0x80000000 | (pl->contr->ns->look_position + FLOORBOX_PAGESIZE)) + sl << uint32 (0x80000000 | (pl->ns->look_position + FLOORBOX_PAGESIZE)) << uint32 (0) << uint32 ((uint32) - 1) << uint32 (empty_face) @@ -412,7 +414,7 @@ << uint8 (0) << uint32 (0); - if (pl->contr->ns->itemcmd == 2) + if (pl->ns->itemcmd == 2) sl << uint16 (0); break; @@ -423,15 +425,15 @@ else head = tmp; - add_object_to_socklist (*pl->contr->ns, sl, head); + add_object_to_socklist (*pl->ns, sl, head); got_one++; if (sl.length () >= (MAXSOCKBUF - MAXITEMLEN)) { - pl->contr->ns->send_packet (sl); + pl->ns->send_packet (sl); sl.reset (); - sl.printf ("item%d ", pl->contr->ns->itemcmd); + sl.printf ("item%d ", pl->ns->itemcmd); sl << uint32 (0); got_one = 0; } @@ -439,7 +441,7 @@ } if (got_one) - pl->contr->ns->send_packet (sl); + pl->ns->send_packet (sl); }