1 | #!/opt/bin/perl |
1 | #!/opt/bin/perl |
2 | |
2 | |
|
|
3 | # do splash-screen thingy on win32 |
3 | my $startup_done = sub { }; |
4 | my $startup_done = sub { }; |
4 | our $PANGO = "1.5.0"; |
|
|
5 | |
|
|
6 | # do splash-screen thingy on win32 |
|
|
7 | BEGIN { |
5 | BEGIN { |
8 | if (%PAR::LibCache && $^O eq "MSWin32") { |
6 | if (%PAR::LibCache && $^O eq "MSWin32") { |
9 | while (my ($filename, $zip) = each %PAR::LibCache) { |
7 | while (my ($filename, $zip) = each %PAR::LibCache) { |
10 | $zip->extractMember ("SPLASH.bmp", "$ENV{PAR_TEMP}/SPLASH.bmp"); |
8 | $zip->extractMember ("SPLASH.bmp", "$ENV{PAR_TEMP}/SPLASH.bmp"); |
11 | } |
9 | } |
… | |
… | |
30 | # do things only needed for single-binary version (par) |
28 | # do things only needed for single-binary version (par) |
31 | BEGIN { |
29 | BEGIN { |
32 | if (%PAR::LibCache) { |
30 | if (%PAR::LibCache) { |
33 | @INC = grep ref, @INC; # weed out all paths except pars loader refs |
31 | @INC = grep ref, @INC; # weed out all paths except pars loader refs |
34 | |
32 | |
35 | my $tmp = $ENV{PAR_TEMP}; |
33 | my $root = $ENV{PAR_TEMP}; |
36 | |
34 | |
37 | while (my ($filename, $zip) = each %PAR::LibCache) { |
35 | while (my ($filename, $zip) = each %PAR::LibCache) { |
38 | for ($zip->memberNames) { |
36 | for ($zip->memberNames) { |
39 | next unless /^root\/(.*)/; |
37 | next unless /^root\/(.*)/; |
40 | $zip->extractMember ($_, "$tmp/$1") |
38 | $zip->extractMember ($_, "$root/$1") |
41 | unless -e "$tmp/$1"; |
39 | unless -e "$root/$1"; |
42 | } |
40 | } |
43 | } |
41 | } |
44 | |
42 | |
45 | if ($^O eq "MSWin32") { |
43 | if ($^O eq "MSWin32") { |
46 | # relocatable |
44 | # pango is relocatable on win32 |
47 | } else { |
45 | } else { |
|
|
46 | open my $fh, "<:perlio", "$root/pangoversion" |
|
|
47 | or die "pangoversion: $!"; |
|
|
48 | my $PANGO = <$fh>; |
48 | # unix, need to patch pango rc file |
49 | # unix, need to patch pango rc file |
49 | open my $fh, "<:perlio", "$tmp/usr/lib/pango/$PANGO/module-files.d/libpango1.0-0.modules" |
50 | open my $fh, "<:perlio", "$root/usr/lib/pango/$PANGO/module-files.d/libpango1.0-0.modules" |
50 | or die "$tmp/usr/lib/$PANGO/module-files.d/libpango1.0-0.modules: $!"; |
51 | or die "$root/usr/lib/$PANGO/module-files.d/libpango1.0-0.modules: $!"; |
51 | local $/; |
52 | local $/; |
52 | my $rc = <$fh>; |
53 | my $rc = <$fh>; |
53 | $rc =~ s/^\//$tmp\//gm; # replace abs paths by relative ones |
54 | $rc =~ s/^\//$root\//gm; # replace abs paths by relative ones |
54 | |
55 | |
55 | mkdir "$tmp/pango-modules"; |
56 | mkdir "$root/pango-modules"; |
56 | open my $fh, ">:perlio", "$tmp/pango-modules/pango.modules" |
57 | open my $fh, ">:perlio", "$root/pango-modules/pango.modules" |
57 | or die "$tmp/pango-modules/pango.modules: $!"; |
58 | or die "$root/pango-modules/pango.modules: $!"; |
58 | print $fh $rc; |
59 | print $fh $rc; |
59 | |
60 | |
60 | $ENV{PANGO_RC_FILE} = "$tmp/pango.rc"; |
61 | $ENV{PANGO_RC_FILE} = "$root/pango.rc"; |
61 | open my $fh, ">:perlio", $ENV{PANGO_RC_FILE} |
62 | open my $fh, ">:perlio", $ENV{PANGO_RC_FILE} |
62 | or die "$ENV{PANGO_RC_FILE}: $!"; |
63 | or die "$ENV{PANGO_RC_FILE}: $!"; |
63 | print $fh "[Pango]\nModuleFiles = $tmp/pango-modules\n"; |
64 | print $fh "[Pango]\nModuleFiles = $root/pango-modules\n"; |
64 | } |
65 | } |
65 | |
66 | |
66 | unshift @INC, $tmp; |
67 | unshift @INC, $root; |
67 | } |
68 | } |
68 | } |
69 | } |
69 | |
70 | |
70 | # need to do it again because that pile of garbage called PAR nukes it before main |
71 | # need to do it again because that pile of garbage called PAR nukes it before main |
71 | unshift @INC, $ENV{PAR_TEMP} |
72 | unshift @INC, $ENV{PAR_TEMP} |
… | |
… | |
86 | use CFPlus::DB; |
87 | use CFPlus::DB; |
87 | use CFPlus::UI; |
88 | use CFPlus::UI; |
88 | use CFPlus::UI::Canvas; |
89 | use CFPlus::UI::Canvas; |
89 | use CFPlus::UI::Inventory; |
90 | use CFPlus::UI::Inventory; |
90 | use CFPlus::UI::SpellList; |
91 | use CFPlus::UI::SpellList; |
|
|
92 | use CFPlus::UI::Dockable; |
91 | use CFPlus::UI::MessageWindow; |
93 | use CFPlus::UI::MessageWindow; |
|
|
94 | use CFPlus::UI::ChatView; |
92 | use CFPlus::Pod; |
95 | use CFPlus::Pod; |
93 | use CFPlus::MapWidget; |
96 | use CFPlus::MapWidget; |
94 | use CFPlus::Macro; |
97 | use CFPlus::Macro; |
95 | |
98 | |
96 | $SIG{QUIT} = sub { Carp::cluck "QUIT" }; |
99 | $SIG{QUIT} = sub { Carp::cluck "QUIT" }; |
… | |
… | |
182 | sub debug { |
185 | sub debug { |
183 | $DEBUG_STATUS->set_text ($_[0]); |
186 | $DEBUG_STATUS->set_text ($_[0]); |
184 | } |
187 | } |
185 | |
188 | |
186 | sub message { |
189 | sub message { |
187 | my ($para) = @_; |
|
|
188 | $MESSAGE_WINDOW->message ($para); |
190 | $MESSAGE_WINDOW->message (@_); |
189 | } |
191 | } |
190 | |
192 | |
191 | ############################################################################# |
193 | ############################################################################# |
192 | #TODO: maybe move into own audio module... |
194 | #TODO: maybe move into own audio module... |
193 | |
195 | |
… | |
… | |
315 | |
317 | |
316 | my $NOW = time; |
318 | my $NOW = time; |
317 | |
319 | |
318 | if ($MUSIC_PLAYING_META->{stop_time} > $NOW - $MUSIC_RESUME) { |
320 | if ($MUSIC_PLAYING_META->{stop_time} > $NOW - $MUSIC_RESUME) { |
319 | my $pos = $MUSIC_PLAYING_META->{stop_pos}; |
321 | my $pos = $MUSIC_PLAYING_META->{stop_pos}; |
320 | $MUSIC_PLAYER->fade_in_pos (0, 1000, $pos); |
322 | $MUSIC_PLAYER->fade_in_pos (0, 700, $pos); |
321 | $MUSIC_START = time - $pos; |
323 | $MUSIC_START = time - $pos; |
322 | } else { |
324 | } else { |
323 | $MUSIC_PLAYER->play (0); |
325 | $MUSIC_PLAYER->play (0); |
324 | $MUSIC_START = time; |
326 | $MUSIC_START = time; |
325 | } |
327 | } |
… | |
… | |
343 | my @have = |
345 | my @have = |
344 | grep $_ && $_->{data}, |
346 | grep $_ && $_->{data}, |
345 | map $CONN->{face}[$_], |
347 | map $CONN->{face}[$_], |
346 | @$MUSIC_WANT; |
348 | @$MUSIC_WANT; |
347 | |
349 | |
|
|
350 | # randomize music a bit so that the order is not always the same |
|
|
351 | $_->{stop_time} ||= rand for @have; |
|
|
352 | |
348 | @MUSIC_HAVE = @have |
353 | @MUSIC_HAVE = @have |
349 | if @have; |
354 | if @have; |
350 | |
355 | |
351 | # default MUSIC_HAVE == MUSIC_DEFAULT |
356 | # default MUSIC_HAVE == MUSIC_DEFAULT |
352 | @MUSIC_HAVE = { path => CFPlus::find_rcfile "music/$MUSIC_DEFAULT" } unless @MUSIC_HAVE; |
357 | @MUSIC_HAVE = { path => CFPlus::find_rcfile "music/$MUSIC_DEFAULT" } unless @MUSIC_HAVE; |
353 | $fade_out = 1000; |
358 | $fade_out = 700; |
354 | } |
359 | } |
355 | |
360 | |
356 | # if the currently playing song is acceptable, let it continue |
361 | # if the currently playing song is acceptable, let it continue |
357 | return if grep $MUSIC_PLAYING_META == $_, @MUSIC_HAVE; |
362 | return if grep $MUSIC_PLAYING_META == $_, @MUSIC_HAVE; |
358 | |
363 | |
… | |
… | |
367 | @MUSIC_HAVE = sort { $a->{stop_time} <=> $b->{stop_time} } @MUSIC_HAVE; |
372 | @MUSIC_HAVE = sort { $a->{stop_time} <=> $b->{stop_time} } @MUSIC_HAVE; |
368 | |
373 | |
369 | # if the most recently-played piece played very recently, |
374 | # if the most recently-played piece played very recently, |
370 | # resume it, else choose the oldest piece for rotation. |
375 | # resume it, else choose the oldest piece for rotation. |
371 | audio_music_set_meta |
376 | audio_music_set_meta |
372 | $MUSIC_HAVE[-1]{stop_time} > $NOW - $MUSIC_RESUME |
377 | $MUSIC_HAVE[-1]{stop_pos} && $MUSIC_HAVE[-1]{stop_time} > $NOW - $MUSIC_RESUME |
373 | ? $MUSIC_HAVE[-1] |
378 | ? $MUSIC_HAVE[-1] |
374 | : $MUSIC_HAVE[0]; |
379 | : $MUSIC_HAVE[0]; |
375 | |
380 | |
376 | audio_music_start; |
381 | audio_music_start; |
377 | } |
382 | } |
… | |
… | |
383 | $MUSIC_WANT = $songs; |
388 | $MUSIC_WANT = $songs; |
384 | audio_music_push; |
389 | audio_music_push; |
385 | } |
390 | } |
386 | |
391 | |
387 | sub audio_music_finished { |
392 | sub audio_music_finished { |
|
|
393 | if ($MUSIC_PLAYING_META) { |
|
|
394 | $MUSIC_PLAYING_META->{stop_time} = time; |
|
|
395 | } |
|
|
396 | |
388 | # we compress multiple jingles of the same type |
397 | # we compress multiple jingles of the same type |
389 | shift @MUSIC_JINGLE |
398 | shift @MUSIC_JINGLE |
390 | while @MUSIC_JINGLE && $MUSIC_PLAYING_META == $MUSIC_JINGLE[0]; |
399 | while @MUSIC_JINGLE && $MUSIC_PLAYING_META == $MUSIC_JINGLE[0]; |
391 | |
400 | |
392 | $MUSIC_PLAYING_WIDGET->clear; |
401 | $MUSIC_PLAYING_WIDGET->clear; |