source: general/prog/python2.xml@ 533ebfd

krejzi/svn
Last change on this file since 533ebfd was d5169f16, checked in by Krejzi <krejzi@…>, 10 years ago

Improvements, updates, additions to Programming section.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/branches/systemd-ng@14748 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 11.6 KB
RevLine 
[bf847d6d]1<?xml version="1.0" encoding="ISO-8859-1"?>
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
[181662f]7 <!ENTITY python2-download-http
[82fac2c]8 "http://www.python.org/ftp/python/&python2-version;/Python-&python2-version;.tar.xz">
[27d9434]9 <!ENTITY python2-download-ftp " ">
[d80de44]10 <!ENTITY python2-md5sum "d235bdfa75b8396942e360a70487ee00">
[167a240]11 <!ENTITY python2-size "11 MB">
[d80de44]12 <!ENTITY python2-buildsize "222 MB (additional 18 MB for the tests)">
13 <!ENTITY python2-time "1.0 SBU (additional 4.8 SBU for tests)">
[82fac2c]14
[181662f]15 <!ENTITY python2htmldoc-download-http
[82fac2c]16 "http://docs.python.org/ftp/python/doc/&python2-version;/python-&python2-version;-docs-html.tar.bz2">
[d80de44]17 <!ENTITY python2htmldoc-md5sum "2cf9ba96b2723a5268cd14432b15fdcf">
18 <!ENTITY python2htmldoc-size "4.4 MB">
[bf847d6d]19]>
20
[4716d52]21<sect1 id="python2" xreflabel="Python-&python2-version;">
[bf847d6d]22 <?dbhtml filename="python2.html" ?>
23
24 <sect1info>
[4949485e]25 <othername>$LastChangedBy$</othername>
26 <date>$Date$</date>
[bf847d6d]27 </sect1info>
28
29 <title>Python-&python2-version;</title>
30
[4716d52]31 <indexterm zone="python2">
[82fac2c]32 <primary sortas="a-Python2">Python2</primary>
[bf847d6d]33 </indexterm>
34
35 <sect2 role="package">
36 <title>Introduction to Python 2</title>
37
[181662f]38 <para>
39 The <application>Python 2</application> package contains the
[82fac2c]40 <application>Python</application> development environment. It is useful
[181662f]41 for object-oriented programming, writing scripts, prototyping large
42 programs or developing entire applications. This version is for backward
43 compatibility with other dependent packages.
44 </para>
[bf847d6d]45
[a3be7192]46 &lfs76_checked;
[bf847d6d]47
48 <bridgehead renderas="sect3">Package Information</bridgehead>
49 <itemizedlist spacing="compact">
50 <listitem>
[181662f]51 <para>
52 Download (HTTP): <ulink url="&python2-download-http;"/>
53 </para>
[bf847d6d]54 </listitem>
55 <listitem>
[181662f]56 <para>
57 Download (FTP): <ulink url="&python2-download-ftp;"/>
58 </para>
[bf847d6d]59 </listitem>
60 <listitem>
[181662f]61 <para>
62 Download MD5 sum: &python2-md5sum;
63 </para>
[bf847d6d]64 </listitem>
65 <listitem>
[181662f]66 <para>
67 Download size: &python2-size;
68 </para>
[bf847d6d]69 </listitem>
70 <listitem>
[181662f]71 <para>
72 Estimated disk space required: &python2-buildsize;
73 </para>
[bf847d6d]74 </listitem>
75 <listitem>
[181662f]76 <para>
77 Estimated build time: &python2-time;
78 </para>
[bf847d6d]79 </listitem>
80 </itemizedlist>
81
82 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
83
[4716d52]84 <itemizedlist spacing="compact">
[bf847d6d]85 <listitem>
[181662f]86 <para>
[167a240]87 Required patch if you wish to run the test suite:
88 <ulink url="&patch-root;/Python-&python2-version;-skip_test_gdb-1.patch"/>
[181662f]89 </para>
[bf847d6d]90 </listitem>
[5d11f8f]91 </itemizedlist>
92
93 <itemizedlist spacing="compact">
94 <title>Optional HTML Documentation</title>
[bf847d6d]95 <listitem>
[181662f]96 <para>
[5d11f8f]97 Download (HTTP): <ulink url="&python2htmldoc-download-http;"/>
[181662f]98 </para>
[bf847d6d]99 </listitem>
100 <listitem>
[181662f]101 <para>
[5d11f8f]102 Download MD5 sum: &python2htmldoc-md5sum;
[181662f]103 </para>
[bf847d6d]104 </listitem>
[fb990982]105 <listitem>
106 <para>
[5d11f8f]107 Download size: &python2htmldoc-size;
[fb990982]108 </para>
109 </listitem>
110 </itemizedlist>
111
[03d30cf]112 <bridgehead renderas="sect3">Python 2 Dependencies</bridgehead>
[bf847d6d]113
[82fac2c]114 <bridgehead renderas="sect4">Recommended</bridgehead>
115 <para role="recommended">
[adf6dd9a]116 <xref linkend="libffi"/>
[82fac2c]117 </para>
118
[bf847d6d]119 <bridgehead renderas="sect4">Optional</bridgehead>
[181662f]120 <para role="optional">
[03d30cf]121 <xref linkend="bluez"/>
[82fac2c]122 </para>
123
124 <bridgehead renderas="sect4">Optional (For Additional Modules)</bridgehead>
125 <para role="optional">
126 <xref linkend="db"/>,
[181662f]127 <xref linkend="openssl"/>,
[82fac2c]128 <xref linkend="sqlite"/> and
129 <xref linkend="tk"/>
[181662f]130 </para>
131
[5be3a74]132 <note>
133 <para>
134 <!-- new for ff31. Any reasonable version of openssl will do,
135 even old maintained versions, so do not xref openssl here -->
[b9f61df]136 If you are building <xref linkend="thunderbird"/> or
[d5169f16]137 <xref linkend="firefox"/><!-- or <xref linkend="xulrunner"/> -->,
138 you must install <application>OpenSSL</application> before you build
[5be3a74]139 <application>Python 2</application>.
140 </para>
141 </note>
142
[181662f]143 <para condition="html" role="usernotes">
144 User Notes: <ulink url="&blfs-wiki;/Python"/>
145 </para>
[bf847d6d]146 </sect2>
147
148 <sect2 role="installation">
[03d30cf]149 <title>Installation of Python 2</title>
[bf847d6d]150
[181662f]151 <para>
[03d30cf]152 Install <application>Python 2</application> by running the following
[181662f]153 commands:
154 </para>
[bf847d6d]155
[167a240]156<screen><userinput>./configure --prefix=/usr \
[82fac2c]157 --enable-shared \
158 --with-system-expat \
159 --with-system-ffi \
160 --enable-unicode=ucs4 &amp;&amp;
[bf847d6d]161make</userinput></screen>
162
[167a240]163 <para>
164 If you wish to run the test suite, disable a test that fails:
165 </para>
166
167<screen><userinput>patch -Np1 -i ../Python-&python2-version;-skip_test_gdb-1.patch</userinput></screen>
168
[181662f]169 <para>
170 To test the results, issue: <command>make test</command>.
171 </para>
[bf847d6d]172
[181662f]173 <para>
174 Now, as the <systemitem class="username">root</systemitem> user:
175 </para>
[bf847d6d]176
[7224506]177<screen role="root"><userinput>make install &amp;&amp;
178chmod -v 755 /usr/lib/libpython&python2-majorver;.so.1.0</userinput></screen>
[bf847d6d]179
[181662f]180 <para>
[7fe0ce3b]181 Since <application>Python 2</application> is in maintenance mode, and
182 <application>Python 3</application> is recommended by upstream for
[d5169f16]183 development, you probably don't need to install the documentation.
[7fe0ce3b]184 However, if you still want to install documentation for both
[d5169f16]185 <application>Python</application> versions, make sure you set PYTHONDOCS
186 variable to the version you want to use each time you need to consult
[7fe0ce3b]187 the documentation. If you have downloaded the preformatted documentation
188 from <ulink url="http://docs.python.org/download.html"/>, install it
[03d30cf]189 as the <systemitem class="username">root</systemitem> user:
[181662f]190 </para>
191
[23d3543c]192<screen role="root"><userinput>install -v -dm755 /usr/share/doc/python-&python2-version; &amp;&amp;
[03d30cf]193tar --strip-components=1 -C /usr/share/doc/python-&python2-version; \
[ff3093a7]194 --no-same-owner -xvf ../python-&python2-version;-docs-html.tar.bz2 &amp;&amp;
[03d30cf]195find /usr/share/doc/python-&python2-version; -type d -exec chmod 0755 {} \; &amp;&amp;
196find /usr/share/doc/python-&python2-version; -type f -exec chmod 0644 {} \;</userinput></screen>
[bf847d6d]197 </sect2>
198
199 <sect2 role="commands">
200 <title>Command Explanations</title>
201
[82fac2c]202 <para>
203 <option>--with-system-expat</option>: This switch enables linking against
[56605b9]204 system version of <application>Expat</application>.
[82fac2c]205 </para>
206
207 <para>
208 <option>--with-system-ffi</option>: This switch enables linking against
209 system version of <application>libffi</application>. Remove if you have
[03d30cf]210 not installed <xref linkend="libffi"/>.
[82fac2c]211 </para>
212
213 <para>
214 <parameter>--enable-unicode=ucs4</parameter>: This switch enables
215 32bit Unicode support in <application>Python</application>.
216 </para>
217
218 <para>
219 <parameter>--with-dbmliborder=bdb:gdbm:ndbm</parameter>: Use this switch
[0d7900a]220 if you want to build <application>Python</application> DBM Module
[82fac2c]221 against <application>Berkeley DB</application> instead of
222 <application>GDBM</application>.
223 </para>
224
[181662f]225 <para>
[0d7900a]226 <command>chmod ...</command>: Fix permissions for libraries to be
[181662f]227 consistent with other libraries.
228 </para>
[82fac2c]229
[bf847d6d]230 </sect2>
231
232 <sect2 role="configuration">
233 <title>Configuring Python 2</title>
234
[181662f]235 <para>
236 In order for <command>python</command> to find the installed
237 documentation, you must add the following environment variable to
238 individual user's or the system's profile:
239 </para>
[bf847d6d]240
[03d30cf]241<screen role="root"><userinput>export PYTHONDOCS=/usr/share/doc/python-&python2-version;</userinput></screen>
[82fac2c]242
[bf847d6d]243 </sect2>
244
245 <sect2 role="content">
246 <title>Contents</title>
247
248 <segmentedlist>
249 <segtitle>Installed Programs</segtitle>
[03d30cf]250 <segtitle>Installed Library</segtitle>
[bf847d6d]251 <segtitle>Installed Directories</segtitle>
252
253 <seglistitem>
[181662f]254 <seg>
[167a240]255 2to3, pydoc, python (symlink), python-config (symlink),
256 python2 (symlink), python2-config (symlink),
[03d30cf]257 python&python2-majorver;, python&python2-majorver;-config,
[d0aecd33]258 smtpd.py, and idle
[181662f]259 </seg>
260 <seg>
[03d30cf]261 libpython&python2-majorver;.so
[167a240]262 and several under /usr/lib/python2.7/{config,lib-dynload}
[181662f]263 </seg>
264 <seg>
265 /usr/include/python&python2-majorver;,
266 /usr/lib/python&python2-majorver;, and
267 /usr/share/doc/python-&python2-version;</seg>
[bf847d6d]268 </seglistitem>
269 </segmentedlist>
270
271 <variablelist>
272 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
273 <?dbfo list-presentation="list"?>
274 <?dbhtml list-presentation="table"?>
275
[62f9a8e]276 <varlistentry id="python2-2to3">
277 <term><command>2to3</command></term>
278 <listitem>
279 <para>
280 is a <application>Python</application> program that reads
281 <application>Python 2.x</application> source code and applies a series of
282 fixers to transform it into valid <application>Python 3.x</application>
283 code.
284 </para>
285 <indexterm zone="python2 python2-2to3">
286 <primary sortas="b-2to3">2to3</primary>
287 </indexterm>
288 </listitem>
289 </varlistentry>
290
[03d30cf]291 <varlistentry id="idle">
[bf847d6d]292 <term><command>idle</command></term>
293 <listitem>
[181662f]294 <para>
295 is a wrapper script that opens a <application>Python</application>
[d0aecd33]296 aware GUI editor. For this script to run, you must have installed
297 <application>Tk</application> before Python so that the Tkinter
298 Python module is built.
[181662f]299 </para>
[03d30cf]300 <indexterm zone="python2 idle">
301 <primary sortas="b-idle">idle</primary>
[bf847d6d]302 </indexterm>
303 </listitem>
304 </varlistentry>
305
306 <varlistentry id="pydoc2">
307 <term><command>pydoc</command></term>
308 <listitem>
[181662f]309 <para>
310 is the <application>Python</application> documentation tool.
311 </para>
[4716d52]312 <indexterm zone="python2 pydoc2">
[bf847d6d]313 <primary sortas="b-pydoc2">pydoc</primary>
314 </indexterm>
315 </listitem>
316 </varlistentry>
317
[181662f]318 <varlistentry id="python">
[bf847d6d]319 <term><command>python</command></term>
320 <listitem>
[181662f]321 <para>
322 is an interpreted, interactive, object-oriented programming
323 language.
324 </para>
325 <indexterm zone="python2 python">
[4716d52]326 <primary sortas="b-python2">python</primary>
[bf847d6d]327 </indexterm>
328 </listitem>
329 </varlistentry>
330
331 <varlistentry id="python2-ver">
332 <term><command>python&python2-majorver;</command></term>
333 <listitem>
[181662f]334 <para>
335 is a version-specific name for the <command>python</command>
336 program.
337 </para>
[4716d52]338 <indexterm zone="python2 python2-ver">
[b88be39]339 <primary sortas="b-python&python2-majorver;">python&python2-majorver;</primary>
[bf847d6d]340 </indexterm>
341 </listitem>
342 </varlistentry>
343
[03d30cf]344 <varlistentry id="smtpd.py">
[bf847d6d]345 <term><command>smtpd.py</command></term>
346 <listitem>
[181662f]347 <para>
348 is an SMTP proxy implemented in <application>Python</application>.
349 </para>
[03d30cf]350 <indexterm zone="python2 smtpd.py">
351 <primary sortas="b-smtpd.py">smtpd.py</primary>
[bf847d6d]352 </indexterm>
353 </listitem>
354 </varlistentry>
[82fac2c]355
[bf847d6d]356 </variablelist>
[82fac2c]357
[bf847d6d]358 </sect2>
[82fac2c]359
[bf847d6d]360</sect1>
Note: See TracBrowser for help on using the repository browser.