ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/lib/cf.pm
(Generate patch)

Comparing deliantra/server/lib/cf.pm (file contents):
Revision 1.257 by root, Sat Apr 21 17:34:24 2007 UTC vs.
Revision 1.260 by root, Fri Apr 27 19:53:05 2007 UTC

1862} 1862}
1863 1863
1864sub cf::object::player::enter_link { 1864sub cf::object::player::enter_link {
1865 my ($self) = @_; 1865 my ($self) = @_;
1866 1866
1867 $self->deactivate_recursive;
1868
1867 return if UNIVERSAL::isa $self->map, "ext::map_link"; 1869 return if UNIVERSAL::isa $self->map, "ext::map_link";
1868 1870
1869 $self->{_link_pos} ||= [$self->map->{path}, $self->x, $self->y] 1871 $self->{_link_pos} ||= [$self->map->{path}, $self->x, $self->y]
1870 if $self->map; 1872 if $self->map;
1871 1873
2921 prio => 6, 2923 prio => 6,
2922 cb => \&IO::AIO::poll_cb, 2924 cb => \&IO::AIO::poll_cb,
2923 ); 2925 );
2924} 2926}
2925 2927
2928sub _log_backtrace {
2929 my ($msg, @addr) = @_;
2930
2931 async {
2932 my @bt = fork_call {
2933 @addr = map { sprintf "%x", $_ } @addr;
2934 open my $fh, "exec addr2line -C -f -i -e \Q$^X\E @addr 2>&1 |"
2935 or die "addr2line: $!";
2936
2937 my @funcs;
2938 my @res = <$fh>;
2939 chomp for @res;
2940 while (@res) {
2941 my ($func, $line) = splice @res, 0, 2, ();
2942 push @funcs, "[$func] $line";
2943 }
2944
2945 @funcs
2946 };
2947
2948 $msg =~ s/\n//;
2949
2950 LOG llevInfo, "[ABT] $msg\n";
2951 LOG llevInfo, "[ABT] $_\n" for @bt;
2952 };
2953}
2954
2926# load additional modules 2955# load additional modules
2927use cf::pod; 2956use cf::pod;
2928 2957
2929END { cf::emergency_save } 2958END { cf::emergency_save }
2930 2959

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines