… | |
… | |
193 | { |
193 | { |
194 | LOG (llevDebug, "esrv_draw_look called when update_look was not set (player %s)\n", &ob->name); |
194 | LOG (llevDebug, "esrv_draw_look called when update_look was not set (player %s)\n", &ob->name); |
195 | return; |
195 | return; |
196 | } |
196 | } |
197 | |
197 | |
|
|
198 | if (pl->ns->need_delinv0) |
|
|
199 | { |
|
|
200 | pl->ns->need_delinv0 = 0; |
198 | pl->ns->send_packet ("delinv 0"); |
201 | pl->ns->send_packet ("delinv 0"); |
|
|
202 | } |
199 | |
203 | |
200 | if (pl->run_on) |
204 | if (pl->run_on) |
201 | return; |
205 | return; |
202 | |
206 | |
203 | pl->ns->update_look = 0; |
207 | pl->ns->update_look = 0; |
|
|
208 | pl->ns->need_delinv0 = 1; |
204 | |
209 | |
205 | if (ob->flag [FLAG_REMOVED] |
210 | if (ob->flag [FLAG_REMOVED] |
206 | || !ob->map |
211 | || !ob->map |
207 | || ob->map->in_memory != MAP_ACTIVE |
212 | || ob->map->in_memory != MAP_ACTIVE |
208 | || out_of_map (ob->map, ob->x, ob->y)) |
213 | || out_of_map (ob->map, ob->x, ob->y)) |
… | |
… | |
622 | pl->ns->look_position = tag & 0x7fffffff; |
627 | pl->ns->look_position = tag & 0x7fffffff; |
623 | pl->ns->floorbox_update (); |
628 | pl->ns->floorbox_update (); |
624 | return; |
629 | return; |
625 | } |
630 | } |
626 | |
631 | |
|
|
632 | // the object might be legally gone already |
627 | object *op = esrv_get_ob_from_count (pl->ob, tag); |
633 | if (object *op = esrv_get_ob_from_count (pl->ob, tag)) |
628 | |
|
|
629 | if (!op) |
|
|
630 | { |
|
|
631 | LOG (llevDebug, "Player '%s' tried to apply the unknown object (%d)\n", &pl->ob->name, tag); |
|
|
632 | return; |
|
|
633 | } |
|
|
634 | |
|
|
635 | pl->ob->apply (op, AP_TOGGLE); |
634 | pl->ob->apply (op, AP_TOGGLE); |
636 | } |
635 | } |
637 | |
636 | |
638 | /** Client wants to lock some object. Lets do so. */ |
637 | /** Client wants to lock some object. Lets do so. */ |
639 | void |
638 | void |
640 | LockItem (char *data, int len, player *pl) |
639 | LockItem (char *data, int len, player *pl) |