… | |
… | |
10 | |
10 | |
11 | my $timer = Event->timer (interval => 0.2, parked => 1, data => cf::WF_AUTOCANCEL, cb => sub { |
11 | my $timer = Event->timer (interval => 0.2, parked => 1, data => cf::WF_AUTOCANCEL, cb => sub { |
12 | cf::sync_job { |
12 | cf::sync_job { |
13 | while (my ($name, $v) = each %follow) { |
13 | while (my ($name, $v) = each %follow) { |
14 | my ($target, $his, $mine) = @$v; |
14 | my ($target, $his, $mine) = @$v; |
15 | my ($who, $other) = (cf::player::find $name, cf::player::find $target); |
15 | my ($who, $other) = (cf::player::find_active $name, cf::player::find_active $target); |
16 | |
16 | |
17 | if ($who && $other && $other->ob->map) { |
17 | if ($who && $other && $other->ob->map) { |
18 | my ($map, $x, $y) = ($other->ob->map->path, $other->ob->x, $other->ob->y); |
18 | my ($map, $x, $y) = ($other->ob->map->path, $other->ob->x, $other->ob->y); |
19 | |
19 | |
20 | if ($map ne $his->[0] || $x != $his->[1] || $y != $his->[2]) { |
20 | if ($map ne $his->[0] || $x != $his->[1] || $y != $his->[2]) { |
… | |
… | |
46 | my ($who, $args) = @_; |
46 | my ($who, $args) = @_; |
47 | |
47 | |
48 | my $name = $who->name; |
48 | my $name = $who->name; |
49 | |
49 | |
50 | if ($args ne "" && $name ne $args) { |
50 | if ($args ne "" && $name ne $args) { |
51 | if (my $other = cf::player::find $args) { |
51 | if (my $other = cf::player::find_active $args) { |
52 | if ($other->ob->map eq $who->map |
52 | if ($other->ob->map == $who->map |
53 | && abs ($other->ob->x - $who->x) <= 1 |
53 | && abs ($other->ob->x - $who->x) <= 1 |
54 | && abs ($other->ob->y - $who->y) <= 1) { |
54 | && abs ($other->ob->y - $who->y) <= 1) { |
55 | $who->message ("Following player '$args', to stop, type: 'follow"); |
55 | $who->message ("Following player '$args', to stop, type: 'follow"); |
56 | $other->ob->message ("$name is now following your every step..."); |
56 | $other->ob->message ("$name is now following your every step..."); |
57 | $follow{$name} = [ |
57 | $follow{$name} = [ |