source: chapter08/expect.xml@ bdcc868

xry111/arm64
Last change on this file since bdcc868 was bdcc868, checked in by Xi Ruoyao <xry111@…>, 3 months ago

Merge remote-tracking branch 'origin/trunk' into xry111/arm64

  • Property mode set to 100644
File size: 5.9 KB
Line 
1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../general.ent">
5 %general-entities;
6]>
7
8<sect1 id="ch-system-expect" role="wrap">
9 <?dbhtml filename="expect.html"?>
10
11 <sect1info condition="script">
12 <productname>expect</productname>
13 <productnumber>&expect-version;</productnumber>
14 <address>&expect-url;</address>
15 </sect1info>
16
17 <title>Expect-&expect-version;</title>
18
19 <indexterm zone="ch-system-expect">
20 <primary sortas="a-Expect">Expect</primary>
21 </indexterm>
22
23 <sect2 role="package">
24 <title/>
25
26 <para>The <application>Expect</application> package contains tools for
27 automating, via scripted dialogues, interactive applications such as
28 <command>telnet</command>, <command>ftp</command>,
29 <command>passwd</command>, <command>fsck</command>,
30 <command>rlogin</command>, and <command>tip</command>.
31 <application>Expect</application> is also useful for testing these same
32 applications as well as easing all sorts of tasks that are prohibitively
33 difficult with anything else. The <application>DejaGnu</application>
34 framework is written in <application>Expect</application>.</para>
35
36 <segmentedlist>
37 <segtitle>&buildtime;</segtitle>
38 <segtitle>&diskspace;</segtitle>
39
40 <seglistitem>
41 <seg>&expect-tmp-sbu;</seg>
42 <seg>&expect-tmp-du;</seg>
43 </seglistitem>
44 </segmentedlist>
45
46 </sect2>
47
48 <sect2 role="installation">
49 <title>Installation of Expect</title>
50
51 <para>Expect needs PTYs to work. Verify that the PTYs are working
52 properly inside the chroot environment by performing a simple
53 test:</para>
54
55<screen><userinput remap="test">python3 -c 'from pty import spawn; spawn(["echo", "ok"])'</userinput></screen>
56
57 <para>This command should output <computeroutput>ok</computeroutput>.
58 If, instead, the output includes <computeroutput>OSError: out of pty
59 devices</computeroutput>, then the environment is not set up for proper
60 PTY operation. You need to exit from the chroot environment, read
61 <xref linkend='ch-tools-kernfs'/> again, and ensure the
62 <systemitem class="filesystem">devpts</systemitem> file system (and
63 other virtual kernel file systems) mounted correctly. Then reenter
64 the chroot environment following <xref linkend='ch-tools-chroot'/>.
65 This issue needs to be resolved before continuing, or the test suites
66 requiring Expect (for example the test suites of Bash, Binutils, GCC,
67 GDBM, and of course Expect itself) will fail catastrophically, and other
68 subtle breakages may also happen.</para>
69
70 <para>Update two config scripts to allow building this package for
71 AArch64:</para>
72
73<screen><userinput remap="pre">tar -C tclconfig -xf ../autoconf-&autoconf-version;.tar.xz --strip-components=2 \
74 autoconf-&autoconf-version;/build-aux/config.{guess,sub}</userinput></screen>
75
76 <para>Now, make some changes to allow the package with gcc-14.1 or later:</para>
77
78<screen><userinput remap="pre">patch -Np1 -i ../expect-&expect-version;-gcc14-1.patch</userinput></screen>
79
80 <para>Prepare Expect for compilation:</para>
81
82<screen><userinput remap="configure">./configure --prefix=/usr \
83 --with-tcl=/usr/lib \
84 --enable-shared \
85 --disable-rpath \
86 --mandir=/usr/share/man \
87 --with-tclinclude=/usr/include</userinput></screen>
88
89 <variablelist>
90 <title>The meaning of the configure options:</title>
91
92 <varlistentry>
93 <term><parameter>--with-tcl=/usr/lib</parameter></term>
94 <listitem>
95 <para>This parameter is needed to tell
96 <command>configure</command> where the
97 <command>tclConfig.sh</command> script is located.</para>
98 </listitem>
99 </varlistentry>
100
101 <varlistentry>
102 <term><parameter>--with-tclinclude=/usr/include</parameter></term>
103 <listitem>
104 <para>This explicitly tells Expect where to find Tcl's internal
105 headers.</para>
106 </listitem>
107 </varlistentry>
108
109 </variablelist>
110
111 <para>Build the package:</para>
112
113<screen><userinput remap="make">make</userinput></screen>
114
115 <para>To test the results, issue:</para>
116
117<screen><userinput remap="test">make test</userinput></screen>
118
119 <para>Install the package:</para>
120
121<screen><userinput remap="install">make install
122ln -svf expect&expect-version;/libexpect&expect-version;.so /usr/lib</userinput></screen>
123
124 </sect2>
125
126 <sect2 id="contents-expect" role="content">
127 <title>Contents of Expect</title>
128
129 <segmentedlist>
130 <segtitle>Installed program</segtitle>
131 <segtitle>Installed library</segtitle>
132
133 <seglistitem>
134 <seg>expect</seg>
135 <seg>libexpect&expect-version;.so</seg>
136 </seglistitem>
137 </segmentedlist>
138
139 <variablelist>
140 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
141 <?dbfo list-presentation="list"?>
142 <?dbhtml list-presentation="table"?>
143
144 <varlistentry id="expect">
145 <term><command>expect</command></term>
146 <listitem>
147 <para>Communicates with other interactive programs according
148 to a script</para>
149 <indexterm zone="ch-system-expect expect">
150 <primary sortas="b-expect">expect</primary>
151 </indexterm>
152 </listitem>
153 </varlistentry>
154
155 <varlistentry id="libexpect">
156 <term><filename class="libraryfile">libexpect-&expect-version;.so</filename></term>
157 <listitem>
158 <para>Contains functions that allow Expect to be used as a Tcl
159 extension or to be used directly from C or C++ (without Tcl)</para>
160 <indexterm zone="ch-system-expect libexpect">
161 <primary sortas="c-libexpect-&expect-version;">libexpect-&expect-version;</primary>
162 </indexterm>
163 </listitem>
164 </varlistentry>
165
166 </variablelist>
167
168 </sect2>
169
170</sect1>
Note: See TracBrowser for help on using the repository browser.