--- deliantra/server/socket/item.C 2007/02/10 01:52:29 1.37 +++ deliantra/server/socket/item.C 2007/04/03 00:21:38 1.43 @@ -266,16 +266,16 @@ if (QUERY_FLAG (head, FLAG_NO_PICK)) flags |= F_NOPICK; - if (!(ns.faces_sent[head->face->number] & NS_FACESENT_FACE)) - esrv_send_face (&ns, head->face->number, 0); + ns.send_face (head->face); + ns.flush_fx (); if (QUERY_FLAG (head, FLAG_ANIMATE) && !ns.anims_sent[head->animation_id]) - esrv_send_animation (&ns, head->animation_id); + ns.send_animation (head->animation_id); sl << uint32 (head->count) << uint32 (flags) << uint32 (QUERY_FLAG (head, FLAG_NO_PICK) ? -1 : WEIGHT (head)) - << uint32 (head->face->number); + << uint32 (head->face); if (!head->custom_name) { @@ -336,11 +336,10 @@ esrv_draw_look (object *pl) { int got_one = 0, start_look = 0, end_look = 0; - char buf[MAX_BUF]; if (!pl->contr->ns->update_look) { - LOG (llevDebug, "esrv_draw_look called when update_look was not set\n"); + LOG (llevDebug, "esrv_draw_look called when update_look was not set (player %s)\n", &pl->name); return; } else @@ -359,8 +358,8 @@ sl << uint32 (0); - if (!(pl->contr->ns->faces_sent[empty_face->number] & NS_FACESENT_FACE)) - esrv_send_face (pl->contr->ns, empty_face->number, 0); + pl->contr->ns->send_face (empty_face); + pl->contr->ns->flush_fx (); if (pl->contr->ns->look_position) { @@ -370,7 +369,7 @@ sl << uint32 (0x80000000 | (pl->contr->ns->look_position - FLOORBOX_PAGESIZE)) << uint32 (0) << sint32 (-1) - << uint32 (empty_face->number) + << uint32 (empty_face) << data8 (buf) << uint16 (0) << uint8 (0) @@ -407,7 +406,7 @@ sl << uint32 (0x80000000 | (pl->contr->ns->look_position + FLOORBOX_PAGESIZE)) << uint32 (0) << uint32 ((uint32) - 1) - << uint32 (empty_face->number) + << uint32 (empty_face) << data8 ("Apply this to see next group of items") << uint16 (0) << uint8 (0) @@ -504,7 +503,6 @@ * to the client (as defined in newclient.h - might as well use the * same value both places. */ - void esrv_update_item (int flags, object *pl, object *op) { @@ -559,10 +557,9 @@ if (flags & UPD_FACE) { - if (!(ns->faces_sent[op->face->number] & NS_FACESENT_FACE)) - esrv_send_face (ns, op->face->number, 0); - - sl << uint32 (op->face->number); + ns->send_face (op->face); + ns->flush_fx (); + sl << uint32 (op->face); } if (flags & UPD_NAME) @@ -672,7 +669,6 @@ * Tells the client to delete an item. Uses the item * command with a -1 location. */ - void esrv_del_item (player *pl, int tag) {