DrakX Specification for Linux-Mandrake 8.0

Current team of Install group is :

gc
damien
fpons
pixel


  Boot process (stage1)

    Installation begin by booting from CD-ROM or Diskette. From CD-ROM all
installation method are available (CD, HD, NFS, FTP, HTTP) on options. From
Diskette according to image selected, only some related method (network or cdrom
or hd) are available and module managed due to size limitation to 1.44Mb.
    Options are always available by pressing on F1.

  DrakX process (stage2)

    DrakX installation organized in steps (execution sequence described below).
Steps listed on left side and help available on bottom right side. most of the
screen is available for various dialog for interacting with the user. Steps
execution sequence is automated and described below.

Mouse is probed and if none has been found or if the mouse has not moved, a
specific mouse configuration is displayed at the begining.


Before the graphical steps, there is a detection step. It detects various
hardware, including modems (from tty0 to tty7), mouse (serial, usb, ps/2) and
tablets.

    Steps

      Choose Your language: step always displayed. default choice is previous one or
English. After choosing a language, a license splash screen translated in the
chosen language is displayed with Accept and Refuse buttons. Refuse should
stop installation. Accept validate language choice which are propagated to all
DrakX visible widget. Advanced mode allow to select other language available to
be installed. Advanced mode allow to select language which will be installed on
system.
      If step is redone, the license is no more displayed.

      Select Install Class: step always displayed. default choice is previous one
or Recommended. Only one other option available is Customized. Two buttons
available are Install or Upgrade. Available steps (left side) are changed
according to installation class selected, where the default is the one of
Recommended with Install.

      Hard Drive Detection: step always displayed. In recommended mode,
automatically done. In Customized mode, all modules that manage SCSI/IDE cards
are loaded automatically and a question asking for other module to load is
displayed.
      If clicked later or if to the question to load other module the
answer is Yes, a list of module is displayed (or if the question to other
module to load is. When a module is chosen, two options are available
Autoprobe and Specify options. Autoprobe try to load the module without any
other user options (default module parameter). Specify options allow user to
give module parameters individually in a list for all known parameters. At this
point Ok or Cancel are available, Cancel should stop the module installation
and go to next step. If any error occurs during module installation, a question
asking to try with other parameter is displayed, the same module is still used.

      Setup filesystems: step always displayed. display a list of available choice
accoding to what has been probed. May contains Use free space, "Use existing
partition, Use the window partition for loopback, Use the free space on the
Windows partition, Remove Windows(TM)|Erase entire disk" (according to disk
configuration => only one big fat for the first case only), "Custom disk
partitioning".
      If Use free space mode, auto allocation in available on available disk.
      If Use existing partition mode, a list of partition named in Linux
scheme are displayed with their approximate size in Mb and propose mount point
to choose in list boxes for each partitions available on hard drive.
      If Use the window partition for loopback mode, DrakX use available size
on the windows partition to create a root file and a swap file which will be
used in loopback, this means this is a lnx4win installation.
      If Use the free space on the Windows partition mode, DrakX will resize
the windows partition and allocate true linux filesystem (at least / and swap).
      If Remove Windows(TM)|Erase entire disk mode, DrakX clean the
partition table before auto allocating partition.
      If Custom disk partitioning mode, diskdrake is launch. TO BE DEFINED to
change make diskdrake use only advanced mode.
Diskdrake show all partition of all non-removable disk graphically. All special
partition are hidden, only user accessible partition are visible: this remove
extended partition, whole disk partition on sparc platform. Clicking on a disk
notebook tab show all his partitions. Clicking on a partition show all actions
available for this partition (depend if customized or advanced mode) as well as
information on this partition (depend if customized or advanced mode). Most
diskdrake operation are done without writing on disk (exception are Resizing
partitions) and everything is written once on the disk when exiting diskdrake,
at any time if writing partition table is necessary, there are always a dialog
box asking the user to confirm the write. If no operation are modifying
partition table, no dialog is displayed on exit (for example if giving mount
point to partition). General action are available too:
        Clear All: clear all partition of the given disk.
        Auto allocate: try to allocate partition in available disk (not the
seen disk).
        Undo: undo last operation.
        Done: quit and save changes.
Other operations are available in advanced mode:
        Rescue partition table: try to rescue a lost partition table,
absolutely no garantee to succeed and may destroy what could be saveable by
another tools.
        Reload: reload partition table from disk, erasing all changes in
memory done by the user.
        Wizard: go to partition wizard, that the partition filesystems default
behaviour on startup.
        Restore from floppy: restore a partition table from previously saved
partition table from diskdrake.
        Save to floppy: save partition table to floppy.
        Options: global options available for filesystem configuration. This
include Removable media automouting supermount check box disabled by default.
      Operation available on partition are:
        Mount point: change or define mount point for partition, only
available for true filesystem partition.
        Resize: resize partition, if a specific algorithm to keep data is
used no data may be lost, else all data are lost but nothing is written by
diskdrake on the partition data in this last case (this means data can be
restored by restoring original size and location).
        Delete: delete partition, if the same partition is created (same type,
location, size) all data can be restored as diskdrake doesn't write on partition
data.
      Operation available on partition table but in advanced mode are:
        Type: change type of partition, all data will be lost but diskdrake as
above does not destroy them, and everyting can be restored.
        Format: format partition, at this point, all data ARE LOST.
        Mount: mount partition now, usefull for swap to increase memory
capacity for machine low on resource that are not available to complete setup
filesystem step correctly (problably if a resize partition is used on FAT fs).
allow Mounting swap on customized mode too.
      A legend for partition type colors is available
(Ext2,ReiserFS,Swap,FAT,Other,Empty). It has additionnal features to create a
partition or change its type (only available in advanced mode).

      Format partitions: step always displayed. display list of partition to
format with click boxes. Some are defined according to type of partitions and if
the partition has been created or taken back.
If a partition has already been formated, it is not proposed, or if it should
not be proposed (alrady existing partition like /mnt/windows).
On Advanced tag, an additional dialog is displayed to select partition to format
(all available partition listed) and to format them with bad block checking.

      Choose packages: step always displayed. default selection done to be
correct according to size available, Install or Upgrade, Hardware available.
This selection is done according to Mandrake first choice of packages.
On all mode, display groups and main desktop used (KDE or Gnome), an
individual package selection check box is available to allow selecting package
individually. In this case, a dialog displaying a tree with groups, (Mandrake
first choice/alternatives) and packages is shown on the left part, a description
window for each packages is shown on the right part.

      Install system: step always displayed. no interactive and display
installation progression. include if available and on a CD basis a spash screen
of advertising and other (pub!).

      Hardware panel: step always displayed. show current configuration for
Mouse, Keyboard, TimeZone, Graphic/TV Card, Monitor.
At each values chosen (list boxes displayed a
synthesis description) the current dialog is removed from screen and specific
configuration panels are displayed (like currently for mouse, keyboard ...).
And end of these specific configuration panels, this one is remapped on screen
to be accepted in general.

      Sub steps of Hardware panel:

        Configure mouse: displayed on request or if the mouse has not been
moved (so unsafe detection), but have to be displayed earlier. A mouse tree
selection for type is displayed with default case as what is probed or
serial/Generic 2 button Mouse if none has been probed. Cancel disable mouse
modification and Ok allow next mouse configuration dialog. Then comes a serial
port dialog for serial mice (default mouse connected to COM1 if nothing found).
Then a mouse screen control is chown (according to mouse capacity: 3 buttons
with or without mouse, need 7 buttons checking ?). Here Ok validate to go to
next step and Cancel to first mouse dialog displayed (mouse tree selection for
type).

        Configure keyboard: displayed on request. default is set according to
TimeZone definition (itself defaulting to language selection at the beginning).
A list of keyboard is shown to the user and Ok validates change and return to
Hardware panel dialog with enabled change. Cancel abort any modification and
return to the same Hardware panel dialog.

        Configure timezone: displayed on request. default is set according to
language selection. A timezone tree selection is shown with only the subtree
corresponding to the current selection expanded (as other tree dialog). Ok
validates change and return to Hardware panel dialog whereas Cancel avoid
the change before returning to the same main dialog.

        Graphic Card: display graphic card probed. No change available.

        TV Card: display TV/Tuner card probed. No change available.

        Monitor: need execution of ddcxinfos at this point. Only Size, Max
resolution and depth displayed. No change available.


      Miscellaneous step have been removed and dispatched to other steps. "Use
hard drive optimisation and Enable num lock at startup are removed. Choose
security level is moved to security step. Precise RAM size if needed" and
Clean /tmp at each boot are moved to bootloader step.
Removable media automouting is moved to diskdrake options.

      Security: step displayed only in customized mode. TO BE DEFINED. should
display at least securty level to choose. level are Low, Medium, High and
for advanced there are Welcome To Crackers, Poor, Paranoid too.

      Configure networking: step always displayed. dialog always displayed in
both Recommended and Customized mode. A list of network configuration
entries are shown with the following:
        Configure a normal modem connection
        Configure an ISDN connection
        "Configure a DSL (or ADSL) connection
        Configure a cable connection
        Configure local network|Reconfigure local network
        Disable networking|Enable networking
        Done
      By cliking on a specific item, another dialog is displayed to configure
some specific part of the network.
        Configure a normal modem connection: display a question to probe for a
modem if not already detected, then if none are found or probe has been refused
a list of possible serial device are listed (in the form ttySx / COM(x+1) with
the current mouse device removed if it is serial). After that a dialog including
all parameters than can be used is shown. This includes Connection Name,
Phone number, Login ID, Password, Authentication, Domain name, DNS 1
and DNS 2. Authentication is a combo of PAP, Termina-Based and
Script-Based (It seems necessary to get CHAP back on this one, no way of
testing TO BE DEFINED). If no DNS are given, the connection is configured to try
using provider DNS. Ok and Cancel button are available.
        Configure an ISDN connection:
Try to detect some PCI card. If not detected, asks if it's a ISA/pcmcia or PCI
card, and gives the list of the cards. Information are then asked: 
Card IRQ only if ISA/pcmcia
Card mem (DMA) only if ISA/pcmcia
Card IO only if ISA/pcmcia
Card IO_0 only if ISA/pcmcia with io0
Card IO_1 only if ISA/pcmcia with io1
Your personal phone number phone
Provider name (ex provider.net)
Provider phone number
Provider dns 1
Provider dns 2
Dialing mode auto or manual
Account Login (user name)
Account Password hided
Confirm Password again
        Configure a DLS (or ADSL) connection:
The user chooses between pptp, pppoe and dhcp. If dhcp, redirection to LAN.
If there is more than one ethernet card, The user must choose the card to use
(displayed with the module). After that, some informations are asked:
Provider name (ex provider.net)
Provider dns 1
Provider dns 2
Account Login (user name)
Account Password hided
Confirm Password again
        Configure a cable connection: redirection to LAN
        Configure local network: display what has been probed with a question
about using another module and Yes, No and See hardware info buttons.
No is the default. If Yes is clicked a list of modules is displayed with
Ok or Cancel buttons available. Cancel should go back to previous
question. If See hardware info is clicked a list of probed hardware is
displayed. If Yes is clicked, for each ethernet interface, a dialog asking for
IP address, Netmask and Automatic IP check box (DHCP/BOOTP) is displayed. Then
if DHCP has been chosen, only a dialog asking for Host name and another for HTTP
proxy and FTP proxy if any. If DHCP has not been chosen, an IP address has to be
defined and a dialog including Host name, DNS server, Gateway and "Gateway
device" is displayed. Then the same HTTP proxy and FTP proxy dialog as above. As
network configuration may to have been reworked a bit it has TO BE DEFINED if
this is kept like that or not.
        Disable networking|Enable networking is just a way to toggle
networking on or off, may be to be accessible only for advanced mode.
        Quit exit the network step.

NETWORK ADVANCED DOCUMENTATION:
Here is a list of entry points available in post install without using the ugly
install graphic toolkit:

http://www.mandrakesoft.com/~damien/html/draknet_advanced_doc.txt>http://www.mandrakesoft.com/~damien/html/draknet_advanced_doc.txt

      Configure Printer: step always displayed. In recommended mode, only
activated if a local printer is detected, else no printer are configured by
default. In customized mode or if the step has been clicked a list of printer
already configured is displayed and the possibility to add or exit the
configuration. It allow configuration of printers for both LPR and CUPS
individually (available by advanced mode when adding a printer). Printer
protocol managed are local/usb/samba/ncp/lpd for LPR and
local/usb/serial/samba/lpd/cups_network for CUPS.

      Set root password: step always displayed for Install only. In
recommended mode display only a Password entry and a Password (again) entry
to select the root password. In advanced mode, a Use NIS (yellow pages) check
boxes and Use MD5 check box are available. Ok validate root password and "No
password avoid setting a password. No password is only available in Low"
security level or less. The length of the minimal password depend upon security level.

In corporate firewall :
      Set admin password: step always displayed for Install only. It only
      displays a Password entry and a Password (again) entry
to select the admin password. 
The length of the minimal password depend upon security level. (double of the
      security level)

      Add a user: step always displayed for Install Only. In recommend mode
display Real name, User name, Password, Password (again) and icon
choices as graphical. For customized mode a shell combo is available to choose a
specific shell for the user depending on the package installed. The real name is
the user friendly name of the user whereas user name is its login id name. The
box display user that have already been added below the title. Accept user
button allow the creation of the user and Done finish this step. High or
higher security level implies the creation of at least one user. Password length
are subject to same restriction according to security level. In advanced mode,
allow to choose the user in auto login mode.

      Create a boot disk: step always displayed. In recommended mode this
step is automatically done by doing nothing. If clicked or customized mode, the
user is prompted to allow building a boot disk (default is yes). In advanced
mode allow selection of floppy drive.

      Install boot loader: step always displayed. In recommended mode this
step is automatically done. In customized mode, a combo Boot device list the
various boot device that can be used where the bootloader can be installed. The
boot device can the Linux description of the whole disk available (ex: /dev/hda)
or partition available in these disk or floppy drives. Other platform
specificity are not listed here.
      LBA check box is displayed in advanced mode (enabled by default) to
allow using LBA addressing if available (PC with LILO). bootloader combo to
select a given bootloader to use, available choice are Grub, "LILO with text
menu, LILO with graphical menu. default chosen is LILO
with graphical menu. Delay before booting default image" entry
field is available with default value current setting (upgrade) or 5 else.
Precise RAM size if needed (found xx MB) entry is displayed too,
clean /tmp check box is disabled by default too.
Boot in graphical mode (init 5) is available here in advanced mode too
(previously in X configuration). Video mode combo, Password, Password (again),
Restrict command line options check box is displayed.
Video mode combo list text mode and video mode used for frame buffer, video mode
used for frame buffer are available only if the install managed to boot with
frame buffer activated. Password are restricted according to security level as
other password. Password are mandatory according to security level TO BE DEFINED.

      Configure X: step always displayed. By default on recommended mode,
everything is done automatically if possible up to test of graphic card, and if
the user accept the settings no more question are asked to him. In customized
mode a dialog is displayed to choose resolution, color depth and which version
of XFree (with 3D optionally) is available for the current card where only a
short description is displayed. Ok button allow to jump to test phase (for the
first time only) if available. Cancel return to main XFree configuration
window allowing to change Monitor, Graphic card, Server options or Resolution
with X version to choose. Show all extend resolution list to more resolutions
according to card (with onboard memory) only and no more monitor capabilities.
      The main dialog is a list of command to change some X configuration aspect
according to advanced mode or not :
        Change Monitor: display a tree selection of monitors where default one
is selected. Ok and Cancel buttons are available.
        Change Graphic card: display a tree selection of graphic card where
default one is selected. Ok and Cancel buttons are available. If Unlisted
is chosen, then a tree of server/driver is displayed containing available server
for XF3 or driver for XF4. Cancel return to main window and Ok validates
change.
        Change Server options: available only in advanced mode. display list
of check boxes options for server currently used. Ok and Cancel available.
        Change Resolution: change resolution and depth including with X server
version chosen (relative to Xdrakres too).
        Show Information: display an information dialog showing current
configuration internals of X.
        Test again: restart test with current configuration of X.
        Quit: exit X configuration main window. Other question about autologin
and window manager to use are asked on Add user step.

      Exit install: step displayed only in customized mode but always
