--- deliantra/server/socket/item.C 2007/01/09 21:32:43 1.32 +++ deliantra/server/socket/item.C 2007/03/11 02:12:45 1.41 @@ -266,8 +266,8 @@ 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); + if (!(ns.faces_sent[head->face] & NS_FACESENT_FACE)) + esrv_send_face (&ns, head->face, 0); if (QUERY_FLAG (head, FLAG_ANIMATE) && !ns.anims_sent[head->animation_id]) esrv_send_animation (&ns, head->animation_id); @@ -275,7 +275,7 @@ 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) { @@ -306,12 +306,12 @@ anim_speed = head->anim_speed; else { - if (FABS (head->speed) < 0.001) + if (fabs (head->speed) < 0.001) anim_speed = 255; - else if (FABS (head->speed) >= 1.0) + else if (fabs (head->speed) >= 1.0) anim_speed = 1; else - anim_speed = (int) (1.0 / FABS (head->speed)); + anim_speed = (int) (1.0 / fabs (head->speed)); } if (anim_speed > 255) @@ -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); + if (!(pl->contr->ns->faces_sent[empty_face] & NS_FACESENT_FACE)) + esrv_send_face (pl->contr->ns, empty_face, 0); 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) @@ -450,6 +449,9 @@ void esrv_send_inventory (object *pl, object *op) { + if (!pl->contr->ns)//D + return; + int got_one = 0; pl->contr->ns->send_packet_printf ("delinv %d", op->count); @@ -501,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) { @@ -556,10 +557,10 @@ if (flags & UPD_FACE) { - if (!(ns->faces_sent[op->face->number] & NS_FACESENT_FACE)) - esrv_send_face (ns, op->face->number, 0); + if (!(ns->faces_sent[op->face] & NS_FACESENT_FACE)) + esrv_send_face (ns, op->face, 0); - sl << uint32 (op->face->number); + sl << uint32 (op->face); } if (flags & UPD_NAME) @@ -603,12 +604,12 @@ anim_speed = op->anim_speed; else { - if (FABS (op->speed) < 0.001) + if (fabs (op->speed) < 0.001) anim_speed = 255; - else if (FABS (op->speed) >= 1.0) + else if (fabs (op->speed) >= 1.0) anim_speed = 1; else - anim_speed = (int) (1.0 / FABS (op->speed)); + anim_speed = (int) (1.0 / fabs (op->speed)); } if (anim_speed > 255) @@ -630,6 +631,9 @@ void esrv_send_item (object *pl, object *op) { + if (!pl->contr->ns) + return; + /* If this is not the player object, do some more checks */ if (op != pl) { @@ -666,10 +670,12 @@ * Tells the client to delete an item. Uses the item * command with a -1 location. */ - void esrv_del_item (player *pl, int tag) { + if (!pl->ns) + return; + packet sl ("delitem"); sl << uint32 (tag); @@ -875,8 +881,6 @@ } } - - /** Client wants to look at some object. Lets do so. */ void LookAt (char *buf, int len, player *pl) @@ -891,7 +895,7 @@ } dy = atoi (cp); - if (FABS (dx) > pl->ns->mapx / 2 || FABS (dy) > pl->ns->mapy / 2) + if (fabs (dx) > pl->ns->mapx / 2 || fabs (dy) > pl->ns->mapy / 2) return; if (pl->blocked_los[dx + pl->ns->mapx / 2][dy + pl->ns->mapy / 2])