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.465 by root, Thu Jan 8 00:54:55 2009 UTC vs.
Revision 1.470 by root, Sun Apr 26 19:42:45 2009 UTC

21 21
22package cf; 22package cf;
23 23
24use 5.10.0; 24use 5.10.0;
25use utf8; 25use utf8;
26use strict "vars", "subs"; 26use strict qw(vars subs);
27 27
28use Symbol; 28use Symbol;
29use List::Util; 29use List::Util;
30use Socket; 30use Socket;
31use EV; 31use EV;
105our %RESOURCE; 105our %RESOURCE;
106 106
107our $TICK = MAX_TIME * 1e-6; # this is a CONSTANT(!) 107our $TICK = MAX_TIME * 1e-6; # this is a CONSTANT(!)
108our $NEXT_RUNTIME_WRITE; # when should the runtime file be written 108our $NEXT_RUNTIME_WRITE; # when should the runtime file be written
109our $NEXT_TICK; 109our $NEXT_TICK;
110our $USE_FSYNC = 1; # use fsync to write maps - default off 110our $USE_FSYNC = 1; # use fsync to write maps - default on
111 111
112our $BDB_DEADLOCK_WATCHER; 112our $BDB_DEADLOCK_WATCHER;
113our $BDB_CHECKPOINT_WATCHER; 113our $BDB_CHECKPOINT_WATCHER;
114our $BDB_TRICKLE_WATCHER; 114our $BDB_TRICKLE_WATCHER;
115our $DB_ENV; 115our $DB_ENV;
116
117our @EXTRA_MODULES = qw(pod mapscript);
116 118
117our %CFG; 119our %CFG;
118 120
119our $UPTIME; $UPTIME ||= time; 121our $UPTIME; $UPTIME ||= time;
120our $RUNTIME; 122our $RUNTIME;
143unless ($RUNTIME || !-e $RUNTIMEFILE) { 145unless ($RUNTIME || !-e $RUNTIMEFILE) {
144 open my $fh, "<", $RUNTIMEFILE 146 open my $fh, "<", $RUNTIMEFILE
145 or die "unable to read $RUNTIMEFILE file: $!"; 147 or die "unable to read $RUNTIMEFILE file: $!";
146 $RUNTIME = <$fh> + 0.; 148 $RUNTIME = <$fh> + 0.;
147} 149}
150
151eval "sub TICK() { $TICK } 1" or die;
148 152
149mkdir $_ 153mkdir $_
150 for $LOCALDIR, $TMPDIR, $UNIQUEDIR, $PLAYERDIR, $RANDOMDIR, $BDBDIR; 154 for $LOCALDIR, $TMPDIR, $UNIQUEDIR, $PLAYERDIR, $RANDOMDIR, $BDBDIR;
151 155
152our $EMERGENCY_POSITION; 156our $EMERGENCY_POSITION;
2384 2388
2385our $SAY_CHANNEL = { 2389our $SAY_CHANNEL = {
2386 id => "say", 2390 id => "say",
2387 title => "Map", 2391 title => "Map",
2388 reply => "say ", 2392 reply => "say ",
2389 tooltip => "Things said to and replied from npcs near you and other players on the same map only.", 2393 tooltip => "Things said to and replied from NPCs near you and other players on the same map only.",
2390}; 2394};
2391 2395
2392our $CHAT_CHANNEL = { 2396our $CHAT_CHANNEL = {
2393 id => "chat", 2397 id => "chat",
2394 title => "Chat", 2398 title => "Chat",
2781 id => "infobox", 2785 id => "infobox",
2782 title => "Skills", 2786 title => "Skills",
2783 reply => undef, 2787 reply => undef,
2784 tooltip => "Shows your experience per skill and item power", 2788 tooltip => "Shows your experience per skill and item power",
2785 }, 2789 },
2790 "c/shopitems" => {
2791 id => "infobox",
2792 title => "Shop Items",
2793 reply => undef,
2794 tooltip => "Shows the items currently for sale in this shop",
2795 },
2786 "c/resistances" => { 2796 "c/resistances" => {
2787 id => "infobox", 2797 id => "infobox",
2788 title => "Resistances", 2798 title => "Resistances",
2789 reply => undef, 2799 reply => undef,
2790 tooltip => "Shows your resistances", 2800 tooltip => "Shows your resistances",
3052The following functions and methods are available within a safe environment: 3062The following functions and methods are available within a safe environment:
3053 3063
3054 cf::object 3064 cf::object
3055 contr pay_amount pay_player map x y force_find force_add destroy 3065 contr pay_amount pay_player map x y force_find force_add destroy
3056 insert remove name archname title slaying race decrease split 3066 insert remove name archname title slaying race decrease split
3067 value
3057 3068
3058 cf::object::player 3069 cf::object::player
3059 player 3070 player
3060 3071
3061 cf::player 3072 cf::player
3067=cut 3078=cut
3068 3079
3069for ( 3080for (
3070 ["cf::object" => qw(contr pay_amount pay_player map force_find force_add x y 3081 ["cf::object" => qw(contr pay_amount pay_player map force_find force_add x y
3071 insert remove inv nrof name archname title slaying race 3082 insert remove inv nrof name archname title slaying race
3072 decrease split destroy change_exp)], 3083 decrease split destroy change_exp value msg lore send_msg)],
3073 ["cf::object::player" => qw(player)], 3084 ["cf::object::player" => qw(player)],
3074 ["cf::player" => qw(peaceful)], 3085 ["cf::player" => qw(peaceful send_msg)],
3075 ["cf::map" => qw(trigger)], 3086 ["cf::map" => qw(trigger)],
3076) { 3087) {
3077 no strict 'refs'; 3088 no strict 'refs';
3078 my ($pkg, @funs) = @$_; 3089 my ($pkg, @funs) = @$_;
3079 *{"safe::$pkg\::$_"} = $safe_hole->wrap (\&{"$pkg\::$_"}) 3090 *{"safe::$pkg\::$_"} = $safe_hole->wrap (\&{"$pkg\::$_"})
3096 my ($code, %vars) = @_; 3107 my ($code, %vars) = @_;
3097 3108
3098 my $qcode = $code; 3109 my $qcode = $code;
3099 $qcode =~ s/"/‟/g; # not allowed in #line filenames 3110 $qcode =~ s/"/‟/g; # not allowed in #line filenames
3100 $qcode =~ s/\n/\\n/g; 3111 $qcode =~ s/\n/\\n/g;
3112
3113 %vars = (_dummy => 0) unless %vars;
3101 3114
3102 local $_; 3115 local $_;
3103 local @safe::cf::_safe_eval_args = values %vars; 3116 local @safe::cf::_safe_eval_args = values %vars;
3104 3117
3105 my $eval = 3118 my $eval =
3693 clear_package "safe::$_" 3706 clear_package "safe::$_"
3694 for qw(cf::attachable cf::object cf::object::player cf::client cf::player cf::map cf::party cf::region); 3707 for qw(cf::attachable cf::object cf::object::player cf::client cf::player cf::map cf::party cf::region);
3695 3708
3696 warn "unloading cf.pm \"a bit\""; 3709 warn "unloading cf.pm \"a bit\"";
3697 delete $INC{"cf.pm"}; 3710 delete $INC{"cf.pm"};
3698 delete $INC{"cf/pod.pm"}; 3711 delete $INC{"cf/$_.pm"} for @EXTRA_MODULES;
3699 3712
3700 # don't, removes xs symbols, too, 3713 # don't, removes xs symbols, too,
3701 # and global variables created in xs 3714 # and global variables created in xs
3702 #clear_package __PACKAGE__; 3715 #clear_package __PACKAGE__;
3703 3716
3920 LOG llevInfo, "[ABT] [suppressed]\n"; 3933 LOG llevInfo, "[ABT] [suppressed]\n";
3921 } 3934 }
3922} 3935}
3923 3936
3924# load additional modules 3937# load additional modules
3925use cf::pod; 3938require "cf/$_.pm" for @EXTRA_MODULES;
3926 3939
3927END { cf::emergency_save } 3940END { cf::emergency_save }
3928 3941
39291 39421
3930 3943

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines