source: chapter06/flex.xml@ 96e8f71

6.0
Last change on this file since 96e8f71 was 3ed279f, checked in by Manuel Canales Esparcia <manuel@…>, 20 years ago

Tags changes in the contents sections to make a better print output.

git-svn-id: http://svn.linuxfromscratch.org/LFS/branches/testing/BOOK@4009 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 4.1 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
6<sect1 id="ch-system-flex" xreflabel="Flex" role="wrap">
7<title>Flex-&flex-version;</title>
8<?dbhtml filename="flex.html"?>
9
10<indexterm zone="ch-system-flex"><primary sortas="a-Flex">Flex</primary></indexterm>
11
12<sect2 role="package"><title/>
13<para>The Flex package contains a utility for generating programs that
14recognize patterns in text.</para>
15
16<segmentedlist>
17<segtitle>&buildtime;</segtitle>
18<segtitle>&diskspace;</segtitle>
19<seglistitem><seg>0.1 SBU</seg><seg>3.4 MB</seg></seglistitem>
20</segmentedlist>
21
22<segmentedlist>
23<segtitle>Flex installation depends on</segtitle>
24<seglistitem><seg>Bash, Binutils, Bison, Coreutils, Diffutils,
25GCC, Gettext, Glibc, Grep, M4, Make, Sed</seg></seglistitem>
26</segmentedlist>
27</sect2>
28
29<sect2 role="installation">
30<title>Installation of Flex</title>
31
32<para>Flex contains several known bugs. Fix these with the following patch:</para>
33
34<screen><userinput>patch -Np1 -i ../flex-&flex-version;-debian_fixes-2.patch</userinput></screen>
35
36<para>The GNU autotools detects that the Flex source code has been
37modified by the previous patch, and tries to update the manual page
38accordingly. This does not work correctly on many systems, and the
39default page is fine, so make sure it does not get regenerated:</para>
40
41<screen><userinput>touch doc/flex.1</userinput></screen>
42
43<para>Now prepare Flex for compilation:</para>
44
45<screen><userinput>./configure --prefix=/usr</userinput></screen>
46
47<para>Compile the package:</para>
48
49<screen><userinput>make</userinput></screen>
50
51<para>To test the results, issue:
52<userinput>make check</userinput>.</para>
53
54<para>Install the package:</para>
55
56<screen><userinput>make install</userinput></screen>
57
58<para>There are some packages that expect to find the
59<filename>lex</filename> library in <filename
60class="directory">/usr/lib</filename>. Create a symlink to account for
61this:</para>
62
63<screen><userinput>ln -s libfl.a /usr/lib/libl.a</userinput></screen>
64
65<para>A few programs do not know about <command>flex</command> yet and
66try to run its predecessor, <command>lex</command>. To support those
67programs, create a wrapper script named <filename>lex</filename> that
68calls <filename>flex</filename> in lex emulation mode:</para>
69
70<screen><userinput>cat &gt; /usr/bin/lex &lt;&lt; "EOF"</userinput>
71#!/bin/sh
72# Begin /usr/bin/lex
73
74exec /usr/bin/flex -l "$@"
75
76# End /usr/bin/lex
77<userinput>EOF
78chmod 755 /usr/bin/lex</userinput></screen>
79
80</sect2>
81
82
83<sect2 id="contents-flex" role="content"><title>Contents of Flex</title>
84
85<segmentedlist>
86<segtitle>Installed programs</segtitle>
87<segtitle>Installed library</segtitle>
88<seglistitem><seg>flex, flex++ (link to flex) and lex</seg>
89<seg>libfl.a</seg></seglistitem>
90</segmentedlist>
91
92<variablelist><bridgehead renderas="sect3">Short descriptions</bridgehead>
93<?dbfo list-presentation="list"?>
94
95<varlistentry id="flex">
96<term><command>flex</command></term>
97<listitem>
98<para>a tool for generating programs that recognize patterns in text.
99Pattern recognition is useful in many applications.
100<application>Flex</application> makes a program that looks for those
101patterns from a set of established rules.
102<application>Flex</application> allows for the versatility to specify
103the rules for a pattern-finding, eradicating the need to develop a
104specialized program.</para>
105<indexterm zone="ch-system-flex flex"><primary sortas="b-flex">flex</primary></indexterm>
106</listitem>
107</varlistentry>
108
109<varlistentry id="flex-">
110<term><command>flex++</command></term>
111<listitem>
112<para>invokes a version of <command>flex</command> that is used exclusively for C++ scanners.</para>
113<indexterm zone="ch-system-flex flex-"><primary sortas="b-flex++">flex++</primary></indexterm>
114</listitem>
115</varlistentry>
116
117<varlistentry id="libfl.a">
118<term><filename class="libraryfile">libfl.a</filename></term>
119<listitem>
120<para>the flex library.</para>
121<indexterm zone="ch-system-flex libfl.a"><primary sortas="c-libfl.a">libfl.a</primary></indexterm>
122</listitem>
123</varlistentry>
124</variablelist>
125
126</sect2>
127
128</sect1>
129
Note: See TracBrowser for help on using the repository browser.