… | |
… | |
10 | |
10 | |
11 | =over 4 |
11 | =over 4 |
12 | |
12 | |
13 | =cut |
13 | =cut |
14 | |
14 | |
|
|
15 | package Deliantra::Client; # work around CPAN breakage |
|
|
16 | package App::Deliantra; # try to reserve namespace |
15 | package DC; |
17 | package DC; |
16 | |
18 | |
17 | use Carp (); |
19 | use Carp (); |
18 | |
20 | |
|
|
21 | our $VERSION; |
|
|
22 | |
19 | BEGIN { |
23 | BEGIN { |
20 | $VERSION = '0.9971'; |
24 | $VERSION = '0.9975'; |
21 | |
25 | |
22 | use XSLoader; |
26 | use XSLoader; |
23 | XSLoader::load "Deliantra::Client", $VERSION; |
27 | XSLoader::load "Deliantra::Client", $VERSION; |
24 | } |
28 | } |
25 | |
29 | |
26 | use utf8; |
30 | use utf8; |
|
|
31 | use strict qw(vars subs); |
27 | |
32 | |
28 | use AnyEvent (); |
33 | use AnyEvent (); |
29 | use Pod::POM (); |
34 | use Pod::POM (); |
30 | use File::Path (); |
35 | use File::Path (); |
31 | use Storable (); # finally |
36 | use Storable (); # finally |
… | |
… | |
140 | print $msg, "\n"; |
145 | print $msg, "\n"; |
141 | } |
146 | } |
142 | |
147 | |
143 | package DC; |
148 | package DC; |
144 | |
149 | |
|
|
150 | our @RC_THEME = ("theme-blue", "."); |
|
|
151 | our $RC_BASE; |
|
|
152 | |
|
|
153 | for (grep !ref, @INC) { |
|
|
154 | $RC_BASE = "$_/Deliantra/Client/private/resources"; |
|
|
155 | last if -d $RC_BASE; |
|
|
156 | } |
|
|
157 | |
145 | sub find_rcfile($) { |
158 | sub find_rcfile($) { |
146 | my $path; |
159 | my $path; |
147 | |
160 | |
148 | for (grep !ref, @INC) { |
161 | for (@RC_THEME) { |
149 | $path = "$_/Deliantra/Client/private/resources/$_[0]"; |
162 | $path = "$RC_BASE/$_/$_[0]"; |
150 | return $path if -r $path; |
163 | return $path if -r $path; |
151 | } |
164 | } |
152 | |
165 | |
153 | die "FATAL: can't find required file $_[0]\n"; |
166 | die "FATAL: can't find required file \"$_[0]\" in \"$RC_BASE\"\n"; |
154 | } |
167 | } |
155 | |
168 | |
156 | sub read_cfg { |
169 | sub read_cfg { |
157 | my ($file) = @_; |
170 | my ($file) = @_; |
158 | |
171 | |
… | |
… | |
170 | |
183 | |
171 | $::CFG->{VERSION} = $::VERSION; |
184 | $::CFG->{VERSION} = $::VERSION; |
172 | |
185 | |
173 | open my $fh, ">:utf8", $file |
186 | open my $fh, ">:utf8", $file |
174 | or return; |
187 | or return; |
175 | print $fh encode_json $::CFG; |
188 | print $fh JSON::XS->new->utf8->pretty->encode ($::CFG); |
176 | } |
189 | } |
177 | |
190 | |
178 | sub http_proxy { |
191 | sub http_proxy { |
179 | my @proxy = win32_proxy_info; |
192 | my @proxy = win32_proxy_info; |
180 | |
193 | |
… | |
… | |
223 | $nb = (! ! $nb) + 0; |
236 | $nb = (! ! $nb) + 0; |
224 | ioctl $fh, 0x8004667e, \$nb; # FIONBIO |
237 | ioctl $fh, 0x8004667e, \$nb; # FIONBIO |
225 | } else { |
238 | } else { |
226 | fcntl $fh, &Fcntl::F_SETFL, $nb ? &Fcntl::O_NONBLOCK : 0; |
239 | fcntl $fh, &Fcntl::F_SETFL, $nb ? &Fcntl::O_NONBLOCK : 0; |
227 | } |
240 | } |
228 | |
|
|
229 | } |
241 | } |
230 | |
242 | |
231 | package DC::Layout; |
243 | package DC::Layout; |
232 | |
244 | |
233 | $DC::OpenGL::INIT_HOOK{"DC::Layout"} = sub { |
245 | $DC::OpenGL::INIT_HOOK{"DC::Layout"} = sub { |