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.83 by root, Mon Dec 11 01:30:41 2006 UTC vs.
Revision 1.86 by root, Thu Dec 14 05:09:32 2006 UTC

16# work around bug in YAML::Syck - bad news for perl6, will it be as broken wrt. unicode? 16# work around bug in YAML::Syck - bad news for perl6, will it be as broken wrt. unicode?
17$YAML::Syck::ImplicitUnicode = 1; 17$YAML::Syck::ImplicitUnicode = 1;
18 18
19use strict; 19use strict;
20 20
21our %COMMAND = ();
22our %COMMAND_TIME = ();
23our %EXTCMD = ();
24
21_init_vars; 25_init_vars;
22 26
23our %COMMAND = ();
24our @EVENT; 27our @EVENT;
25our $LIBDIR = maps_directory "perl"; 28our $LIBDIR = maps_directory "perl";
26 29
27our $TICK = MAX_TIME * 1e-6; 30our $TICK = MAX_TIME * 1e-6;
28our $TICK_WATCHER; 31our $TICK_WATCHER;
29our $NEXT_TICK; 32our $NEXT_TICK;
30 33
31our %CFG; 34our %CFG;
32 35
33our $uptime;#d# 36our $UPTIME; $UPTIME ||= time;
34our $UPTIME;
35$UPTIME ||= $uptime;#d#
36$UPTIME ||= time;
37 37
38############################################################################# 38#############################################################################
39 39
40=head2 GLOBAL VARIABLES 40=head2 GLOBAL VARIABLES
41 41
76 76
77@safe::cf::object::player::ISA = @cf::object::player::ISA = 'cf::object'; 77@safe::cf::object::player::ISA = @cf::object::player::ISA = 'cf::object';
78 78
79# we bless all objects into (empty) derived classes to force a method lookup 79# we bless all objects into (empty) derived classes to force a method lookup
80# within the Safe compartment. 80# within the Safe compartment.
81for my $pkg (qw(cf::object cf::object::player cf::player cf::map cf::party cf::region cf::arch cf::living)) { 81for my $pkg (qw(
82 cf::object cf::object::player
83 cf::client_socket cf::player
84 cf::arch cf::living
85 cf::map cf::party cf::region
86)) {
82 no strict 'refs'; 87 no strict 'refs';
83 @{"safe::$pkg\::wrap::ISA"} = @{"$pkg\::wrap::ISA"} = $pkg; 88 @{"safe::$pkg\::wrap::ISA"} = @{"$pkg\::wrap::ISA"} = $pkg;
84} 89}
85 90
86$Event::DIED = sub { 91$Event::DIED = sub {
88}; 93};
89 94
90my %ext_pkg; 95my %ext_pkg;
91my @exts; 96my @exts;
92my @hook; 97my @hook;
93my %command;
94my %extcmd;
95 98
96=head2 UTILITY FUNCTIONS 99=head2 UTILITY FUNCTIONS
97 100
98=over 4 101=over 4
99 102
570 if exists $src->{_attachment}; 573 if exists $src->{_attachment};
571 }, 574 },
572; 575;
573 576
574############################################################################# 577#############################################################################
575# old plug-in events 578# command handling &c
576 579
577sub inject_event { 580=item cf::register_command $name => \&callback($ob,$args);
578 my $extension = shift;
579 my $event_code = shift;
580 581
581 my $cb = $hook[$event_code]{$extension} 582Register a callback for execution when the client sends the user command
582 or return; 583$name.
583 584
584 &$cb 585=cut
585}
586
587sub inject_global_event {
588 my $event = shift;
589
590 my $cb = $hook[$event]
591 or return;
592
593 List::Util::max map &$_, values %$cb
594}
595
596sub inject_command {
597 my ($name, $obj, $params) = @_;
598
599 for my $cmd (@{ $command{$name} }) {
600 $cmd->[1]->($obj, $params);
601 }
602
603 -1
604}
605 586
606sub register_command { 587sub register_command {
607 my ($name, $time, $cb) = @_; 588 my ($name, $cb) = @_;
608 589
609 my $caller = caller; 590 my $caller = caller;
610 #warn "registering command '$name/$time' to '$caller'"; 591 #warn "registering command '$name/$time' to '$caller'";
611 592
612 push @{ $command{$name} }, [$time, $cb, $caller]; 593 push @{ $COMMAND{$name} }, [$caller, $cb];
613 $COMMAND{"$name\000"} = List::Util::max map $_->[0], @{ $command{$name} };
614} 594}
595
596=item cf::register_extcmd $name => \&callback($pl,$packet);
597
598Register a callbackf ro execution when the client sends an extcmd packet.
599
600If the callback returns something, it is sent back as if reply was being
601called.
602
603=cut
615 604
616sub register_extcmd { 605sub register_extcmd {
617 my ($name, $cb) = @_; 606 my ($name, $cb) = @_;
618 607
619 my $caller = caller; 608 my $caller = caller;
620 #warn "registering extcmd '$name' to '$caller'"; 609 #warn "registering extcmd '$name' to '$caller'";
621 610
622 $extcmd{$name} = [$cb, $caller]; 611 $EXTCMD{$name} = [$cb, $caller];
623} 612}
613
614attach_to_players
615 on_command => sub {
616 my ($pl, $name, $params) = @_;
617
618 my $cb = $COMMAND{$name}
619 or return;
620
621 for my $cmd (@$cb) {
622 $cmd->[1]->($pl->ob, $params);
623 }
624
625 cf::override;
626 },
627 on_extcmd => sub {
628 my ($pl, $buf) = @_;
629
630 my $msg = eval { from_json $buf };
631
632 if (ref $msg) {
633 if (my $cb = $EXTCMD{$msg->{msgtype}}) {
634 if (my %reply = $cb->[0]->($pl, $msg)) {
635 $pl->ext_reply ($msg->{msgid}, %reply);
636 }
637 }
638 } else {
639 warn "player " . ($pl->ob->name) . " sent unparseable ext message: <$buf>\n";
640 }
641
642 cf::override;
643 },
644;
624 645
625sub register { 646sub register {
626 my ($base, $pkg) = @_; 647 my ($base, $pkg) = @_;
627 648
628 #TODO 649 #TODO
671# for my $idx (0 .. $#PLUGIN_EVENT) { 692# for my $idx (0 .. $#PLUGIN_EVENT) {
672# delete $hook[$idx]{$pkg}; 693# delete $hook[$idx]{$pkg};
673# } 694# }
674 695
675 # remove commands 696 # remove commands
676 for my $name (keys %command) { 697 for my $name (keys %COMMAND) {
677 my @cb = grep $_->[2] ne $pkg, @{ $command{$name} }; 698 my @cb = grep $_->[0] ne $pkg, @{ $COMMAND{$name} };
678 699
679 if (@cb) { 700 if (@cb) {
680 $command{$name} = \@cb; 701 $COMMAND{$name} = \@cb;
681 $COMMAND{"$name\000"} = List::Util::max map $_->[0], @cb;
682 } else { 702 } else {
683 delete $command{$name};
684 delete $COMMAND{"$name\000"}; 703 delete $COMMAND{$name};
685 } 704 }
686 } 705 }
687 706
688 # remove extcmds 707 # remove extcmds
689 for my $name (grep $extcmd{$_}[1] eq $pkg, keys %extcmd) { 708 for my $name (grep $EXTCMD{$_}[1] eq $pkg, keys %EXTCMD) {
690 delete $extcmd{$name}; 709 delete $EXTCMD{$name};
691 } 710 }
692 711
693 if (my $cb = $pkg->can ("unload")) { 712 if (my $cb = $pkg->can ("unload")) {
694 eval { 713 eval {
695 $cb->($pkg); 714 $cb->($pkg);
709 load_extension $ext; 728 load_extension $ext;
710 1 729 1
711 } or warn "$ext not loaded: $@"; 730 } or warn "$ext not loaded: $@";
712 } 731 }
713} 732}
714
715#############################################################################
716# extcmd framework, basically convert ext <msg>
717# into pkg::->on_extcmd_arg1 (...) while shortcutting a few
718
719attach_to_players
720 on_extcmd => sub {
721 my ($pl, $buf) = @_;
722
723 my $msg = eval { from_json $buf };
724
725 if (ref $msg) {
726 if (my $cb = $extcmd{$msg->{msgtype}}) {
727 if (my %reply = $cb->[0]->($pl, $msg)) {
728 $pl->ext_reply ($msg->{msgid}, %reply);
729 }
730 }
731 } else {
732 warn "player " . ($pl->ob->name) . " sent unparseable ext message: <$buf>\n";
733 }
734
735 cf::override;
736 },
737;
738 733
739############################################################################# 734#############################################################################
740# load/save/clean perl data associated with a map 735# load/save/clean perl data associated with a map
741 736
742*cf::mapsupport::on_clean = sub { 737*cf::mapsupport::on_clean = sub {
1158 warn $_[0]; 1153 warn $_[0];
1159 print "$_[0]\n"; 1154 print "$_[0]\n";
1160 }; 1155 };
1161} 1156}
1162 1157
1158register "<global>", __PACKAGE__;
1159
1163register_command "perl-reload", 0, sub { 1160register_command "perl-reload" => sub {
1164 my ($who, $arg) = @_; 1161 my ($who, $arg) = @_;
1165 1162
1166 if ($who->flag (FLAG_WIZ)) { 1163 if ($who->flag (FLAG_WIZ)) {
1167 _perl_reload { 1164 _perl_reload {
1168 warn $_[0]; 1165 warn $_[0];
1169 $who->message ($_[0]); 1166 $who->message ($_[0]);
1170 }; 1167 };
1171 } 1168 }
1172}; 1169};
1173
1174register "<global>", __PACKAGE__;
1175 1170
1176unshift @INC, $LIBDIR; 1171unshift @INC, $LIBDIR;
1177 1172
1178$TICK_WATCHER = Event->timer ( 1173$TICK_WATCHER = Event->timer (
1179 prio => 1, 1174 prio => 1,

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines