ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/DC.pm
(Generate patch)

Comparing deliantra/Deliantra-Client/DC.pm (file contents):
Revision 1.188 by root, Tue Sep 2 16:27:34 2008 UTC vs.
Revision 1.200 by root, Sun Jan 4 10:22:19 2009 UTC

10 10
11=over 4 11=over 4
12 12
13=cut 13=cut
14 14
15package Deliantra::Client; # work around CPAN breakage
16package App::Deliantra; # try to reserve namespace
17package DC; 15package DC;
18 16
19use Carp (); 17use Carp ();
20 18
21our $VERSION; 19our $VERSION;
22 20
23BEGIN { 21BEGIN {
24 $VERSION = '0.9975'; 22 $VERSION = '2.02';
25 23
26 use XSLoader; 24 use XSLoader;
27 XSLoader::load "Deliantra::Client", $VERSION; 25 XSLoader::load "Deliantra::Client", $VERSION;
28} 26}
29 27
30use utf8; 28use utf8;
31use strict qw(vars subs); 29use strict qw(vars subs);
32 30
31use Socket ();
33use AnyEvent (); 32use AnyEvent ();
33use AnyEvent::Util ();
34use Pod::POM (); 34use Pod::POM ();
35use File::Path (); 35use File::Path ();
36use Storable (); # finally 36use Storable (); # finally
37use Fcntl (); 37use Fcntl ();
38use JSON::XS qw(encode_json decode_json); 38use JSON::XS qw(encode_json decode_json);
69 s/</&lt;/g; 69 s/</&lt;/g;
70 70
71 $_ 71 $_
72} 72}
73 73
74sub socketpipe() {
75 socketpair my $fh1, my $fh2, Socket::AF_UNIX, Socket::SOCK_STREAM, Socket::PF_UNSPEC
76 or die "cannot establish bidirectional pipe: $!\n";
77
78 ($fh1, $fh2)
79}
80
81sub background(&;&) { 74sub background(&;&) {
82 my ($bg, $cb) = @_; 75 my ($bg, $cb) = @_;
83 76
84 my ($fh_r, $fh_w) = DC::socketpipe; 77 my ($fh_r, $fh_w) = AnyEvent::Util::portable_socketpair
78 or die "unable to create background socketpair: $!";
85 79
86 my $pid = fork; 80 my $pid = fork;
87 81
88 if (defined $pid && !$pid) { 82 if (defined $pid && !$pid) {
89 local $SIG{__DIE__}; 83 local $SIG{__DIE__};
145 print $msg, "\n"; 139 print $msg, "\n";
146} 140}
147 141
148package DC; 142package DC;
149 143
150our $RC_THEME = "theme-metal"; 144our $RC_THEME;
145our %THEME;
146our @RC_PATH;
151our $RC_BASE; 147our $RC_BASE;
152 148
153for (grep !ref, @INC) { 149for (grep !ref, @INC) {
154 $RC_BASE = "$_/Deliantra/Client/private/resources"; 150 $RC_BASE = "$_/Deliantra/Client/private/resources";
155 last if -d $RC_BASE; 151 last if -d $RC_BASE;
156} 152}
157 153
158sub find_rcfile($) { 154sub find_rcfile($) {
159 my $path; 155 my $path;
160 156
157 for (@RC_PATH, "") {
161 $path = "$RC_BASE/$RC_THEME/$_[0]"; 158 $path = "$RC_BASE/$_/$_[0]";
162 return $path if -r $path; 159 return $path if -r $path;
163 160 }
164 $path = "$RC_BASE/$_[0]";
165 return $path if -r $path;
166 161
167 die "FATAL: can't find required file \"$_[0]\" in \"$RC_BASE\"\n"; 162 die "FATAL: can't find required file \"$_[0]\" in \"$RC_BASE\"\n";
163}
164
165sub load_json($) {
166 my ($file) = @_;
167
168 open my $fh, $file
169 or return;
170
171 local $/;
172 JSON::XS->new->utf8->relaxed->decode (<$fh>)
173}
174
175sub set_theme($) {
176 return if $RC_THEME eq $_[0];
177 $RC_THEME = $_[0];
178
179 # kind of hacky, find the main theme file, then load all theme files and merge them
180
181 %THEME = ();
182 @RC_PATH = "theme-$RC_THEME";
183
184 my $theme = load_json find_rcfile "theme.json"
185 or die "FATAL: theme resource file not found";
186
187 @RC_PATH = @{ $theme->{path} } if $theme->{path};
188
189 for (@RC_PATH, "") {
190 my $theme = load_json "$RC_BASE/$_/theme.json"
191 or next;
192
193 %THEME = ( %$theme, %THEME );
194 }
168} 195}
169 196
170sub read_cfg { 197sub read_cfg {
171 my ($file) = @_; 198 my ($file) = @_;
172 199
173 open my $fh, $file 200 $::CFG = load_json $file;
174 or return;
175
176 local $/;
177 my $CFG = <$fh>;
178
179 $::CFG = decode_json $CFG;
180} 201}
181 202
182sub write_cfg { 203sub write_cfg {
183 my $file = "$Deliantra::VARDIR/client.cf"; 204 my $file = "$Deliantra::VARDIR/client.cf";
184 205

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines