231 lines
6.8 KiB
Text
231 lines
6.8 KiB
Text
<!-- $Id: russian.sgml,v 1.8 1998-02-23 17:07:22 ache Exp $ -->
|
|
<!-- The FreeBSD Documentation Project -->
|
|
|
|
<sect><heading>Russian Language (KOI8-R encoding)<label id="russian"></heading>
|
|
<p><em>Contributed by &a.ache;<newline>
|
|
1 May 1997</em>.
|
|
<p>See more info about KOI8-R encoding at
|
|
<htmlurl url="http://www.nagual.pp.ru/~ache/koi8.html"
|
|
name="KOI8-R References (Russian Net Character Set)">.
|
|
|
|
<sect1><heading>Console Setup<label id="russian:console"></heading>
|
|
<p>
|
|
<enum>
|
|
<item>Add following line to your kernel configuration file:
|
|
<verb>
|
|
options "SC_MOUSE_CHAR=0x03"
|
|
</verb>
|
|
to move character codes used for mouse cursor off KOI8-R
|
|
pseudographics range.
|
|
<item>Russian console entry in <tt>/etc/rc.conf</tt> should looks like
|
|
<verb>
|
|
keymap=ru.koi8-r
|
|
keychange="61 ^[[K"
|
|
scrnmap=koi8-r2cp866
|
|
font8x16=cp866b-8x16
|
|
font8x14=cp866-8x14
|
|
font8x8=cp866-8x8
|
|
</verb>
|
|
<p>
|
|
<it>NOTE:</it> ^[ means that real ESC character must be entered into
|
|
<tt>/etc/rc.conf</tt>,
|
|
not just ^[ string.
|
|
<p>
|
|
This tuning means KOI8-R keyboard with Alternative
|
|
screen font mapped to KOI8-R encoding to
|
|
preserve pseudographics, <it>Gray Delete</it> key remapped to match Russian
|
|
<tt>termcap(5)</tt> entry for FreeBSD console.
|
|
<p>
|
|
RUS/LAT switch will be <bf>CapsLock</bf>. Old CapsLock function still
|
|
available via <bf>Shift+CapsLock</bf>. CapsLock LED will
|
|
indicate RUS mode, not CapsLock mode.
|
|
|
|
<item>For each <tt>ttyv?</tt> entry in <tt>/etc/ttys</tt>
|
|
change terminal type from <tt>cons25</tt> to
|
|
<tt>cons25r</tt>, i.e. each entry should looks like
|
|
<verb>
|
|
ttyv0 "/usr/libexec/getty Pc" cons25r on secure
|
|
</verb>
|
|
</enum>
|
|
|
|
<sect1><heading>Locale Setup<label id="russian:locale"></heading>
|
|
<p><label id="russian:env">
|
|
There is two environment variables for locale setup:
|
|
<itemize>
|
|
<item><tt>LANG</tt>
|
|
for POSIX <tt>setlocale(3)</tt> family functions;
|
|
<item><tt>MM_CHARSET</tt>
|
|
for applications MIME chararter set.
|
|
</itemize>
|
|
<p>
|
|
The best way is using <tt>/etc/login.conf</tt>
|
|
<tt>russian</tt> user's login class
|
|
in <tt>passwd(5)</tt> entry login class position.
|
|
See <tt>login.conf(5)</tt> for details.
|
|
|
|
<sect2><heading>Login Class Method<label id="russian:class"></heading>
|
|
<p>
|
|
First of all check your <tt>/etc/login.conf</tt> have
|
|
<tt>russian</tt> login class, this entry may looks like:
|
|
<verb>
|
|
russian:Russian Users Accounts:\
|
|
:charset=KOI8-R:\
|
|
:lang=ru_RU.KOI8-R:\
|
|
:tc=default:
|
|
</verb>
|
|
|
|
<sect3><heading>How to do it with vipw(8)</heading>
|
|
<p>
|
|
If you use <tt>vipw(8)</tt> for adding new users,
|
|
<tt>/etc/master.passwd</tt>
|
|
entry should looks like:
|
|
<verb>
|
|
user:password:1111:11:russian:0:0:User Name:/home/user:/bin/csh
|
|
</verb>
|
|
|
|
<sect3><heading>How to do it with adduser(8)</heading>
|
|
<p>
|
|
If you use <tt>adduser(8)</tt> for adding new users:
|
|
<itemize>
|
|
<item>Set
|
|
<verb>
|
|
defaultclass = russian
|
|
</verb>
|
|
in <tt>/etc/adduser.conf</tt>
|
|
(you must enter <tt>default</tt> class for all non-Russian
|
|
users in this case);
|
|
<newline><newline>
|
|
|
|
<item>Alternative variant will be answering <tt>russian</tt>
|
|
each time when you see
|
|
<verb>
|
|
Enter login class: default []:
|
|
</verb>
|
|
prompt from <tt>adduser(8)</tt>;
|
|
<newline><newline>
|
|
|
|
<item>Another variant: call
|
|
<verb>
|
|
# adduser -class russian
|
|
</verb>
|
|
for each Russian user you want to add.
|
|
</itemize>
|
|
|
|
<sect3><heading>How to do it with pw(8)</heading>
|
|
<p>
|
|
If you use <tt>pw(8)</tt> for adding new users, call it in this form:
|
|
<verb>
|
|
# pw useradd user_name -L russian
|
|
</verb>
|
|
|
|
<sect2><heading>Shell Startup Files Method</heading>
|
|
<p>
|
|
If you don't want to use
|
|
<ref id="russian:class" name="login class method">
|
|
for some reasons, just set
|
|
this
|
|
<ref id="russian:env" name="two environment variables">
|
|
in the following shell startup files:
|
|
<itemize>
|
|
<item><tt>/etc/profile</tt>:
|
|
<verb>
|
|
LANG=ru_RU.KOI8-R; export LANG
|
|
MM_CHARSET=KOI8-R; export MM_CHARSET
|
|
</verb>
|
|
|
|
<item><tt>/etc/csh.login</tt>:
|
|
<verb>
|
|
setenv LANG ru_RU.KOI8-R
|
|
setenv MM_CHARSET KOI8-R
|
|
</verb>
|
|
</itemize>
|
|
<p>
|
|
Alternatively you can add this instructions to
|
|
<itemize>
|
|
<item><tt>/usr/share/skel/dot.profile</tt>:
|
|
<p>
|
|
(similar to <tt>/etc/profile</tt> above);
|
|
|
|
<item><tt>/usr/share/skel/dot.login</tt>:
|
|
<p>
|
|
(similar to <tt>/etc/csh.login</tt> above).
|
|
</itemize>
|
|
|
|
<sect1><heading>Printer Setup<label id="russian:printer"></heading>
|
|
<p>
|
|
Since most printers with Russian characters comes with hardware
|
|
code page CP866, special output filter needed for KOI8-R -> CP866
|
|
conversion. Such filter installed by default as
|
|
<tt>/usr/libexec/lpr/ru/koi2alt</tt>. So, Russian printer
|
|
<tt>/etc/printcap</tt> entry should looks like:
|
|
<verb>
|
|
lp|Russian local line printer:\
|
|
:sh:of=/usr/libexec/lpr/ru/koi2alt:\
|
|
:lp=/dev/lpt0:sd=/var/spool/output/lpd:lf=/var/log/lpd-errs:
|
|
</verb>
|
|
see <tt>printcap(5)</tt> for detailed description.
|
|
|
|
<sect1><heading>MSDOS FS and Russian file names<label id="russian:msdosfs"></heading>
|
|
<p>
|
|
Look at following example <tt>fstab(5)</tt> entry to enable support for
|
|
Russian file names in MSDOS FS:
|
|
<verb>
|
|
/dev/sd0s1 /dos/c msdos rw,-W=koi2dos,-L=ru_RU.KOI8-R 0 0
|
|
</verb>
|
|
see <tt>mount_msdos(8)</tt> for detailed description of
|
|
<tt>-W</tt> and <tt>-L</tt> options.
|
|
|
|
<sect1><heading>X Window Setup<label id="russian:xwindow"></heading>
|
|
<p>
|
|
Step by step instructions:
|
|
<enum>
|
|
<item>Do
|
|
<ref id="russian:locale" name="non-X locale setup"> first as described.
|
|
<p>
|
|
<it>NOTE:</it><label id="russian:note">
|
|
Russian KOI8-R locale may not work with old XFree86 releases
|
|
(lower than 3.3).
|
|
XFree86 port from <tt>/usr/ports/x11/XFree86</tt> already have
|
|
most recent XFree86 version,
|
|
so it will work, if you install XFree86
|
|
from this port.
|
|
XFree86 version shipped with the latest FreeBSD distribution should
|
|
work too (check XFree86 version number not less than 3.3 first).
|
|
|
|
<item>Go to <tt>/usr/ports/russian/X.language</tt> directory and say
|
|
<verb>
|
|
# make all install
|
|
</verb>
|
|
there. This port install latest version of KOI8-R fonts. XFree86 3.3
|
|
already have some KOI8-R fonts, but this ones scaled better.
|
|
<p>
|
|
Check find <tt>"Files"</tt> section in your <tt>/etc/XF86Config</tt>,
|
|
following lines must be before any other <tt>FontPath</tt> entries:
|
|
<verb>
|
|
FontPath "/usr/X11R6/lib/X11/fonts/cyrillic/misc"
|
|
FontPath "/usr/X11R6/lib/X11/fonts/cyrillic/75dpi"
|
|
FontPath "/usr/X11R6/lib/X11/fonts/cyrillic/100dpi"
|
|
</verb>
|
|
<p>
|
|
If you use high resolution video mode, swap 75 dpi and
|
|
100 dpi lines.
|
|
|
|
<item>To activate Russian keyboard add
|
|
<verb>
|
|
XkbKeymap "xfree86(ru)"
|
|
</verb>
|
|
line into <tt>"Keyboard"</tt> section in your <tt>/etc/XF86Config</tt>,
|
|
also make sure that <tt>XkbDisable</tt> is turned off (commented out)
|
|
there.
|
|
<p>
|
|
RUS/LAT switch will be <bf>CapsLock</bf>. Old CapsLock function still
|
|
available via <bf>Shift+CapsLock</bf> (in LAT mode only).
|
|
<p>
|
|
<it>NOTE:</it>
|
|
Russian XKB keyboard may not work with old XFree86 versions,
|
|
see <ref id="russian:note" name="locale note"> for more info.
|
|
Russian XKB keyboard may not work with non-localized applications
|
|
too, minimally localized application should call
|
|
<bf>XtSetLanguageProc</bf> (NULL, NULL, NULL);
|
|
function early in the program.
|
|
</enum>
|