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.324 by root, Sat Jul 28 14:23:17 2007 UTC vs.
Revision 1.330 by elmex, Fri Aug 10 10:35:07 2007 UTC

1370 $self->{deny_save} = 1; 1370 $self->{deny_save} = 1;
1371 1371
1372 $cf::PLAYER{$login} = $self; 1372 $cf::PLAYER{$login} = $self;
1373 1373
1374 $self 1374 $self
1375}
1376
1377=item $player->send_msg ($channel, $msg, $color, [extra...])
1378
1379=cut
1380
1381sub send_msg {
1382 my $ns = shift->ns
1383 or return;
1384 $ns->send_msg (@_);
1375} 1385}
1376 1386
1377=item $pl->quit_character 1387=item $pl->quit_character
1378 1388
1379Nukes the player without looking back. If logged in, the connection will 1389Nukes the player without looking back. If logged in, the connection will
1921 $self->set_darkness_map; 1931 $self->set_darkness_map;
1922 Coro::cede; 1932 Coro::cede;
1923 $self->activate; 1933 $self->activate;
1924 } 1934 }
1925 1935
1926 $map->{last_save} = $cf::RUNTIME; 1936 $self->{last_save} = $cf::RUNTIME;
1927 $map->last_access ($cf::RUNTIME); 1937 $self->last_access ($cf::RUNTIME);
1928 1938
1929 $self->in_memory (cf::MAP_IN_MEMORY); 1939 $self->in_memory (cf::MAP_IN_MEMORY);
1930 } 1940 }
1931 1941
1932 $self->post_load; 1942 $self->post_load;
2241 } else { 2251 } else {
2242 $msg = $npc->name . " says: $msg" if $npc; 2252 $msg = $npc->name . " says: $msg" if $npc;
2243 $self->message ($msg, $flags); 2253 $self->message ($msg, $flags);
2244 } 2254 }
2245 } 2255 }
2256}
2257
2258=item $object->send_msg ($channel, $msg, $color, [extra...])
2259
2260=cut
2261
2262sub cf::object::send_msg {
2263 my $pl = shift->contr
2264 or return;
2265 $pl->send_msg (@_);
2246} 2266}
2247 2267
2248=item $player_object->may ("access") 2268=item $player_object->may ("access")
2249 2269
2250Returns wether the given player is authorized to access resource "access" 2270Returns wether the given player is authorized to access resource "access"
2550 || s/<fg name=\"([^"]+)\">([^<]*)<\/fg>/[color=$1]${2}[\/color]/; 2570 || s/<fg name=\"([^"]+)\">([^<]*)<\/fg>/[color=$1]${2}[\/color]/;
2551 } 2571 }
2552 2572
2553 $color &= cf::NDI_COLOR_MASK; 2573 $color &= cf::NDI_COLOR_MASK;
2554 2574
2575 utf8::encode $msg;
2576
2555 if (0 && $msg =~ /\[/) { 2577 if (0 && $msg =~ /\[/) {
2556 $self->send_packet ("drawextinfo $color 4 0 $msg") 2578 $self->send_packet ("drawextinfo $color 4 0 $msg")
2557 } else { 2579 } else {
2558 $msg =~ s/\[\/?(?:b|i|u|fixed|color)[^\]]*\]//g; 2580 $msg =~ s/\[\/?(?:b|i|u|fixed|color)[^\]]*\]//g;
2559 $self->send_packet ("drawinfo $color $msg") 2581 $self->send_packet ("drawinfo $color $msg")
2708our $safe = new Safe "safe"; 2730our $safe = new Safe "safe";
2709our $safe_hole = new Safe::Hole; 2731our $safe_hole = new Safe::Hole;
2710 2732
2711$SIG{FPE} = 'IGNORE'; 2733$SIG{FPE} = 'IGNORE';
2712 2734
2713$safe->permit_only (Opcode::opset qw(:base_core :base_mem :base_orig :base_math sort time)); 2735$safe->permit_only (Opcode::opset qw(
2736 :base_core :base_mem :base_orig :base_math
2737 grepstart grepwhile mapstart mapwhile
2738 sort time
2739));
2714 2740
2715# here we export the classes and methods available to script code 2741# here we export the classes and methods available to script code
2716 2742
2717=pod 2743=pod
2718 2744
2719The following functions and methods are available within a safe environment: 2745The following functions and methods are available within a safe environment:
2720 2746
2721 cf::object 2747 cf::object
2722 contr pay_amount pay_player map x y force_find force_add 2748 contr pay_amount pay_player map x y force_find force_add
2723 insert remove 2749 insert remove name archname title slaying race
2724 2750
2725 cf::object::player 2751 cf::object::player
2726 player 2752 player
2727 2753
2728 cf::player 2754 cf::player
2733 2759
2734=cut 2760=cut
2735 2761
2736for ( 2762for (
2737 ["cf::object" => qw(contr pay_amount pay_player map force_find force_add x y 2763 ["cf::object" => qw(contr pay_amount pay_player map force_find force_add x y
2738 insert remove)], 2764 insert remove inv name archname title slaying race)],
2739 ["cf::object::player" => qw(player)], 2765 ["cf::object::player" => qw(player)],
2740 ["cf::player" => qw(peaceful)], 2766 ["cf::player" => qw(peaceful)],
2741 ["cf::map" => qw(trigger)], 2767 ["cf::map" => qw(trigger)],
2742) { 2768) {
2743 no strict 'refs'; 2769 no strict 'refs';
2909 for (0 .. SOUND_CAST_SPELL_0 - 1) { 2935 for (0 .. SOUND_CAST_SPELL_0 - 1) {
2910 my $sound = $soundconf->{compat}[$_] 2936 my $sound = $soundconf->{compat}[$_]
2911 or next; 2937 or next;
2912 2938
2913 my $face = cf::face::find "sound/$sound->[1]"; 2939 my $face = cf::face::find "sound/$sound->[1]";
2914
2915 cf::sound::set $sound->[0] => $face; 2940 cf::sound::set $sound->[0] => $face;
2916 cf::sound::old_sound_index $_, $face; # gcfclient-compat 2941 cf::sound::old_sound_index $_, $face; # gcfclient-compat
2917 } 2942 }
2918 2943
2944 while (my ($k, $v) = each %{$soundconf->{event}}) {
2945 my $face = cf::face::find "sound/$v";
2946 cf::sound::set $k => $face;
2919 #TODO 2947 }
2920 } 2948 }
2921 } 2949 }
2922 2950
2923 1 2951 1
2924} 2952}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines