… | |
… | |
15 | package CFPlus; |
15 | package CFPlus; |
16 | |
16 | |
17 | use Carp (); |
17 | use Carp (); |
18 | |
18 | |
19 | BEGIN { |
19 | BEGIN { |
20 | $VERSION = '0.97'; |
20 | $VERSION = '0.9841'; |
21 | |
21 | |
22 | use XSLoader; |
22 | use XSLoader; |
23 | XSLoader::load "CFPlus", $VERSION; |
23 | XSLoader::load "CFPlus", $VERSION; |
24 | } |
24 | } |
25 | |
25 | |
… | |
… | |
27 | |
27 | |
28 | use AnyEvent (); |
28 | use AnyEvent (); |
29 | use Pod::POM (); |
29 | use Pod::POM (); |
30 | use File::Path (); |
30 | use File::Path (); |
31 | use Storable (); # finally |
31 | use Storable (); # finally |
32 | |
32 | use Fcntl (); |
33 | BEGIN { |
33 | use JSON::XS qw(to_json from_json); |
34 | use Crossfire::Protocol::Base (); |
|
|
35 | *to_json = \&Crossfire::Protocol::Base::to_json; |
|
|
36 | *from_json = \&Crossfire::Protocol::Base::from_json; |
|
|
37 | } |
|
|
38 | |
34 | |
39 | =item guard { BLOCK } |
35 | =item guard { BLOCK } |
40 | |
36 | |
41 | Returns an object that executes the given block as soon as it is destroyed. |
37 | Returns an object that executes the given block as soon as it is destroyed. |
42 | |
38 | |
… | |
… | |
226 | and die $res->status_line; |
222 | and die $res->status_line; |
227 | |
223 | |
228 | $res |
224 | $res |
229 | } |
225 | } |
230 | |
226 | |
|
|
227 | sub fh_nonblocking($$) { |
|
|
228 | my ($fh, $nb) = @_; |
|
|
229 | |
|
|
230 | if ($^O eq "MSWin32") { |
|
|
231 | $nb = (! ! $nb) + 0; |
|
|
232 | ioctl $fh, 0x8004667e, \$nb; # FIONBIO |
|
|
233 | } else { |
|
|
234 | fcntl $fh, &Fcntl::F_SETFL, $nb ? &Fcntl::O_NONBLOCK : 0; |
|
|
235 | } |
|
|
236 | |
|
|
237 | } |
|
|
238 | |
231 | package CFPlus::Layout; |
239 | package CFPlus::Layout; |
232 | |
240 | |
233 | $CFPlus::OpenGL::SHUTDOWN_HOOK{"CFPlus::Layout"} = sub { |
241 | $CFPlus::OpenGL::SHUTDOWN_HOOK{"CFPlus::Layout"} = sub { |
234 | reset_glyph_cache; |
242 | reset_glyph_cache; |
235 | }; |
243 | }; |