executed. Only a text is displayed with a Ok button. If clicked and some step
have not been executed/completed correctly, a question dialog ask the user if he
really want to quit now, default answer is No. Advanced switch let user access
to do the previously Auto install floppy step in DrakX < 8.0. This is just a
question asking the user to generate an auto install floppy automatically.
str">'ga' => 'uk:90', 'ga_IE'=> 'uk:90', 'gd' => 'uk:90', 'gl' => 'es:90', 'gv' => 'uk:90', 'he' => 'il:90 il_phonetic:10', 'hr' => 'hr:90 si:50', 'hu' => 'hu:90', 'hy' => 'am:80 am_old:10 am_phonetic:5', 'id' => 'us:90 us_intl:20', 'is' => 'is:90', 'iu' => 'iu:90', 'it_CH' => 'ch_fr:80 ch_de:60 it:50', 'it_IT' => 'it:90', 'ja' => 'jp:80 us:50 us_intl:20', 'ka' => 'ge_la:80 ge_ru:50', 'ka_GE'=> 'ge_la:80 ge_ru:50', 'kl' => 'dk:80 us_intl:30', 'ko' => 'kr:80 us:60', 'kw' => 'uk:90', 'lo' => 'us:60', 'lt' => 'lt:80 lt_new:70 lt_b:60 lt_p:50', 'lv' => 'lv:80 lt:40 lt_new:30 lt_b:20 lt_p:10 ee:5', 'mi' => 'us_intl:60 uk:20 us:10', 'mk' => 'mk:80', 'ms' => 'us:90 us_intl:20', 'nb' => 'no:90 dvorak_no:10', 'nl_BE'=> 'be:90 nl:10 us_intl:5', 'nl_NL'=> 'us_intl:95 nl:15 us:10 uk:5', 'nn' => 'no:90 dvorak_no:10', 'no' => 'no:90 dvorak_no:10', 'oc' => 'fr:90', 'oc_FR'=> 'fr:90', 'ph' => 'us:90 us_intl:20', 'pl' => 'pl:80 pl2:60', 'pp' => 'br:80 la:20 pt:10 us_intl:30', 'pt_BR'=> 'br:80 la:20 pt:10 us_intl:30', 'pt_PT'=> 'pt:80', 'ro' => 'ro2:80 ro:40 us-intl:10', 'ru' => 'ru:90 ru_yawerty:80', 'ru_RU'=> 'ru:90 ru_yawerty:80', 'sk' => 'sk_qwerty:80 sk:70 sk_prog:50', 'sl' => 'si:80 hr:50', 'sp' => 'sr:80', 'sq' => 'al:80', 'sr' => 'yu:80', 'sv' => 'se:90 fi:20', 'sv_FI'=> 'fi:90 sv:20', 'sv_SE'=> 'se:90 fi:20', 'tg' => 'tj:80 ru_yawerty:40', 'th' => 'th:90', 'tr' => 'tr_q:90 tr_q:30', 'tt' => 'ru:50 ru_yawerty:40', 'uk' => 'ua:90 ru:50 ru_yawerty:40', 'uk_UA'=> 'ua:90 ru:50 ru_yawerty:40', 'uz' => 'us:80', 'vi' => 'vn:80 us:60 us_intl:50', 'vi_VN'=> 'vn us:60 us_intl:50', 'wa' => 'be:90 fr:5', 'wa_BE'=> 'be:90 fr:5', 'zh_CN'=> 'us:60', 'zh_TW'=> 'us:60', ); #- key = extension for Xmodmap file, [0] = description of the keyboard, #- [1] = name for loadkeys, [2] = name for XKB my %keyboards = ( arch() =~ /^sparc/ ? ( "cz" => [ __("Czech (QWERTZ)"), "sunt5-cz-us", "cz" ], "de" => [ __("German"), "sunt5-de-latin1", "de" ], "dvorak" => [ __("Dvorak"), "sundvorak", "dvorak" ], "es" => [ __("Spanish"), "sunt5-es", "es" ], "fi" => [ __("Finnish"), "sunt5-fi-latin1", "fi" ], "fr" => [ __("French"), "sunt5-fr-latin1", "fr" ], "no" => [ __("Norwegian"), "sunt4-no-latin1", "no" ], "pl" => [ __("Polish"), "sun-pl-altgraph", "pl" ], "ru" => [ __("Russian"), "sunt5-ru", "ru" ], # TODO: check the console map "se" => [ __("Swedish"), "sunt5-fi-latin1", "se" ], "uk" => [ __("UK keyboard"), "sunt5-uk", "gb" ], "us" => [ __("US keyboard"), "sunkeymap", "us" ], ) : ( arch() eq "ppc" ? ( "de_nodeadkeys" => [ __("German"), "mac-de-latin1-nodeadkeys", "de(nodeadkeys)" ], "fr" => [ __("French"), "mac-fr2-ext", "fr" ], "us" => [ __("US keyboard"), "mac-us-ext", "us" ], ) : ( "al" => [ __("Albanian"), "al", "al" ], "am_old" => [ __("Armenian (old)"), "am_old", "am(old)" ], "am" => [ __("Armenian (typewriter)"), "am-armscii8", "am" ], "am_phonetic" => [ __("Armenian (phonetic)"), "am_phonetic", "am(phonetic)" ], #-"ar_azerty" => [ __("Arabic (AZERTY)"), "ar-8859_6", "ar(azerty)" ], #-"ar_azerty_d" => [ __("Arabic (AZERTY, arabic digits)"),"ar-8859_6","ar(azerty_digits)" ], #-"ar" => [ __("Arabic (QWERTY)"), "ar-8859_6", "ar" ], #-"ar_d" => [ __("Arabic (QWERTY, arabic digits)"),"ar-8859_6","ar(digits)" ], "az" => [ __("Azerbaidjani (latin)"), "az", "az" ], #"a3" => [ __("Azerbaidjani (cyrillic)"), "az-koi8k","az(cyrillic)" ], "be" => [ __("Belgian"), "be2-latin1", "be" ], "bg" => [ __("Bulgarian"), "bg", "bg" ], "br" => [ __("Brazilian (ABNT-2)"), "br-abnt2", "br" ], "by" => [ __("Belarusian"), "by-cp1251", "by" ], "ch_de" => [ __("Swiss (German layout)"), "sg-latin1", "de_CH" ], "ch_fr" => [ __("Swiss (French layout)"), "fr_CH-latin1", "fr_CH" ], #"cz" => [ __("Czech (QWERTZ)"), "cz-latin2", "czsk(cz_us_qwertz)" ], #"cz_qwerty" => [ __("Czech (QWERTY)"), "cz-lat2", "czsk(cz_us_qwerty)" ], #"cz_prog" => [ __("Czech (Programmers)"), "cz-lat2-prog", "czsk(us_cz_prog)" ], "cz" => [ __("Czech (QWERTZ)"), "cz-latin2", "cz" ], "cz_qwerty" => [ __("Czech (QWERTY)"), "cz-lat2", "cz_qwerty" ], "de" => [ __("German"), "de-latin1", "de" ], "de_nodeadkeys" => [ __("German (no dead keys)"), "de-latin1-nodeadkeys", "de(nodeadkeys)" ], "dk" => [ __("Danish"), "dk-latin1", "dk" ], "dvorak" => [ __("Dvorak (US)"), "pc-dvorak-latin1", "dvorak" ], "dvorak_no" => [ __("Dvorak (Norwegian)"), "no-dvorak", "dvorak(no)" ], "ee" => [ __("Estonian"), "ee-latin9", "ee" ], "es" => [ __("Spanish"), "es-latin1", "es" ], "fi" => [ __("Finnish"), "fi-latin1", "fi" ], "fr" => [ __("French"), "fr-latin1", "fr" ], "ge_ru"=>[__("Georgian (\"Russian\" layout)"),"ge_ru-georgian_academy","ge_ru"], "ge_la"=>[__("Georgian (\"Latin\" layout)"),"ge_la-georgian_academy","ge_la"], "gr" => [ __("Greek"), "gr-8859_7", "el" ], "hu" => [ __("Hungarian"), "hu-latin2", "hu" ], "hr" => [ __("Croatian"), "croat", "hr" ], "il" => [ __("Israeli"), "il-8859_8", "il" ], "il_phonetic" => [ __("Israeli (Phonetic)"),"hebrew", "il_phonetic" ], "ir" => [ __("Iranian"), "ir-isiri3342","ir" ], "is" => [ __("Icelandic"), "is-latin1", "is" ], "it" => [ __("Italian"), "it-latin1", "it" ], #"iu" => [ __("Inuktitut"), "iu", "iu" ], "jp" => [ __("Japanese 106 keys"), "jp106", "jp" ], "kr" => [ __("Korean keyboard"),"us", "kr" ], "la" => [ __("Latin American"), "la-latin1", "la" ], "lt" => [ __("Lithuanian AZERTY (old)"), "lt-latin7","lt_a" ], #- TODO: write a console kbd map for lt_new "lt_new" => [ __("Lithuanian AZERTY (new)"), "lt-latin7","lt_std" ], "lt_b" => [ __("Lithuanian \"number row\" QWERTY"), "ltb-latin7", "lt" ], "lt_p" => [ __("Lithuanian \"phonetic\" QWERTY"), "ltp-latin7", "lt_p" ], "lv" => [ __("Latvian"), "lv-latin7", "lv" ], "mk" => [ __("Macedonian"), "mk", "mk" ], "nl" => [ __("Dutch"), "nl-latin1", "nl" ], "no" => [ __("Norwegian"), "no-latin1", "no" ], "pl" => [ __("Polish (qwerty layout)"), "pl", "pl" ], "pl2" => [ __("Polish (qwertz layout)"), "pl-latin2", "pl2" ], "pt" => [ __("Portuguese"), "pt-latin1", "pt" ], "qc" => [ __("Canadian (Quebec)"), "qc-latin1","ca_enhanced" ], #- TODO: write a console kbd map for ro2 "ro2" => [ __("Romanian (qwertz)"), "ro2", "ro2" ], "ro" => [ __("Romanian (qwerty)"), "ro", "ro" ], "ru" => [ __("Russian"), "ru4", "ru(winkeys)" ], "ru_yawerty" => [ __("Russian (Yawerty)"),"ru-yawerty","ru_yawerty" ], "se" => [ __("Swedish"), "se-latin1", "se" ], "si" => [ __("Slovenian"), "slovene", "si" ], # "sk" => [ __("Slovakian (QWERTZ)"), "sk-qwertz", "czsk(sk_us_qwertz)" ], # "sk_qwerty" => [ __("Slovakian (QWERTY)"), "sk-qwerty", "czsk(sk_us_qwerty)" ], # "sk_prog" => [ __("Slovakian (Programmers)"), "sk-prog", "czsk(us_sk_prog" ], "sk" => [ __("Slovakian (QWERTZ)"), "sk-qwertz", "sk" ], "sk_qwerty" => [ __("Slovakian (QWERTY)"), "sk-qwerty", "sk_qwerty" ], # TODO: console map "sr" => [ __("Serbian (cyrillic)"), "yu", "sr" ], "th" => [ __("Thai keyboard"), "th", "th" ], # TODO: console map "tj" => [ __("Tajik keyboard"), "tj", "tj" ], "tr_f" => [ __("Turkish (traditional \"F\" model)"), "trf", "tr_f" ], "tr_q" => [ __("Turkish (modern \"Q\" model)"), "tr_q-latin5", "tr" ], "ua" => [ __("Ukrainian"), "ua", "ua" ], "uk" => [ __("UK keyboard"), "uk", "gb" ], "us" => [ __("US keyboard"), "us", "us" ], "us_intl" => [ __("US keyboard (international)"), "us-latin1", "us_intl" ], "vn" => [ __("Vietnamese \"numeric row\" QWERTY"),"vn-tcvn", "vn" ], "yu" => [ __("Yugoslavian (latin)"), "yu", "hr" ], )), ); #-###################################################################################### #- Functions #-###################################################################################### sub keyboards { keys %keyboards } sub keyboard2text { $keyboards{$_[0]} && $keyboards{$_[0]}[0] } sub keyboard2kmap { $keyboards{$_[0]} && $keyboards{$_[0]}[1] } sub keyboard2xkb { $keyboards{$_[0]} && $keyboards{$_[0]}[2] } sub loadkeys_files { my ($warn) = @_; my $archkbd = arch() =~ /^sparc/ ? "sun" : arch() =~ /i.86/ ? "i386" : arch() =~ /ppc/ ? "mac" : arch(); my $p = "/usr/lib/kbd/keymaps/$archkbd"; my $post = ".kmap.gz"; my %trans = ("cz-latin2" => "cz-lat2"); my %find_file; foreach my $dir (all($p)) { $find_file{$dir} = ''; foreach (all("$p/$dir")) { $find_file{$_} && $warn and warn "file $_ is both in $find_file{$_} and $dir\n"; $find_file{$_} = "$p/$dir/$_"; } } my (@l, %l); foreach (values %keyboards) { local $_ = $trans{$_->[1]} || $_->[1]; my $l = $find_file{"$_$post"} || $find_file{first(/(..)/) . $post}; print STDERR "unknown $_\n" if $warn && !$l; $l or next; push @l, $l; foreach (`zgrep include $l | grep "^include"`) { /include\s+"(.*)"/ or die "bad line $_"; @l{grep { -e $_ } ("$p/$1.inc.gz")} = (); } } @l, keys %l, grep { -e $_ } map { "$p/$_.inc.gz" } qw(compose euro windowkeys linux-keys-bare); } sub unpack_keyboards { my ($k) = @_ or return; [ grep { my $b = $keyboards{$_->[0]}; $b or log::l("bad keyboard $_->[0] in %keyboard::lang2keyboard"); $b; } map { [ split ':' ] } split ' ', $k ]; } sub lang2keyboards { my ($l) = @_; my $li = unpack_keyboards($lang2keyboard{substr($l, 0, 5)}) || [ $keyboards{$l} && $l || "us" ]; $li->[0][1] ||= 100; $li; } sub lang2keyboard { my ($l) = @_; my $kb = lang2keyboards($l)->[0][0]; $keyboards{$kb} ? $kb : "us"; #- handle incorrect keyboad mapping to us. } sub load { my ($keymap) = @_; return if $::testing; my ($magic, @keymaps) = unpack "I i" . c::MAX_NR_KEYMAPS() . "a*", $keymap; $keymap = pop @keymaps; $magic != $KMAP_MAGIC and die "failed to read kmap magic"; local *F; sysopen F, "/dev/console", 2 or die "failed to open /dev/console: $!"; my $count = 0; foreach (0 .. c::MAX_NR_KEYMAPS() - 1) { $keymaps[$_] or next; my @keymap = unpack "s" . c::NR_KEYS() . "a*", $keymap; $keymap = pop @keymap; my $key = -1; foreach my $value (@keymap) { $key++; c::KTYP($value) != c::KT_SPEC() or next; ioctl(F, c::KDSKBENT(), pack("CCS", $_, $key, $value)) or die "keymap ioctl failed ($_ $key $value): $!"; } $count++; } #- log::l("loaded $count keymap tables"); } sub xmodmap_file { my ($keyboard) = @_; my $f = "$ENV{SHARE_PATH}/xmodmap/xmodmap.$keyboard"; if (! -e $f) { eval { require packdrake; my $packer = new packdrake("$ENV{SHARE_PATH}/xmodmap.cz2", quiet => 1); $packer->extract_archive("/tmp", "xmodmap.$keyboard"); }; $f = "/tmp/xmodmap.$keyboard"; } -e $f && $f; } sub setup { return if arch() =~ /^sparc/; #- Xpmac doesn't map keys quite right if (arch() =~ /ppc/ && !$::testing && $ENV{DISPLAY}) { log::l("Fixing Mac keyboard"); run_program::run('xmodmap', "-e", "keycode 59 = BackSpace" ); run_program::run('xmodmap', "-e", "keycode 131 = Shift_R" ); run_program::run('xmodmap', "-e", "add shift = Shift_R" ); return; } my ($keyboard) = @_; my $o = $keyboards{$keyboard} or return; log::l("loading keymap $o->[1]"); if (-e (my $f = "$ENV{SHARE_PATH}/keymaps/$o->[1].bkmap")) { load(scalar cat_($f)); } else { local *F; if (my $pid = open F, "-|") { local $/ = undef; eval { load(join('', <F>)) }; waitpid $pid, 0; } else { eval { require packdrake; my $packer = new packdrake("$ENV{SHARE_PATH}/keymaps.cz2", quiet => 1); $packer->extract_archive(undef, "$o->[1].bkmap"); }; c::_exit(0); } } my $f = xmodmap_file($keyboard); eval { run_program::run('xmodmap', $f) } if $f && !$::testing && $ENV{DISPLAY}; } sub write { my ($prefix, $keyboard, $charset, $isNotDelete) = @_; my $config = read_raw($prefix); put_in_hash($config, { KEYTABLE => keyboard2kmap($keyboard), KBCHARSET => $charset, }); add2hash_($config, {