1
0

perl.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518
  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. <sect1 id="ch-system-perl" role="wrap">
  8. <?dbhtml filename="perl.html"?>
  9. <sect1info condition="script">
  10. <productname>perl</productname>
  11. <productnumber>&perl-version;</productnumber>
  12. <address>&perl-url;</address>
  13. </sect1info>
  14. <title>Perl-&perl-version;</title>
  15. <indexterm zone="ch-system-perl">
  16. <primary sortas="a-Perl">Perl</primary>
  17. </indexterm>
  18. <sect2 role="package">
  19. <title/>
  20. <para>Perl 软件包包含实用报表提取语言。</para>
  21. <segmentedlist>
  22. <segtitle>&buildtime;</segtitle>
  23. <segtitle>&diskspace;</segtitle>
  24. <seglistitem>
  25. <seg>&perl-ch6-sbu;</seg>
  26. <seg>&perl-ch6-du;</seg>
  27. </seglistitem>
  28. </segmentedlist>
  29. </sect2>
  30. <sect2 role="installation">
  31. <title>安装 Perl</title>
  32. <para>首先创建一个基本的 <filename>/etc/hosts</filename> 文件,
  33. Perl 的一个配置文件和可选的测试套件都会引用它:</para>
  34. <screen><userinput remap="pre">echo "127.0.0.1 localhost $(hostname)" &gt; /etc/hosts</userinput></screen>
  35. <!--para>This version of Perl now builds the Compress::Raw::Zlib and
  36. Compress::Raw::BZip2 modules. By
  37. default Perl will use an internal copy of the sources for the build.
  38. Issue the following command so that Perl will use the libraries
  39. installed on the system:</para-->
  40. <para>该版本的 Perl 会构建 Compress::Raw::ZLib 和 Compress::Raw::BZip2
  41. 模块。默认情况下 Perl 会使用内部的 zlib 和 bzip2 源码副本构建它们,
  42. 执行以下命令,使得 Perl 使用系统中已经安装好的库:</para>
  43. <screen><userinput remap="pre">export BUILD_ZLIB=False
  44. export BUILD_BZIP2=0</userinput></screen>
  45. <!--
  46. <para>Apply a patch to allow the Errno.pm module and the h2ph
  47. program to build correctly when building with GCC 5:</para>
  48. <screen><userinput remap="pre">patch -Np1 -i ../&perl-gcc5-fixes-patch;</userinput></screen>
  49. -->
  50. <!--para>To have full control over the way Perl is set up, you can remove the
  51. <quote>-des</quote> options from the following command and hand-pick the way
  52. this package is built. Alternatively, use the command exactly as below to
  53. use the defaults that Perl auto-detects:</para-->
  54. <para>为了能够完全控制 Perl 的设置,您可以在以下命令中移除
  55. <quote>-des</quote> 选项,并手动选择构建该软件包的方式。
  56. 或者,直接使用下面的命令,以使用 Perl 自动检测的默认值:</para>
  57. <screen><userinput remap="configure">sh Configure -des -Dprefix=/usr \
  58. -Dvendorprefix=/usr \
  59. -Dman1dir=/usr/share/man/man1 \
  60. -Dman3dir=/usr/share/man/man3 \
  61. -Dpager="/usr/bin/less -isR" \
  62. -Duseshrplib \
  63. -Dusethreads</userinput></screen>
  64. <variablelist>
  65. <title>配置选项的含义</title>
  66. <varlistentry>
  67. <term><parameter>-Dvendorprefix=/usr</parameter></term>
  68. <listitem>
  69. <para>这保证 <command>perl</command>
  70. 知道如何告知软件包应该在哪里安装它们的 perl 模块。</para>
  71. </listitem>
  72. </varlistentry>
  73. <varlistentry>
  74. <term><parameter>-Dpager="/usr/bin/less -isR"</parameter></term>
  75. <listitem>
  76. <para>这保证该软件包使用<userinput>less</userinput>
  77. 对输出进行分页,而不是使用 <userinput>more</userinput>。
  78. </para>
  79. </listitem>
  80. </varlistentry>
  81. <varlistentry>
  82. <term><parameter>-Dman1dir=/usr/share/man/man1
  83. -Dman3dir=/usr/share/man/man3</parameter></term>
  84. <listitem>
  85. <para>由于 Groff 还没有安装,<command>Configure</command>
  86. 认为我们不需要 Perl 的 man 页面。这些参数覆盖这个判断。</para>
  87. </listitem>
  88. </varlistentry>
  89. <varlistentry>
  90. <term><parameter>-Duseshrplib</parameter></term>
  91. <listitem>
  92. <para>构建 libperl 共享库,一些 perl 模块需要它。</para>
  93. </listitem>
  94. </varlistentry>
  95. <varlistentry>
  96. <term><parameter>-Dusethreads</parameter></term>
  97. <listitem>
  98. <para>构建带有线程支持的 perl。</para>
  99. </listitem>
  100. </varlistentry>
  101. </variablelist>
  102. <para>编译该软件包:</para>
  103. <screen><userinput remap="make">make</userinput></screen>
  104. <para>为了测试编译结果 (需要约 11 SBU),执行以下命令:</para>
  105. <screen><userinput remap="test">make -k test</userinput></screen>
  106. <note><para>由于使用了最新的 gdbm 版本,一项测试会失败。</para></note>
  107. <para>安装该软件包,并清理环境变量:</para>
  108. <screen><userinput remap="install">make install
  109. unset BUILD_ZLIB BUILD_BZIP2</userinput></screen>
  110. </sect2>
  111. <sect2 id="contents-perl" role="content">
  112. <title>Perl 的内容</title>
  113. <segmentedlist>
  114. <segtitle>安装的程序</segtitle>
  115. <segtitle>安装的库</segtitle>
  116. <segtitle>安装的目录</segtitle>
  117. <seglistitem>
  118. <seg>corelist, cpan, enc2xs, encguess, h2ph, h2xs, instmodsh,
  119. json_pp, libnetcfg, perl, perl&perl-version; (指向 perl 的硬链接),
  120. perlbug, perldoc, perlivp, perlthanks (指向 perlbug 的硬链接), piconv,
  121. pl2pm, pod2html, pod2man, pod2text, pod2usage, podchecker, podselect,
  122. prove, ptar, ptardiff, ptargrep, shasum,
  123. splain, xsubpp, 以及 zipdetails</seg>
  124. <seg>很多,无法在这里列出</seg>
  125. <seg>/usr/lib/perl5</seg>
  126. </seglistitem>
  127. </segmentedlist>
  128. <variablelist>
  129. <bridgehead renderas="sect3">简要描述</bridgehead>
  130. <?dbfo list-presentation="list"?>
  131. <?dbhtml list-presentation="table"?>
  132. <!--
  133. <varlistentry id="c2ph">
  134. <term><command>c2ph</command></term>
  135. <listitem>
  136. <para>转储如同
  137. <command>cc -g -S</command>生成的 C 结构体</para>
  138. <indexterm zone="ch-system-perl c2ph">
  139. <primary sortas="b-c2ph">c2ph</primary>
  140. </indexterm>
  141. </listitem>
  142. </varlistentry>
  143. -->
  144. <varlistentry id="corelist">
  145. <term><command>corelist</command></term>
  146. <listitem>
  147. <para>Module::CoreList 的命令行前端</para>
  148. <indexterm zone="ch-system-perl corelist">
  149. <primary sortas="b-corelist">corelist</primary>
  150. </indexterm>
  151. </listitem>
  152. </varlistentry>
  153. <varlistentry id="cpan">
  154. <term><command>cpan</command></term>
  155. <listitem>
  156. <para>通过命令行与综合 Perl 归档网络 (CPAN) 交互</para>
  157. <indexterm zone="ch-system-perl cpan">
  158. <primary sortas="b-cpan">cpan</primary>
  159. </indexterm>
  160. </listitem>
  161. </varlistentry>
  162. <varlistentry id="enc2xs">
  163. <term><command>enc2xs</command></term>
  164. <listitem>
  165. <para>从 Unicode 字符映射或 Tcl 编码文件构建 Encode 模块使用的
  166. Perl 扩展</para>
  167. <indexterm zone="ch-system-perl enc2xs">
  168. <primary sortas="b-enc2xs">enc2xs</primary>
  169. </indexterm>
  170. </listitem>
  171. </varlistentry>
  172. <varlistentry id="encguess">
  173. <term><command>encguess</command></term>
  174. <listitem>
  175. <para>猜测一些文件的编码格式</para>
  176. <indexterm zone="ch-system-perl encguess">
  177. <primary sortas="b-encguess">encguess</primary>
  178. </indexterm>
  179. </listitem>
  180. </varlistentry>
  181. <varlistentry id="h2ph">
  182. <term><command>h2ph</command></term>
  183. <listitem>
  184. <para>将 <filename class="extension">.h</filename> C 头文件转化为
  185. <filename class="extension">.ph</filename> Perl 头文件</para>
  186. <indexterm zone="ch-system-perl h2ph">
  187. <primary sortas="b-h2ph">h2ph</primary>
  188. </indexterm>
  189. </listitem>
  190. </varlistentry>
  191. <varlistentry id="h2xs">
  192. <term><command>h2xs</command></term>
  193. <listitem>
  194. <para>将 <filename class="extension">.h</filename> C 头文件转化为
  195. Perl 扩展</para>
  196. <indexterm zone="ch-system-perl h2xs">
  197. <primary sortas="b-h2xs">h2xs</primary>
  198. </indexterm>
  199. </listitem>
  200. </varlistentry>
  201. <varlistentry id="instmodsh">
  202. <term><command>instmodsh</command></term>
  203. <listitem>
  204. <para>用于检验安装好的 Perl 模块的 shell 脚本,
  205. 可以从安装好的模块创建压缩包</para>
  206. <indexterm zone="ch-system-perl instmodsh">
  207. <primary sortas="b-instmodsh">instmodsh</primary>
  208. </indexterm>
  209. </listitem>
  210. </varlistentry>
  211. <varlistentry id="json_pp">
  212. <term><command>json_pp</command></term>
  213. <listitem>
  214. <para>在特定输入输出格式之间转化数据</para>
  215. <indexterm zone="ch-system-perl json_pp">
  216. <primary sortas="b-json_pp">json_pp</primary>
  217. </indexterm>
  218. </listitem>
  219. </varlistentry>
  220. <varlistentry id="libnetcfg">
  221. <term><command>libnetcfg</command></term>
  222. <listitem>
  223. <para>可以被用于配置
  224. <filename class="libraryfile">libnet</filename> Perl 模块</para>
  225. <indexterm zone="ch-system-perl libnetcfg">
  226. <primary sortas="b-libnetcfg">libnetcfg</primary>
  227. </indexterm>
  228. </listitem>
  229. </varlistentry>
  230. <varlistentry id="perl">
  231. <term><command>perl</command></term>
  232. <listitem>
  233. <para>由 C 语言、<command>sed</command>、
  234. <command>awk</command> 和 <command>sh</command>
  235. 的最好特性结合成的一门瑞士军刀式语言</para>
  236. <indexterm zone="ch-system-perl perl">
  237. <primary sortas="b-perl">perl</primary>
  238. </indexterm>
  239. </listitem>
  240. </varlistentry>
  241. <varlistentry id="perl-version">
  242. <term><command>perl&perl-version;</command></term>
  243. <listitem>
  244. <para>指向 <command>perl</command> 的硬链接</para>
  245. <indexterm zone="ch-system-perl perl-version">
  246. <primary sortas="b-perl&perl-version;">perl&perl-version;</primary>
  247. </indexterm>
  248. </listitem>
  249. </varlistentry>
  250. <varlistentry id="perlbug">
  251. <term><command>perlbug</command></term>
  252. <listitem>
  253. <para>用于创建关于 Perl 或者它附带的模块的 bug 报告,
  254. 并用邮件发送它们</para>
  255. <indexterm zone="ch-system-perl perlbug">
  256. <primary sortas="b-perlbug">perlbug</primary>
  257. </indexterm>
  258. </listitem>
  259. </varlistentry>
  260. <varlistentry id="perldoc">
  261. <term><command>perldoc</command></term>
  262. <listitem>
  263. <para>显示集成在 Perl 安装目录树或某个 Perl 脚本中的一页
  264. pod 格式文档</para>
  265. <indexterm zone="ch-system-perl perldoc">
  266. <primary sortas="b-perldoc">perldoc</primary>
  267. </indexterm>
  268. </listitem>
  269. </varlistentry>
  270. <varlistentry id="perlivp">
  271. <term><command>perlivp</command></term>
  272. <listitem>
  273. <para>Perl 安装检验程序;它可以被用于确认 Perl
  274. 和它的库都安装正确</para>
  275. <indexterm zone="ch-system-perl perlivp">
  276. <primary sortas="b-perlivp">perlivp</primary>
  277. </indexterm>
  278. </listitem>
  279. </varlistentry>
  280. <varlistentry id="perlthanks">
  281. <term><command>perlthanks</command></term>
  282. <listitem>
  283. <para>用于生成发送给 Perl 开发者的感谢信</para>
  284. <indexterm zone="ch-system-perl perlthanks">
  285. <primary sortas="b-perlthanks">perlthanks</primary>
  286. </indexterm>
  287. </listitem>
  288. </varlistentry>
  289. <varlistentry id="piconv">
  290. <term><command>piconv</command></term>
  291. <listitem>
  292. <para>字符编码转换器
  293. <command>iconv</command> 的 Perl 版本</para>
  294. <indexterm zone="ch-system-perl piconv">
  295. <primary sortas="b-piconv">piconv</primary>
  296. </indexterm>
  297. </listitem>
  298. </varlistentry>
  299. <varlistentry id="pl2pm">
  300. <term><command>pl2pm</command></term>
  301. <listitem>
  302. <para>一个用于将 Perl4
  303. <filename class="extension">.pl</filename> 文件转换成 Perl5
  304. <filename class="extension">.pm</filename> 模块的粗糙工具</para>
  305. <indexterm zone="ch-system-perl pl2pm">
  306. <primary sortas="b-pl2pm">pl2pm</primary>
  307. </indexterm>
  308. </listitem>
  309. </varlistentry>
  310. <varlistentry id="pod2html">
  311. <term><command>pod2html</command></term>
  312. <listitem>
  313. <para>将 pod 格式的文件转换为 HTML 格式</para>
  314. <indexterm zone="ch-system-perl pod2html">
  315. <primary sortas="b-pod2html">pod2html</primary>
  316. </indexterm>
  317. </listitem>
  318. </varlistentry>
  319. <varlistentry id="pod2man">
  320. <term><command>pod2man</command></term>
  321. <listitem>
  322. <para>将 pod 数据转换为格式化的 *roff 输入</para>
  323. <indexterm zone="ch-system-perl pod2man">
  324. <primary sortas="b-pod2man">pod2man</primary>
  325. </indexterm>
  326. </listitem>
  327. </varlistentry>
  328. <varlistentry id="pod2text">
  329. <term><command>pod2text</command></term>
  330. <listitem>
  331. <para>将 pod 数据转化为格式化的 ASCII 文本</para>
  332. <indexterm zone="ch-system-perl pod2text">
  333. <primary sortas="b-pod2text">pod2text</primary>
  334. </indexterm>
  335. </listitem>
  336. </varlistentry>
  337. <varlistentry id="pod2usage">
  338. <term><command>pod2usage</command></term>
  339. <listitem>
  340. <para>输出文件中嵌入的 pod 文档中的使用方法信息</para>
  341. <indexterm zone="ch-system-perl pod2usage">
  342. <primary sortas="b-pod2usage">pod2usage</primary>
  343. </indexterm>
  344. </listitem>
  345. </varlistentry>
  346. <varlistentry id="podchecker">
  347. <term><command>podchecker</command></term>
  348. <listitem>
  349. <para>检查 pod 格式文档文件的语法</para>
  350. <indexterm zone="ch-system-perl podchecker">
  351. <primary sortas="b-podchecker">podchecker</primary>
  352. </indexterm>
  353. </listitem>
  354. </varlistentry>
  355. <varlistentry id="podselect">
  356. <term><command>podselect</command></term>
  357. <listitem>
  358. <para>显示 pod 文档中的指定章节</para>
  359. <indexterm zone="ch-system-perl podselect">
  360. <primary sortas="b-podselect">podselect</primary>
  361. </indexterm>
  362. </listitem>
  363. </varlistentry>
  364. <varlistentry id="prove">
  365. <term><command>prove</command></term>
  366. <listitem>
  367. <para>用于运行使用 Test::Harness 模块的测试</para>
  368. <indexterm zone="ch-system-perl prove">
  369. <primary sortas="b-prove">prove</primary>
  370. </indexterm>
  371. </listitem>
  372. </varlistentry>
  373. <!--
  374. <varlistentry id="pstruct">
  375. <term><command>pstruct</command></term>
  376. <listitem>
  377. <para>转储如同 <command>cc -g -S</command>
  378. 生成的结构体符号表</para>
  379. <indexterm zone="ch-system-perl pstruct">
  380. <primary sortas="b-pstruct">pstruct</primary>
  381. </indexterm>
  382. </listitem>
  383. </varlistentry>
  384. -->
  385. <varlistentry id="ptar">
  386. <term><command>ptar</command></term>
  387. <listitem>
  388. <para>一个 Perl 编写的类似 <command>tar</command> 的程序</para>
  389. <indexterm zone="ch-system-perl ptar">
  390. <primary sortas="b-ptar">ptar</primary>
  391. </indexterm>
  392. </listitem>
  393. </varlistentry>
  394. <varlistentry id="ptardiff">
  395. <term><command>ptardiff</command></term>
  396. <listitem>
  397. <para>一个比较压缩档案和未压缩版本的 Perl 程序</para>
  398. <indexterm zone="ch-system-perl ptardiff">
  399. <primary sortas="b-ptardiff">ptardiff</primary>
  400. </indexterm>
  401. </listitem>
  402. </varlistentry>
  403. <varlistentry id="ptargrep">
  404. <term><command>ptargrep</command></term>
  405. <listitem>
  406. <para>一个在 tar 档案中的文件内容上进行模式匹配的 Perl 程序</para>
  407. <indexterm zone="ch-system-perl ptargrep">
  408. <primary sortas="b-ptargrep">ptargrep</primary>
  409. </indexterm>
  410. </listitem>
  411. </varlistentry>
  412. <varlistentry id="shasum">
  413. <term><command>shasum</command></term>
  414. <listitem>
  415. <para>打印或检查 SHA 校验和</para>
  416. <indexterm zone="ch-system-perl shasum">
  417. <primary sortas="b-shasum">shasum</primary>
  418. </indexterm>
  419. </listitem>
  420. </varlistentry>
  421. <varlistentry id="splain">
  422. <term><command>splain</command></term>
  423. <listitem>
  424. <para>被用于 Perl 的强制性详细警告诊断</para>
  425. <indexterm zone="ch-system-perl splain">
  426. <primary sortas="b-splain">splain</primary>
  427. </indexterm>
  428. </listitem>
  429. </varlistentry>
  430. <varlistentry id="xsubpp">
  431. <term><command>xsubpp</command></term>
  432. <listitem>
  433. <para>将 Perl XS 代码转换为 C 代码</para>
  434. <indexterm zone="ch-system-perl xsubpp">
  435. <primary sortas="b-xsubpp">xsubpp</primary>
  436. </indexterm>
  437. </listitem>
  438. </varlistentry>
  439. <varlistentry id="zipdetails">
  440. <term><command>zipdetails</command></term>
  441. <listitem>
  442. <para>显示 Zip 文件内部结构的详细信息</para>
  443. <indexterm zone="ch-system-perl zipdetails">
  444. <primary sortas="b-zipdetails">zipdetails</primary>
  445. </indexterm>
  446. </listitem>
  447. </varlistentry>
  448. </variablelist>
  449. </sect2>
  450. </sect1>