blob: 842f359297d3267092d741be4e8d2511fe1c5900 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN" "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
<!ENTITY % general-entities SYSTEM "../general.ent">
%general-entities;
]>
<sect1 id="ch-scripts-inputrc">
<title>Creating the /etc/inputrc File</title>
<?dbhtml filename="inputrc.html"?>
<indexterm zone="ch-scripts-inputrc"><primary sortas="e-/etc/inputrc">/etc/inputrc</primary></indexterm>
<para>The <filename>/etc/inputrc</filename> file deals with mapping
the keyboard for specific situations. This file is the start-up file
used by <application>Readline</application>, the input-related
library used by <application>Bash</application> and most other
shells.</para>
<para>For more information, see the <command>bash</command> info page, section
<emphasis>Readline Init File</emphasis>. The
<filename class="libraryfile">readline</filename> info page is
also a good source of information.</para>
<para>Global values are set in <filename>/etc/inputrc</filename>.
Personal user values are set in <filename>~/.inputrc</filename>. The
<filename>~/.inputrc</filename> file will override the global settings
file. A later page sets up Bash to use
<filename>/etc/inputrc</filename> if there is no
<filename>.inputrc</filename> for a user when
<filename>/etc/profile</filename> is read (usually at login). To make
the system use both, or to negate global keyboard handling, it is a
good idea to place a default <filename>.inputrc</filename> into the
<filename class="directory">/etc/skel</filename> directory for use
with new users.</para>
<para>Below is a base <filename>/etc/inputrc</filename>, along with
comments to explain what the various options do. Note that comments
cannot be on the same line as commands.</para>
<para>To create the <filename>.inputrc</filename> in <filename
class="directory">/etc/skel</filename> using the command below, change
the command's output to <filename
class="directory">/etc/skel/.inputrc</filename> and be sure to
check/set permissions afterward. Copy that file to
<filename>/etc/inputrc</filename> and the home directory of any user
already existing on the system, including <emphasis>root</emphasis>,
that needs a private version of the file. Be certain to use the
<parameter>-p</parameter> parameter of <command>cp</command> to
maintain permissions and be sure to change owner and group
appropriately.</para>
<screen><userinput>cat > /etc/inputrc << "EOF"
<literal># Begin /etc/inputrc
# Modified by Chris Lynn <roryo@roryo.dynup.net>
# Make sure we don't output everything on the 1 line
set horizontal-scroll-mode Off
# Enable 8bit input
set meta-flag On
set input-meta On
# Turns off 8th bit stripping
set convert-meta Off
# Keep the 8th bit for display
set output-meta On
# none, visible or audible
set bell-style none
# All of the following map the escape sequence of the
# value contained inside the 1st argument to the
# readline specific functions
"\eOd": backward-word
"\eOc": forward-word
# for linux console
"\e[1~": beginning-of-line
"\e[4~": end-of-line
"\e[5~": beginning-of-history
"\e[6~": end-of-history
"\e[3~": delete-char
"\e[2~": quoted-insert
# for xterm
"\eOH": beginning-of-line
"\eOF": end-of-line
# for Konsole
"\e[H": beginning-of-line
"\e[F": end-of-line
# End /etc/inputrc</literal>
EOF</userinput></screen>
</sect1>
|