diff options
Diffstat (limited to 'perl-install/install_gtk.pm')
| -rw-r--r-- | perl-install/install_gtk.pm | 533 | 
1 files changed, 0 insertions, 533 deletions
| diff --git a/perl-install/install_gtk.pm b/perl-install/install_gtk.pm deleted file mode 100644 index 778f75381..000000000 --- a/perl-install/install_gtk.pm +++ /dev/null @@ -1,533 +0,0 @@ -package install_gtk; # $Id$ - -use diagnostics; -use strict; - -use my_gtk qw(:helpers :wrappers); -use common; -use lang; -use devices; - -#-##################################################################################### -#-INTERN CONSTANT -#-##################################################################################### -my @themes_vga16 = qw(blue blackwhite savane); -my @themes_desktop = qw(mdk-Desktop DarkMarble marble3d blueHeart); -my @themes_firewall = qw(mdk-Firewall); -my @themes = qw(mdk DarkMarble marble3d blueHeart); - -my (@background1, @background2); - - -#------------------------------------------------------------------------------ -sub load_rc { -    my ($name) = @_; - -    if (my ($f) = grep { -r $_ } map { "$_/$name.rc" } ("share", $ENV{SHARE_PATH}, dirname(__FILE__))) { -	Gtk::Rc->parse($f); -	foreach (cat_($f)) { -	    if (/style\s+"background"/ .. /^\s*$/) { -		@background1 = map { $_ * 256 * 257 } split ',', $1 if /NORMAL.*\{(.*)\}/; -		@background2 = map { $_ * 256 * 257 } split ',', $1 if /PRELIGHT.*\{(.*)\}/; -	    } -	} -    } -} - -sub default_theme { -    my ($o) = @_; -    @themes = @themes_desktop if $o->{meta_class} eq 'desktop'; -    @themes = @themes_firewall if $o->{meta_class} eq 'firewall'; -    @themes = @themes_vga16 if $o->{simple_themes} || $o->{vga16}; -    install_theme($o, $o->{theme} || $themes[0]); -} - -#------------------------------------------------------------------------------ -sub install_theme { -    my ($o, $theme) = @_; - -    $o->{theme} = $theme || $o->{theme}; - -    load_rc($_) foreach "themes-$o->{theme}", "install", "themes"; - -    if (my ($font, $font2) = lang::get_x_fontset($o->{lang}, $::rootwidth < 800 ? 10 : 12)) { -	$font2 ||= $font; -	Gtk::Rc->parse_string(qq( -style "default-font"  -{ -   fontset = "$font,*" -} -style "small-font" -{ -   fontset = "$font2,*" -} -widget "*" style "default-font" -widget "*Steps*" style "small-font" - -)); -    } - -    gtkset_background(@background1) unless $::live; #- || testing; - -    create_logo_window($o); -    create_help_window($o); -} - -#------------------------------------------------------------------------------ -sub create_big_help { -    my ($o) = @_; -    my $w = my_gtk->new('', grab => 1, force_position => [ $::stepswidth, $::logoheight ]); -    $w->{rwindow}->set_usize($::logowidth, $::rootheight - $::logoheight); -    gtkadd($w->{window}, -	   gtkpack_(new Gtk::VBox(0,0), -		    1, createScrolledWindow(gtktext_insert(new Gtk::Text, $o->{current_help})), -		    0, gtksignal_connect(my $ok = new Gtk::Button(_("Ok")), "clicked" => sub { Gtk->main_quit }), -		   )); -    $ok->grab_focus; -    $w->main; -    gtkset_mousecursor_normal(); -} - -#------------------------------------------------------------------------------ -sub create_help_window { -    my ($o) = @_; - -    my $w; -    if ($w = $o->{help_window}) { -	$_->destroy foreach $w->{window}->children; -    } else { -	$w = bless {}, 'my_gtk'; -	$w->{rwindow} = $w->{window} = new Gtk::Window; -	$w->{rwindow}->set_uposition($::rootwidth - $::helpwidth, $::rootheight - $::helpheight); -	$w->{rwindow}->set_usize($::helpwidth, $::helpheight); -	$w->sync; -    } -    my $pixmap = gtkpng("$ENV{SHARE_PATH}/help.png"); -    gtkadd($w->{window}, -	   gtkpack_(new Gtk::HBox(0,-2), -		    0, gtkadd(gtksignal_connect(new Gtk::Button, clicked => sub { create_big_help($o) }), $pixmap), -		    1, createScrolledWindow($o->{help_window_text} = new Gtk::Text), -		   )); -    $o->set_help($o->{step}) if $o->{step}; -    $w->show; -    $o->{help_window} = $w; -} - -#------------------------------------------------------------------------------ -sub create_steps_window { -    my ($o) = @_; - -    my $PIX_H = my $PIX_W = 21; - -    $o->{steps_window}->destroy if $o->{steps_window}; - -    my $w = bless {}, 'my_gtk'; -    $w->{rwindow} = $w->{window} = new Gtk::Window; -    $w->{rwindow}->set_uposition(0, 0); -    $w->{rwindow}->set_usize($::stepswidth, $::stepsheight); -    $w->{rwindow}->set_name('Steps'); -    $w->{rwindow}->set_events('button_press_mask'); -    #$w->show; - -    gtkadd($w->{window}, -	   gtkpack_(new Gtk::VBox(0,0), -		    (map {; 1, $_ } map { -			my $step_name = $_; -			my $step = $o->{steps}{$_}; -			my $darea = new Gtk::DrawingArea; -			my $in_button; -			my $draw_pix = sub { -			    my ($map, $mask) = gtkcreate_xpm($darea, $_[0]); -			    $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -							 $map, 0, 0, -							 ($darea->allocation->[2]-$PIX_W)/2 + 3, -							 ($darea->allocation->[3]-$PIX_H)/2, -							 $PIX_W , $PIX_H ); -			}; - -			my $f = sub {  -			    my ($type) = @_; -			    my $color = $step->{done} ? 'green' : $step->{entered} ? 'orange' : 'red'; -			    "$ENV{SHARE_PATH}/step-$color$type.xpm"; -			}; -			$darea->set_usize($PIX_W+3,$PIX_H); -			$darea->set_events(['exposure_mask', 'enter_notify_mask', 'leave_notify_mask', 'button_press_mask', 'button_release_mask' ]); -			$darea->signal_connect(expose_event => sub { $draw_pix->($f->('')) }); -			if ($step->{reachable}) { -			    $darea->signal_connect(enter_notify_event => sub { $in_button=1; $draw_pix->($f->('-on')); }); -			    $darea->signal_connect(leave_notify_event => sub { undef $in_button; $draw_pix->($f->('')); }); -			    $darea->signal_connect(button_press_event => sub { $draw_pix->($f->('-click')); }); -			    $darea->signal_connect(button_release_event => sub { $in_button && die "setstep $step_name\n" }); -			} -			gtkpack_(new Gtk::HBox(0,5), 0, $darea, 0, new Gtk::Label(translate($step->{text}))); -		    } grep { -			!eval $o->{steps}{$_}{hidden}; -		    } @{$o->{orderedSteps}}), -		    0, gtkpack(new Gtk::HBox(0,0), map { -			my $t = $_; -			my $w = new Gtk::Button(''); -			$w->set_name($t); -			$w->set_usize(0, 7); -			gtksignal_connect($w, clicked => sub { -			    $::setstep or return; #- just as setstep s -			    install_theme($o, $t); die "theme_changed\n"  -			}); -		    } @themes))); -    $w->show; -    $o->{steps_window} = $w; -} - -#------------------------------------------------------------------------------ -sub create_logo_window { -    my ($o) = @_; - -    gtkdestroy($o->{logo_window}); -    my $w = bless {}, 'my_gtk'; -    $w->{rwindow} = $w->{window} = new Gtk::Window; -    $w->{rwindow}->set_uposition($::stepswidth, 0); -    $w->{rwindow}->set_usize($::logowidth, $::logoheight); -    $w->{rwindow}->set_name("logo"); -    $w->show; -    my $file = $o->{meta_class} eq 'desktop' ? "logo-mandrake-Desktop.png" : "logo-mandrake.png"; -    $o->{meta_class} eq 'firewall' and $file = "logo-mandrake-Firewall.png"; -    -r $file or $file = "$ENV{SHARE_PATH}/$file"; -    -r $file and gtkadd($w->{window}, gtkpng($file)); -    $o->{logo_window} = $w; -} - -#------------------------------------------------------------------------------ -sub init_sizes() { -    ($::rootheight,  $::rootwidth)    = my_gtk::gtkroot()->get_size; -    $::live and $::rootheight -= 80; -    #- ($::rootheight,  $::rootwidth)    = (min(768, $::rootheight), min(1024, $::rootwidth)); -    ($::stepswidth,  $::stepsheight)  = (145, $::rootheight); -    ($::logowidth,   $::logoheight)   = ($::rootwidth - $::stepswidth, 40); -    ($::helpwidth,   $::helpheight)   = ($::rootwidth - $::stepswidth, 104); -    ($::windowwidth, $::windowheight) = ($::rootwidth - $::stepswidth, $::rootheight - $::helpheight - $::logoheight); -} - -#------------------------------------------------------------------------------ -sub createXconf { -    my ($file, $mouse_type, $mouse_dev, $wacom_dev) = @_; - -    devices::make("/dev/kbd") if arch() =~ /^sparc/; #- used by Xsun style server. -    symlinkf(devices::make($mouse_dev), "/dev/mouse"); - -    #- needed for imlib to start on 8-bit depth visual. -    symlink("/tmp/stage2/etc/imrc", "/etc/imrc"); -    symlink("/tmp/stage2/etc/im_palette.pal", "etc/im_palette.pal"); - -if (arch() =~ /^ia64/) { -     require Xconfigurator; -     my ($card) = Xconfigurator::cardConfigurationAuto(); -     Xconfigurator::updateCardAccordingName($card, $card->{type}) if $card && $card->{type}; -    local *F; -    open F, ">$file" or die "can't create X configuration file $file"; -    print F <<END; - -Section "Files" -   FontPath   "/usr/X11R6/lib/X11/fonts:unscaled" -EndSection - -Section "InputDevice" -    Identifier "Keyboard1" -    Driver      "Keyboard" -    Option "AutoRepeat"  "250 30" -    Option "XkbDisable" - -    Option "XkbRules" "xfree86" -    Option "XkbModel" "pc105" -    Option "XkbLayout" "" -EndSection - -Section "InputDevice" -    Identifier  "Mouse1" -    Driver      "mouse" -    Option "Protocol"    "$mouse_type" -    Option "Device"      "/dev/mouse" -EndSection - -Section "Monitor" -    Identifier "Generic|High Frequency SVGA, 1024x768 at 70 Hz" -    VendorName "Unknown" -    ModelName  "Unknown" -    HorizSync  31.5-35.5 -    VertRefresh 50-70 -EndSection - -Section "Device" -    Identifier "Generic VGA" -    Driver     "vga" -EndSection - -Section "Device" -    Identifier  "device1" -    VendorName  "Unknown" -    BoardName   "Unknown" -    Driver      "$card->{driver}" -EndSection - -Section "Screen" -    Identifier "screen1" -    Device      "device1" -    Monitor     "Generic|High Frequency SVGA, 1024x768 at 70 Hz" -    DefaultColorDepth 16 -    Subsection "Display" -        Depth       16 -        Modes       "800x600" "640x480" -        ViewPort    0 0 -    EndSubsection -EndSection - -Section "ServerLayout" -    Identifier "layout1" -    Screen     "screen1" -    InputDevice "Mouse1" "CorePointer" -    InputDevice "Keyboard1" "CoreKeyboard" -EndSection - -END - - -} -else -  { - - -    my $wacom; -    if ($wacom_dev) { -	$wacom_dev = devices::make($wacom_dev); -	$wacom = <<END; -Section "Module" -   Load "xf86Wacom.so" -EndSection - -Section "XInput" -    SubSection "WacomStylus" -        Port "$wacom_dev" -        AlwaysCore -    EndSubSection -    SubSection "WacomCursor" -        Port "$wacom_dev" -        AlwaysCore -    EndSubSection -    SubSection "WacomEraser" -        Port "$wacom_dev" -        AlwaysCore -    EndSubSection -EndSection -END -    } - -    local *F; -    open F, ">$file" or die "can't create X configuration file $file"; -    print F <<END; -Section "Files" -   FontPath   "/usr/X11R6/lib/X11/fonts:unscaled" -EndSection - -Section "Keyboard" -   Protocol    "Standard" -   AutoRepeat  0 0 - -   LeftAlt         Meta -   RightAlt        Meta -   ScrollLock      Compose -   RightCtl        Control -END - -    if (arch() =~ /^sparc/) { -	print F <<END; -   XkbRules    "sun" -   XkbModel    "sun" -   XkbLayout   "us" -   XkbCompat   "compat/complete" -   XkbTypes    "types/complete" -   XkbKeycodes "sun(type5)" -   XkbGeometry "sun(type5)" -   XkbSymbols  "sun/us(sun5)" -END -    } else { -	print F "    XkbDisable\n"; -    } - -    print F <<END; -EndSection - -Section "Pointer" -   Protocol    "$mouse_type" -   Device      "/dev/mouse" -   ZAxisMapping 4 5 -EndSection - -$wacom - -Section "Monitor" -   Identifier  "My Monitor" -   VendorName  "Unknown" -   ModelName   "Unknown" -   HorizSync   31.5-35.5 -   VertRefresh 50-70 -   Modeline "640x480"     25.175 640  664  760  800   480  491  493  525 -   Modeline "640x480"     28.3   640  664  760  800   480  491  493  525 -   ModeLine "800x600"     36     800  824  896 1024   600  601  603  625 -EndSection - - -Section "Device" -   Identifier "Generic VGA" -   VendorName "Unknown" -   BoardName "Unknown" -   Chipset "generic" -EndSection - -Section "Device" -   Identifier "svga" -   VendorName "Unknown" -   BoardName "Unknown" -EndSection - -Section "Screen" -    Driver      "vga16" -    Device      "Generic VGA" -    Monitor     "My Monitor" -    Subsection "Display" -        Modes       "640x480" -        ViewPort    0 0 -    EndSubsection -EndSection - -Section "Screen" -    Driver      "fbdev" -    Device      "Generic VGA" -    Monitor     "My Monitor" -    Subsection "Display" -        Depth       16 -        Modes       "default" -        ViewPort    0 0 -    EndSubsection -EndSection - -Section "Screen" -    Driver "svga" -    Device      "svga" -    Monitor     "My Monitor" -    Subsection "Display" -        Depth       16 -        Modes       "800x600" "640x480" -        ViewPort    0 0 -    EndSubsection -EndSection - -Section "Screen" -    Driver      "accel" -    Device      "svga" -    Monitor     "My Monitor" -    Subsection "Display" -        Depth       16 -        Modes       "800x600" "640x480" -        ViewPort    0 0 -    EndSubsection -EndSection -END -} -} -#-   ModeLine "640x480"     28     640  672  768  800   480  490  492  525 - - -sub test_mouse { -    my ($mouse) = @_; - -    my $w = my_gtk->new; -    my ($width, $height, $offset) = (210, round_up(min(350, $::windowheight - 150), 6), 25); -    my $darea = new Gtk::DrawingArea; -    $darea->set_events([ 'button_press_mask', 'button_release_mask' ]);  #$darea must be unrealized. -    gtkadd($w->{window}, -  	   gtkpack(my $vbox_grab = new Gtk::VBox(0,0), -		   gtksize(gtkset_usize($darea, $width+1, $height+1), $width+1, $height+1), -		   my $okcancel = gtkset_sensitive(create_okcancel($w, '', '', "edge"), 0), -		  ), -	  ); -    $okcancel->set_uposition(2, $height-23); -#    $w->{window}->set_usize($width+1, $height+1); -    Gtk->timeout_add(2000, sub { gtkset_sensitive($okcancel, 1) }); - -    $darea->realize(); -    my ($m3_image, $m3_mask) = gtkcreate_xpm($darea, 'mouse_3b.xpm'); -    my ($m3_imagep, $m3_maskp) = gtkcreate_xpm($darea, 'mouse_3b+.xpm'); -    my ($m3_left, $m3_left_mask) = gtkcreate_xpm($darea, 'mouse_left.xpm'); -    my ($m3_right, $m3_right_mask) = gtkcreate_xpm($darea, 'mouse_right.xpm'); -    my ($m3_middle, $m3_middle_mask) = gtkcreate_xpm($darea, 'mouse_middle.xpm'); -    my $image = $m3_image; -    $mouse->{nbuttons} > 3 and $image = $m3_imagep; -    my $draw_text = sub { -  	my ($t, $y) = @_; -  	my $font = $darea->style->font; -  	my $w = $font->string_width($t); -  	$darea->window->draw_string($font, $darea->style->black_gc, ($width - $w) / 2, $y, $t); -    }; -    my $drawarea; $drawarea = sub { $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -								 $image, 0, 0, -								 ($darea->allocation->[2]-$width)/2, ($darea->allocation->[3]-$height)/2, -								 210, 350); -				    $draw_text->(_("Please test the mouse"), $height - 80); -				    $draw_text->(_("To activate the mouse,"), $height - 65) if $mouse->{XMOUSETYPE} eq 'IMPS/2'; -				    $draw_text->(_("MOVE YOUR WHEEL!"), $height - 50) if $mouse->{XMOUSETYPE} eq 'IMPS/2'; -				}; - -    my $paintButton = sub { -	my ($nb, $pressed) = @_; -	my $x = 60 + $nb*33; -	$drawarea->(); -	if ($nb == 0) { -	    $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -					 $m3_left, 0, 0, -					 ($darea->allocation->[2]-$width)/2+31, ($darea->allocation->[3]-$height)/2 + 52, -					 59, 91); -	} elsif ($nb == 2) { -	    $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -					 $m3_right, 0, 0, -					 ($darea->allocation->[2]-$width)/2+117, ($darea->allocation->[3]-$height)/2 + 52, -					 61, 91); -	} elsif ($nb == 1) { -	    if ($mouse->{nbuttons} > 3) { -		$darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -					     $m3_middle, 0, 0, -					     ($darea->allocation->[2]-$width)/2+98, ($darea->allocation->[3]-$height)/2 + 67, -					     13, 62); -	    } else { -		$darea->window->draw_arc ( $darea->style->black_gc, -					   1, ($darea->allocation->[2]-$width)/2 + $x, ($darea->allocation->[3]-$height)/2 + 90, 20, 25, -					   0, 360*64); -	    } -	} elsif ($nb == 4) { -	    $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -					 $m3_middle, 0, 0, -					 ($darea->allocation->[2]-$width)/2+98, ($darea->allocation->[3]-$height)/2 + 67, -					 13, 62) -	} elsif ($nb == 5) { -	    $darea->window->draw_pixmap ($darea->style->bg_gc('normal'), -					 $m3_middle, 0, 0, -					 ($darea->allocation->[2]-$width)/2+98, ($darea->allocation->[3]-$height)/2 + 67, -					 13, 62) -	} -    }; -    $darea->signal_connect(button_press_event => sub { -  			       my $b = $_[1]{button}; -			       $paintButton->($b - 1); -  			   }); -    $darea->signal_connect(button_release_event => sub {  -			       $drawarea->() -  			   }); -    $darea->signal_connect(expose_event => sub { $drawarea->() }); -    $darea->size($width, $height); -    $darea->set_events([ 'button_press_mask', 'button_release_mask' ]); -    $w->sync; # HACK -#    $okcancel->draw(undef); -    Gtk::Gdk->pointer_grab($darea->window, 1, -  			   [ 'pointer_motion_mask'],  -  			   $darea->window, undef ,0); -    $w->main; -} - -1; | 
