… | |
… | |
1489 | my ($path) = @_; |
1489 | my ($path) = @_; |
1490 | |
1490 | |
1491 | my ($match, $specificity); |
1491 | my ($match, $specificity); |
1492 | |
1492 | |
1493 | for my $region (list) { |
1493 | for my $region (list) { |
1494 | if ($region->match && $path =~ $region->match) { |
1494 | if ($region->{match} && $path =~ $region->{match}) { |
1495 | ($match, $specificity) = ($region, $region->specificity) |
1495 | ($match, $specificity) = ($region, $region->specificity) |
1496 | if $region->specificity > $specificity; |
1496 | if $region->specificity > $specificity; |
1497 | } |
1497 | } |
1498 | } |
1498 | } |
1499 | |
1499 | |
… | |
… | |
2256 | |
2256 | |
2257 | local $self->{_prev_pos} = $link_pos; # ugly hack for rent.ext |
2257 | local $self->{_prev_pos} = $link_pos; # ugly hack for rent.ext |
2258 | $self->enter_map ($map, $x, $y); |
2258 | $self->enter_map ($map, $x, $y); |
2259 | } |
2259 | } |
2260 | |
2260 | |
2261 | =item $player_object->goto ($path, $x, $y[, $check->($map)]) |
2261 | =item $player_object->goto ($path, $x, $y[, $check->($map)[, $done->()]]) |
2262 | |
2262 | |
2263 | Moves the player to the given map-path and coordinates by first freezing |
2263 | Moves the player to the given map-path and coordinates by first freezing |
2264 | her, loading and preparing them map, calling the provided $check callback |
2264 | her, loading and preparing them map, calling the provided $check callback |
2265 | that has to return the map if sucecssful, and then unfreezes the player on |
2265 | that has to return the map if sucecssful, and then unfreezes the player on |
2266 | the new (success) or old (failed) map position. |
2266 | the new (success) or old (failed) map position. In either case, $done will |
|
|
2267 | be called at the end of this process. |
2267 | |
2268 | |
2268 | =cut |
2269 | =cut |
2269 | |
2270 | |
2270 | our $GOTOGEN; |
2271 | our $GOTOGEN; |
2271 | |
2272 | |
2272 | sub cf::object::player::goto { |
2273 | sub cf::object::player::goto { |
2273 | my ($self, $path, $x, $y, $check) = @_; |
2274 | my ($self, $path, $x, $y, $check, $done) = @_; |
2274 | |
2275 | |
2275 | # do generation counting so two concurrent goto's will be executed in-order |
2276 | # do generation counting so two concurrent goto's will be executed in-order |
2276 | my $gen = $self->{_goto_generation} = ++$GOTOGEN; |
2277 | my $gen = $self->{_goto_generation} = ++$GOTOGEN; |
2277 | |
2278 | |
2278 | $self->enter_link; |
2279 | $self->enter_link; |
… | |
… | |
2298 | |
2299 | |
2299 | if ($gen == $self->{_goto_generation}) { |
2300 | if ($gen == $self->{_goto_generation}) { |
2300 | delete $self->{_goto_generation}; |
2301 | delete $self->{_goto_generation}; |
2301 | $self->leave_link ($map, $x, $y); |
2302 | $self->leave_link ($map, $x, $y); |
2302 | } |
2303 | } |
|
|
2304 | |
|
|
2305 | $done->() if $done; |
2303 | })->prio (1); |
2306 | })->prio (1); |
2304 | } |
2307 | } |
2305 | |
2308 | |
2306 | =item $player_object->enter_exit ($exit_object) |
2309 | =item $player_object->enter_exit ($exit_object) |
2307 | |
2310 | |
… | |
… | |
2465 | =cut |
2468 | =cut |
2466 | |
2469 | |
2467 | sub cf::client::ext_event($$%) { |
2470 | sub cf::client::ext_event($$%) { |
2468 | my ($self, $type, %msg) = @_; |
2471 | my ($self, $type, %msg) = @_; |
2469 | |
2472 | |
|
|
2473 | return unless $self->extcmd; |
|
|
2474 | |
2470 | $msg{msgtype} = "event_$type"; |
2475 | $msg{msgtype} = "event_$type"; |
2471 | $self->send_packet ("ext " . $self->{json_coder}->encode (\%msg)); |
2476 | $self->send_packet ("ext " . $self->{json_coder}->encode (\%msg)); |
2472 | } |
2477 | } |
2473 | |
2478 | |
2474 | =item $success = $client->query ($flags, "text", \&cb) |
2479 | =item $success = $client->query ($flags, "text", \&cb) |
… | |
… | |
2766 | my $meta = $enc->encode ({ |
2771 | my $meta = $enc->encode ({ |
2767 | name => $name, |
2772 | name => $name, |
2768 | type => $info->{type}, |
2773 | type => $info->{type}, |
2769 | copyright => $info->{copyright}, #TODO# |
2774 | copyright => $info->{copyright}, #TODO# |
2770 | }); |
2775 | }); |
2771 | my $data = pack "(w/a*)*", $meta, $info->{data}; |
|
|
2772 | my $chk = Digest::MD5::md5 "$info->{chksum},$meta"; # mangle data checksum and metadata |
|
|
2773 | |
2776 | |
2774 | my $idx = (cf::face::find $name) || cf::face::alloc $name; |
2777 | my $idx = (cf::face::find $name) || cf::face::alloc $name; |
|
|
2778 | |
|
|
2779 | if ($name =~ /\.jpg$/) { |
|
|
2780 | cf::face::set_data $idx, 0, $info->{data}, $info->{chksum};#d# temp hack |
|
|
2781 | cf::face::set_data $idx, 1, $info->{data}, $info->{chksum};#d# temp hack |
|
|
2782 | } else { |
|
|
2783 | my $data = pack "(w/a*)*", $meta, $info->{data}; |
|
|
2784 | my $chk = Digest::MD5::md5 "$info->{chksum},$meta"; # mangle data checksum and metadata |
|
|
2785 | |
2775 | cf::face::set_type $idx, 1; |
2786 | cf::face::set_type $idx, 1; |
2776 | cf::face::set_data $idx, 0, $data, $chk; |
2787 | cf::face::set_data $idx, 0, $data, $chk; |
|
|
2788 | } |
2777 | |
2789 | |
2778 | cf::cede_to_tick; |
2790 | cf::cede_to_tick; |
2779 | } |
2791 | } |
2780 | } |
2792 | } |
2781 | |
2793 | |
… | |
… | |
2783 | } |
2795 | } |
2784 | |
2796 | |
2785 | sub reload_regions { |
2797 | sub reload_regions { |
2786 | load_resource_file "$MAPDIR/regions" |
2798 | load_resource_file "$MAPDIR/regions" |
2787 | or die "unable to load regions file\n"; |
2799 | or die "unable to load regions file\n"; |
|
|
2800 | |
|
|
2801 | for (cf::region::list) { |
|
|
2802 | $_->{match} = qr/$_->{match}/ |
|
|
2803 | if exists $_->{match}; |
|
|
2804 | } |
2788 | } |
2805 | } |
2789 | |
2806 | |
2790 | sub reload_facedata { |
2807 | sub reload_facedata { |
2791 | load_facedata "$DATADIR/facedata" |
2808 | load_facedata "$DATADIR/facedata" |
2792 | or die "unable to load facedata\n"; |
2809 | or die "unable to load facedata\n"; |