… | |
… | |
49 | } |
49 | } |
50 | } |
50 | } |
51 | |
51 | |
52 | if ($^O eq "MSWin32") { |
52 | if ($^O eq "MSWin32") { |
53 | # pango is relocatable on win32 |
53 | # pango is relocatable on win32 |
54 | } else { |
54 | } elsif (-e "$root/pangoversion") { |
55 | open my $fh, "<:perlio", "$root/pangoversion" |
55 | open my $fh, "<:perlio", "$root/pangoversion" |
56 | or die "pangoversion: $!"; |
56 | or die "pangoversion: $!"; |
57 | my $PANGO = <$fh>; |
57 | my $PANGO = <$fh>; |
58 | # unix, need to patch pango rc file |
58 | # unix, need to patch pango rc file |
59 | open my $fh, "<:perlio", "$root/usr/lib/pango/$PANGO/module-files.d/libpango1.0-0.modules" |
59 | open my $fh, "<:perlio", "$root/usr/lib/pango/$PANGO/module-files.d/libpango1.0-0.modules" |
… | |
… | |
69 | |
69 | |
70 | $ENV{PANGO_RC_FILE} = "$root/pango.rc"; |
70 | $ENV{PANGO_RC_FILE} = "$root/pango.rc"; |
71 | open my $fh, ">:perlio", $ENV{PANGO_RC_FILE} |
71 | open my $fh, ">:perlio", $ENV{PANGO_RC_FILE} |
72 | or die "$ENV{PANGO_RC_FILE}: $!"; |
72 | or die "$ENV{PANGO_RC_FILE}: $!"; |
73 | print $fh "[Pango]\nModuleFiles = $root/pango-modules\n"; |
73 | print $fh "[Pango]\nModuleFiles = $root/pango-modules\n"; |
|
|
74 | } else { |
|
|
75 | # OS X |
|
|
76 | $ENV{FC_CONFIG_FILE} = "$root/fonts.conf"; # no effect??!?! |
|
|
77 | $ENV{FC_CONFIG_DIR} = $root; # no effect??!?! |
|
|
78 | $ENV{PANGO_RC_FILE} = "$root/pango.rc"; |
|
|
79 | $ENV{DYLD_LIBRARY_PATH} = $root; |
|
|
80 | chdir $root; # for pango modules, maybe other things |
74 | } |
81 | } |
75 | |
82 | |
76 | unshift @INC, $root; |
83 | unshift @INC, $root; |
77 | } |
84 | } |
78 | } |
85 | } |
… | |
… | |
849 | $table->add_at (0, $row, new DC::UI::Label align => 1, text => "Video Mode"); |
856 | $table->add_at (0, $row, new DC::UI::Label align => 1, text => "Video Mode"); |
850 | $table->add_at (1, $row++, my $hbox = new DC::UI::HBox); |
857 | $table->add_at (1, $row++, my $hbox = new DC::UI::HBox); |
851 | |
858 | |
852 | $hbox->add ($MODE_SLIDER = new DC::UI::Slider |
859 | $hbox->add ($MODE_SLIDER = new DC::UI::Slider |
853 | force_w => $WIDTH * 0.1, expand => 1, |
860 | force_w => $WIDTH * 0.1, expand => 1, |
|
|
861 | range => [ ($CFG->{sdl_mode}) x 3 ], |
854 | tooltip => $vidmode_tooltip); |
862 | tooltip => $vidmode_tooltip); |
855 | $hbox->add (my $mode_label = new DC::UI::Label |
863 | $hbox->add (my $mode_label = new DC::UI::Label |
856 | height => 0.8, template => "9999x9999@9+9", |
864 | height => 0.8, template => "9999x9999@9+9", |
857 | can_events => 1, tooltip => $vidmode_tooltip); |
865 | can_events => 1, tooltip => $vidmode_tooltip); |
858 | |
866 | |
… | |
… | |
930 | on_activate => sub { |
938 | on_activate => sub { |
931 | video_shutdown (); |
939 | video_shutdown (); |
932 | video_init (); |
940 | video_init (); |
933 | 0 |
941 | 0 |
934 | } |
942 | } |
|
|
943 | ); |
|
|
944 | |
|
|
945 | $table->add_at (0, $row, new DC::UI::Label align => 1, text => "Smooth Movement"); |
|
|
946 | $table->add_at (1, $row++, new DC::UI::CheckBox |
|
|
947 | state => $CFG->{smooth_movement}, |
|
|
948 | tooltip => "<b>Smooth Movement</b> tries to make movement, well, smoother, but also increases the framerate. " |
|
|
949 | . "If you have a very slow system, non-accelerated drivers or plain dislike smooth scrolling, " |
|
|
950 | . "then disable this option. Changes take effect immdiately.", |
|
|
951 | on_changed => sub { my ($self, $value) = @_; $CFG->{smooth_movement} = $value; 0 } |
935 | ); |
952 | ); |
936 | |
953 | |
937 | $table->add_at (0, $row, new DC::UI::Label align => 1, text => "Map Scale"); |
954 | $table->add_at (0, $row, new DC::UI::Label align => 1, text => "Map Scale"); |
938 | $table->add_at (1, $row++, new DC::UI::Slider |
955 | $table->add_at (1, $row++, new DC::UI::Slider |
939 | range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1], |
956 | range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1], |
… | |
… | |
1579 | 1 |
1596 | 1 |
1580 | }, |
1597 | }, |
1581 | ); |
1598 | ); |
1582 | |
1599 | |
1583 | $vbox->add (new DC::UI::FancyFrame |
1600 | $vbox->add (new DC::UI::FancyFrame |
1584 | label => "Registering", |
1601 | label => "How to Play", |
1585 | min_h => 200, |
1602 | min_h => 200, |
1586 | child => (new DC::UI::Label valign => 0, ellipsise => 0, |
1603 | child => (new DC::UI::Label valign => 0, ellipsise => 0, |
1587 | markup => |
1604 | markup => |
|
|
1605 | "First select a suitable video resolution in the Graphics tab, above.\n\n" |
|
|
1606 | . "Then register a new account (or use an existibg one if you have one). " |
1588 | "To register a new account, choose a username that hasn't been taken yet and " |
1607 | . "To register an account, choose a username that hasn't been taken yet and " |
1589 | . "try to log-in. Follow the instructions in the Log tab in the message window.", |
1608 | . "try to log-in. Follow the instructions in the Log tab in the message window.", |
1590 | ), |
1609 | ), |
1591 | ); |
1610 | ); |
1592 | |
1611 | |
1593 | $vbox |
1612 | $vbox |
… | |
… | |
1739 | ["Magic Devices" => PICKUP_MAGIC_DEVICE], |
1758 | ["Magic Devices" => PICKUP_MAGIC_DEVICE], |
1740 | ["Ignore cursed" => PICKUP_NOT_CURSED], |
1759 | ["Ignore cursed" => PICKUP_NOT_CURSED], |
1741 | ["Jewelery" => PICKUP_JEWELS], |
1760 | ["Jewelery" => PICKUP_JEWELS], |
1742 | ["Flesh" => PICKUP_FLESH], |
1761 | ["Flesh" => PICKUP_FLESH], |
1743 | ], |
1762 | ], |
1744 | ["Weight/Value ratio", 2, 17] |
1763 | ["Value/Weight ratio", 2, 17] |
1745 | ) |
1764 | ) |
1746 | { |
1765 | { |
1747 | my ($title, $x, $y, @bits) = @$_; |
1766 | my ($title, $x, $y, @bits) = @$_; |
1748 | $table->add_at ($x, $y, new DC::UI::Label text => $title, align => 1, fg => [1, 1, 0]); |
1767 | $table->add_at ($x, $y, new DC::UI::Label text => $title, align => 1, fg => [1, 1, 0]); |
1749 | |
1768 | |
… | |
… | |
1774 | } |
1793 | } |
1775 | |
1794 | |
1776 | $table->add_at (2, 18, new DC::UI::ValSlider |
1795 | $table->add_at (2, 18, new DC::UI::ValSlider |
1777 | range => [$::CFG->{pickup} & 0xF, 0, 16, 1, 1], |
1796 | range => [$::CFG->{pickup} & 0xF, 0, 16, 1, 1], |
1778 | template => ">= 99", |
1797 | template => ">= 99", |
|
|
1798 | tooltip => "Pick up items whose value/weight (silver/kg) ratio is equal or higher than this setting (which is specified in gold coins).", |
1779 | to_value => sub { ">= " . 5 * $_[0] }, |
1799 | to_value => sub { ">= " . 5 * $_[0] }, |
1780 | on_changed => sub { |
1800 | on_changed => sub { |
1781 | my ($slider, $value) = @_; |
1801 | my ($slider, $value) = @_; |
1782 | |
1802 | |
1783 | $::CFG->{pickup} &= ~0xF; |
1803 | $::CFG->{pickup} &= ~0xF; |
… | |
… | |
1839 | $::CFG->{inv_sort} = $_[1]; |
1859 | $::CFG->{inv_sort} = $_[1]; |
1840 | $INV->set_sort_order ($SORT_ORDER{$_[1]}); |
1860 | $INV->set_sort_order ($SORT_ORDER{$_[1]}); |
1841 | }, |
1861 | }, |
1842 | ); |
1862 | ); |
1843 | $hb1->add (new DC::UI::Label text => "Weight: ", align => 1, expand => 1); |
1863 | $hb1->add (new DC::UI::Label text => "Weight: ", align => 1, expand => 1); |
1844 | #TODO# update to weigh/maxweight |
1864 | #TODO# update to weight/maxweight |
1845 | $hb1->add ($STATWIDS->{i_weight} = new DC::UI::Label align => 0); |
1865 | $hb1->add ($STATWIDS->{i_weight} = new DC::UI::Label align => 0); |
1846 | |
1866 | |
1847 | $vb1->add (my $sw1 = new DC::UI::ScrolledWindow expand => 1, scroll_y => 1); |
1867 | $vb1->add (my $sw1 = new DC::UI::ScrolledWindow expand => 1, scroll_y => 1); |
1848 | $sw1->add ($INV = new DC::UI::Inventory); |
1868 | $sw1->add ($INV = new DC::UI::Inventory); |
1849 | $INV->set_sort_order ($SORT_ORDER{$::CFG->{inv_sort}}); |
1869 | $INV->set_sort_order ($SORT_ORDER{$::CFG->{inv_sort}}); |
… | |
… | |
2191 | @SDL_MODES = DC::SDL_ListModes 5, 0 unless @SDL_MODES; |
2211 | @SDL_MODES = DC::SDL_ListModes 5, 0 unless @SDL_MODES; |
2192 | @SDL_MODES or DC::fatal "Unable to find a usable video mode\n(hardware accelerated opengl fullscreen)"; |
2212 | @SDL_MODES or DC::fatal "Unable to find a usable video mode\n(hardware accelerated opengl fullscreen)"; |
2193 | |
2213 | |
2194 | @SDL_MODES = sort { $a->[0] * $a->[1] <=> $b->[0] * $b->[1] } @SDL_MODES; |
2214 | @SDL_MODES = sort { $a->[0] * $a->[1] <=> $b->[0] * $b->[1] } @SDL_MODES; |
2195 | |
2215 | |
2196 | if (!exists $CFG->{sdl_mode} or $CFG->{sdl_mode} >= @SDL_MODES) { |
2216 | if (!defined $CFG->{sdl_mode} or $CFG->{sdl_mode} > $#SDL_MODES) { |
2197 | $CFG->{sdl_mode} = 0; |
2217 | $CFG->{sdl_mode} = 0; # lowest resolution by default |
|
|
2218 | |
|
|
2219 | # now choose biggets mode <= 1024x768 |
2198 | for (reverse 0 .. $#SDL_MODES) { |
2220 | for (0 .. $#SDL_MODES) { |
2199 | $CFG->{sdl_mode} = $_ if $SDL_MODES[$_][0] * $SDL_MODES[$_][1] >= 800 * 600; |
2221 | if ($SDL_MODES[$_][0] * $SDL_MODES[$_][1] <= 1024 * 768) { |
|
|
2222 | $CFG->{sdl_mode} = $_; |
|
|
2223 | } |
2200 | } |
2224 | } |
2201 | } |
2225 | } |
2202 | |
2226 | |
2203 | my ($old_w, $old_h) = ($WIDTH, $HEIGHT); |
2227 | my ($old_w, $old_h) = ($WIDTH, $HEIGHT); |
2204 | |
2228 | |
2205 | ($WIDTH, $HEIGHT, my ($rgb, $alpha)) = @{ $SDL_MODES[$CFG->{sdl_mode}] }; |
2229 | ($WIDTH, $HEIGHT, my ($rgb, $alpha)) = @{ $SDL_MODES[$CFG->{sdl_mode}] }; |
2206 | $FULLSCREEN = $CFG->{fullscreen}; |
2230 | $FULLSCREEN = $CFG->{fullscreen}; |
2207 | $FAST = $CFG->{fast}; |
2231 | $FAST = $CFG->{fast}; |
2208 | |
2232 | |
|
|
2233 | # due to mac os x braindamage, we simply retry with !fullscreen in case of an error |
2209 | DC::SDL_SetVideoMode $WIDTH, $HEIGHT, $rgb, $alpha, $FULLSCREEN |
2234 | DC::SDL_SetVideoMode $WIDTH, $HEIGHT, $rgb, $alpha, $FULLSCREEN |
|
|
2235 | or DC::SDL_SetVideoMode $WIDTH, $HEIGHT, $rgb, $alpha, !$FULLSCREEN |
2210 | or die "SDL_SetVideoMode failed: " . (DC::SDL_GetError) . "\n"; |
2236 | or die "SDL_SetVideoMode failed: " . (DC::SDL_GetError) . "\n"; |
2211 | |
2237 | |
2212 | $SDL_ACTIVE = 1; |
2238 | $SDL_ACTIVE = 1; |
2213 | $LAST_REFRESH = time - 0.01; |
2239 | $LAST_REFRESH = time - 0.01; |
2214 | |
2240 | |
… | |
… | |
2394 | |
2420 | |
2395 | $MODE_SLIDER->set_range ([$CFG->{sdl_mode}, 0, $#SDL_MODES, 1, 1]); |
2421 | $MODE_SLIDER->set_range ([$CFG->{sdl_mode}, 0, $#SDL_MODES, 1, 1]); |
2396 | $MODE_SLIDER->emit (changed => $CFG->{sdl_mode}); |
2422 | $MODE_SLIDER->emit (changed => $CFG->{sdl_mode}); |
2397 | |
2423 | |
2398 | $CAVEAT_LABEL->set_text ("None :)"); |
2424 | $CAVEAT_LABEL->set_text ("None :)"); |
2399 | $CAVEAT_LABEL->set_text ("Non-accelerated video mode") |
2425 | $CAVEAT_LABEL->set_text ("Software Rendering (very slow)") |
2400 | unless DC::SDL_GL_GetAttribute DC::SDL_GL_ACCELERATED_VISUAL; |
2426 | unless DC::SDL_GL_GetAttribute DC::SDL_GL_ACCELERATED_VISUAL; |
2401 | |
2427 | |
2402 | $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]); |
2428 | $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]); |
2403 | } |
2429 | } |
2404 | |
2430 | |
… | |
… | |
2504 | $SIG{INT} = $SIG{TERM} = sub { |
2530 | $SIG{INT} = $SIG{TERM} = sub { |
2505 | EV::unloop; |
2531 | EV::unloop; |
2506 | #d# TODO calling exit here hangs the process in some futex |
2532 | #d# TODO calling exit here hangs the process in some futex |
2507 | }; |
2533 | }; |
2508 | |
2534 | |
2509 | { |
2535 | # due to mac os x + sdl combined briandamage, we need this contortion |
|
|
2536 | sub main { |
|
|
2537 | { |
2510 | DC::Pod::load_docwiki DC::find_rcfile "docwiki.pst"; |
2538 | DC::Pod::load_docwiki DC::find_rcfile "docwiki.pst"; |
2511 | |
2539 | |
2512 | if (-e "$Deliantra::VARDIR/client.cf") { |
2540 | if (-e "$Deliantra::VARDIR/client.cf") { |
2513 | DC::read_cfg "$Deliantra::VARDIR/client.cf"; |
2541 | DC::read_cfg "$Deliantra::VARDIR/client.cf"; |
2514 | } else { |
2542 | } else { |
2515 | #TODO: compatibility cruft |
2543 | #TODO: compatibility cruft |
2516 | DC::read_cfg "$Deliantra::OLDDIR/cfplusrc"; |
2544 | DC::read_cfg "$Deliantra::OLDDIR/cfplusrc"; |
2517 | print STDERR "INFO: used old configuration file\n"; |
2545 | print STDERR "INFO: used old configuration file\n"; |
2518 | } |
2546 | } |
2519 | |
2547 | |
2520 | DC::DB::Server::run; |
2548 | DC::DB::Server::run; |
2521 | |
2549 | |
2522 | if ($CFG->{db_schema} < 1) { |
2550 | if ($CFG->{db_schema} < 1) { |
2523 | warn "INFO: upgrading database schema from 0 to 1, mapcache and tilecache will be lost\n"; |
2551 | warn "INFO: upgrading database schema from 0 to 1, mapcache and tilecache will be lost\n"; |
2524 | DC::DB::nuke_db; |
2552 | DC::DB::nuke_db; |
2525 | $CFG->{db_schema} = 1; |
2553 | $CFG->{db_schema} = 1; |
2526 | DC::write_cfg; |
2554 | DC::write_cfg; |
2527 | } |
2555 | } |
2528 | |
2556 | |
2529 | DC::DB::open_db; |
2557 | DC::DB::open_db; |
2530 | |
2558 | |
2531 | DC::UI::set_layout ($::CFG->{layout}); |
2559 | DC::UI::set_layout ($::CFG->{layout}); |
2532 | |
2560 | |
2533 | my %DEF_CFG = ( |
2561 | my %DEF_CFG = ( |
2534 | sdl_mode => 0, |
2562 | sdl_mode => undef, |
2535 | fullscreen => 1, |
2563 | fullscreen => 1, |
2536 | fast => 0, |
2564 | fast => 0, |
2537 | force_opengl11 => undef, |
2565 | force_opengl11 => undef, |
2538 | disable_alpha => 0, |
2566 | disable_alpha => 0, |
|
|
2567 | smooth_movement => 1, |
2539 | texture_compression => 1, |
2568 | texture_compression => 1, |
2540 | map_scale => 1, |
2569 | map_scale => 1, |
2541 | fow_enable => 1, |
2570 | fow_enable => 1, |
2542 | fow_intensity => 0, |
2571 | fow_intensity => 0, |
2543 | map_smoothing => 1, |
2572 | map_smoothing => 1, |
2544 | gui_fontsize => 1, |
2573 | gui_fontsize => 1, |
2545 | log_fontsize => 0.7, |
2574 | log_fontsize => 0.7, |
2546 | gauge_fontsize => 1, |
2575 | gauge_fontsize => 1, |
2547 | gauge_size => 0.35, |
2576 | gauge_size => 0.35, |
2548 | stat_fontsize => 0.7, |
2577 | stat_fontsize => 0.7, |
2549 | mapsize => 100, |
2578 | mapsize => 100, |
2550 | audio_enable => 1, |
2579 | audio_enable => 1, |
2551 | audio_hw_channels => 0, |
2580 | audio_hw_channels => 0, |
2552 | audio_hw_frequency => 0, |
2581 | audio_hw_frequency => 0, |
2553 | audio_hw_chunksize => 0, |
2582 | audio_hw_chunksize => 0, |
2554 | audio_mix_channels => 8, |
2583 | audio_mix_channels => 8, |
2555 | effects_enable => 1, |
2584 | effects_enable => 1, |
2556 | effects_volume => 1, |
2585 | effects_volume => 1, |
2557 | bgm_enable => 1, |
2586 | bgm_enable => 1, |
2558 | bgm_volume => 0.5, |
2587 | bgm_volume => 0.5, |
2559 | output_rate => "", |
2588 | output_rate => "", |
2560 | pickup => 0, |
2589 | pickup => 0, |
2561 | inv_sort => "mtime", |
2590 | inv_sort => "mtime", |
2562 | default => "profile", # default profile |
2591 | default => "profile", # default profile |
2563 | show_tips => 1, |
2592 | show_tips => 1, |
2564 | logview_max_par => 1000, |
2593 | logview_max_par => 1000, |
2565 | shift_fire_stop => 0, |
2594 | shift_fire_stop => 0, |
2566 | ); |
2595 | ); |
2567 | |
2596 | |
2568 | while (my ($k, $v) = each %DEF_CFG) { |
2597 | while (my ($k, $v) = each %DEF_CFG) { |
2569 | $CFG->{$k} = $v unless exists $CFG->{$k}; |
2598 | $CFG->{$k} = $v unless exists $CFG->{$k}; |
2570 | } |
2599 | } |
2571 | |
2600 | |
2572 | $CFG->{profile}{default}{host} ||= "gameserver.deliantra.net"; |
2601 | $CFG->{profile}{default}{host} ||= "gameserver.deliantra.net"; |
2573 | $PROFILE = $CFG->{profile}{default}; |
2602 | $PROFILE = $CFG->{profile}{default}; |
2574 | |
2603 | |
2575 | # convert old bindings (only default profile matters) |
2604 | # convert old bindings (only default profile matters) |
2576 | if (my $bindings = delete $PROFILE->{bindings}) { |
2605 | if (my $bindings = delete $PROFILE->{bindings}) { |
2577 | while (my ($mod, $syms) = each %$bindings) { |
2606 | while (my ($mod, $syms) = each %$bindings) { |
2578 | while (my ($sym, $cmds) = each %$syms) { |
2607 | while (my ($sym, $cmds) = each %$syms) { |
2579 | push @{ $PROFILE->{macro} }, { |
2608 | push @{ $PROFILE->{macro} }, { |
2580 | accelkey => [$mod*1, $sym*1], |
2609 | accelkey => [$mod*1, $sym*1], |
2581 | action => $cmds, |
2610 | action => $cmds, |
|
|
2611 | }; |
2582 | }; |
2612 | } |
2583 | } |
2613 | } |
2584 | } |
2614 | } |
2585 | } |
|
|
2586 | |
2615 | |
2587 | sdl_init; |
2616 | sdl_init; |
2588 | |
2617 | |
2589 | { |
2618 | { |
2590 | my @fonts = map DC::find_rcfile "fonts/$_", qw( |
2619 | my @fonts = map DC::find_rcfile "fonts/$_", qw( |
2591 | DejaVuSans.ttf |
2620 | DejaVuSans.ttf |
2592 | DejaVuSansMono.ttf |
2621 | DejaVuSansMono.ttf |
2593 | DejaVuSans-Bold.ttf |
2622 | DejaVuSans-Bold.ttf |
2594 | DejaVuSansMono-Bold.ttf |
2623 | DejaVuSansMono-Bold.ttf |
2595 | DejaVuSans-Oblique.ttf |
2624 | DejaVuSans-Oblique.ttf |
2596 | DejaVuSansMono-Oblique.ttf |
2625 | DejaVuSansMono-Oblique.ttf |
2597 | DejaVuSans-BoldOblique.ttf |
2626 | DejaVuSans-BoldOblique.ttf |
2598 | DejaVuSansMono-BoldOblique.ttf |
2627 | DejaVuSansMono-BoldOblique.ttf |
2599 | ); |
2628 | ); |
2600 | |
2629 | |
2601 | DC::add_font $_ for @fonts; |
2630 | DC::add_font $_ for @fonts; |
2602 | |
2631 | |
2603 | $FONT_PROP = new_from_file DC::Font $fonts[0]; |
2632 | $FONT_PROP = new_from_file DC::Font $fonts[0]; |
2604 | $FONT_FIXED = new_from_file DC::Font $fonts[1]; |
2633 | $FONT_FIXED = new_from_file DC::Font $fonts[1]; |
2605 | |
2634 | |
2606 | $FONT_PROP->make_default; |
2635 | $FONT_PROP->make_default; |
2607 | |
2636 | |
2608 | DC::pango_init; |
2637 | DC::pango_init; |
2609 | } |
2638 | } |
2610 | |
2639 | |
2611 | # compare mono (ft) vs. rgba (cairo) |
2640 | # compare mono (ft) vs. rgba (cairo) |
2612 | # ft - 1.8s, cairo 3s, even in alpha-only mode |
2641 | # ft - 1.8s, cairo 3s, even in alpha-only mode |
2613 | # for my $rgba (0..1) { |
2642 | # for my $rgba (0..1) { |
2614 | # my $t1 = Time::HiRes::time; |
2643 | # my $t1 = Time::HiRes::time; |
… | |
… | |
2619 | # } |
2648 | # } |
2620 | # my $t2 = Time::HiRes::time; |
2649 | # my $t2 = Time::HiRes::time; |
2621 | # warn $t2-$t1; |
2650 | # warn $t2-$t1; |
2622 | # } |
2651 | # } |
2623 | |
2652 | |
2624 | video_init; |
2653 | video_init; |
2625 | audio_init; |
2654 | audio_init; |
2626 | } |
2655 | } |
2627 | |
2656 | |
2628 | show_tip_of_the_day if $CFG->{show_tips}; |
2657 | show_tip_of_the_day if $CFG->{show_tips}; |
2629 | |
2658 | |
2630 | our $STARTUP_CANCEL = EV::idle sub { |
2659 | our $STARTUP_CANCEL = EV::idle sub { |
2631 | undef $::STARTUP_CANCEL; |
2660 | undef $::STARTUP_CANCEL; |
2632 | $startup_done->(); |
2661 | $startup_done->(); |
2633 | }; |
2662 | }; |
2634 | |
2663 | |
2635 | delete $SIG{__DIE__}; |
2664 | delete $SIG{__DIE__}; |
2636 | EV::loop; |
2665 | EV::loop; |
2637 | |
2666 | |
2638 | #video_shutdown; |
2667 | #video_shutdown; |
2639 | #audio_shutdown; |
2668 | #audio_shutdown; |
2640 | DC::OpenGL::quit; |
2669 | DC::OpenGL::quit; |
2641 | DC::SDL_Quit; |
2670 | DC::SDL_Quit; |
2642 | DC::DB::Server::stop; |
2671 | DC::DB::Server::stop; |
|
|
2672 | } |
|
|
2673 | |
|
|
2674 | DC::SDL_braino; # see sub above |
2643 | |
2675 | |
2644 | =head1 NAME |
2676 | =head1 NAME |
2645 | |
2677 | |
2646 | deliantra - A Deliantra MORPG game client |
2678 | deliantra - A Deliantra MORPG game client |
2647 | |
2679 | |
… | |
… | |
2664 | 4 show fps |
2696 | 4 show fps |
2665 | 8 suppress tooltips |
2697 | 8 suppress tooltips |
2666 | |
2698 | |
2667 | =head1 AUTHOR |
2699 | =head1 AUTHOR |
2668 | |
2700 | |
2669 | Marc Lehmann <crossfire@schmorp.de>, Robin Redeker <elmex@ta-sa.org> |
2701 | Marc Lehmann <deliantra@schmorp.de>, Robin Redeker <elmex@ta-sa.org> |
2670 | |
2702 | |
2671 | |
2703 | |
2672 | |
2704 | |