Provided by: po4a_0.69-1_all bug

名称

       Locale::Po4a::Sgml - 将 SGML 文档从/转换为 PO 文件

描述

       Po4a (PO For Anything) 项目的目标是在文档等不需要翻译的领域使用 gettext 工具简化翻译(更有
       趣的是,简化翻译的维护)。

       Locale::Po4a::Sgml 是一个帮助将 SGML 格式的文档翻译成其他 [人类] 语言的模块。

       本模块使用 onsgmls(1) 解析 SGML 文件。确保它已安装。还要确保 SGML 文件的 DTD 已安装在系统
       中。

此模块接受的选项

       debug
           空格分隔的关键字列表,指示要调试的部件。可能的值有:标记、类属、图元和参照。

       verbose
           给出更多关于正在发生的事情的信息。

       translate
           空格分隔的额外标记列表 (除了 DTD 提供的标记之外),其内容应形成额外的 msgid。

       section
           空格分隔的包含其他标记的额外标记列表 (除了 DTD 提供的标记之外),其中一些标记属于
           translate 类别。

       indent
           增加缩进级别的以空格分隔的标记列表。

       verbatim
           这些标签内的布局不应更改。段落不会换行,也不会添加额外的缩进空间或新行用于修饰。

       empty
           标签不需要关闭。

       ignore
           标签被 po4a 忽略并视为纯字符数据。也就是说,它们可以是 msgid 的一部分。例如,<b> 是此
           类别的一个很好的候选者,因为将其放入翻译部分会创建不是完整句子的 msgid,这是不好的。

       attributes
           需要转换的属性的空格分隔列表。您可以按属性的名称指定属性(例如,"lang"(语言)),但也可以
           在其前面加上标记层次结构,以指定此属性仅在转换为指定的标记时才会被转换。例
           如:<bbb><aaa> lang 指定只有当 lang 属性在 <aaa> 标记中(该标记在 <bbb> 标记中)时,lang
           属性才会被转换。标记名称实际上是正则表达式,因此您还可以编写类似 <aaa|bbbb> lang 这样
           的内容,以便仅转换 <aaa> 或 <bbb> 标记中的 lang 属性。

       qualify
           翻译必须由属性名称限定的属性的空格分隔列表。请注意,此设置会自动将给定属性添加到"属
           性"列表中。

       force
           即使 DTD 未知或 onsgmls 在输入文件中发现错误,也要继续。

       include-all
           默认情况下,仅包含一个实体(如 '&version;')的 msgid 会被跳过,以方便翻译人员使用。激活
           此选项可阻止此优化。如果文档包含像 "<title>&Aacute;</title>" 这样的结构,那么它可能会
           很有用,即使我怀疑这样的事情是否会发生……

       ignore-inclusion
           不会内联的实体的空格分隔列表。请谨慎使用此选项:它可能会导致 onsgmls (内部使用) 添加标
           记并使输出文档无效。

此模块的状态

       结果是完美的。即生成的文档完全相同。但是仍然存在一些问题:

       • 默认情况下,onsgmls 的错误输出被重定向到 /dev/null,这显然是错误的。我不知道如何避免这一
         点。

         问题是我必须 "protect" 条件包含(即"<! [ %foo [" and "]]>" stuff) 不受 onsgmls 的影响。否
         则 onsgmls 会吃掉它们,我不知道如何在最终文档中恢复它们。为了防止出现这种情况,我将它们
         重写为 "{PO4A-beg-foo}" 和 "{PO4A-end}"。

         这样做的问题是,"{PO4A-end}" 和 I 添加的内容在文档中无效(不在 <p> 标记中)。

         如果您想查看在输出,请将以下内容添加到命令行(或 po4a 配置行):

           -o debug=onsgmls

       • 它只适用于 DebianDoc 和 DocBook DTD。添加对新 DTD 的支持应该非常容易。该机制对于每个 DTD
         都是相同的,您只需给出现有标记及其一些特征的列表。

         我同意,这需要更多的文档,但它仍然被认为是测试版,我讨厌记录可能/将会改变的东西。

       • 警告,对 DTD 的支持只是试验性的。我没有阅读任何参考手册来查找每个标签的定义。我确实在模
         块中添加了标签定义,直到它适用于我在网上找到的一些文档。如果你的文档使用的标签比我的
         多,它就不会起作用。但正如我上面所说的,修复这个问题应该是相当容易的。

         我只针对 SAG (系统管理员指南)测试了 DocBook,但是这个文档相当大,应该使用大多数 DocBook
         特性。

         对于 DebianDoc,我测试了 DDP 的一些手册,但还没有全部测试。

       • 在包含文件的情况下,PO 文件中消息的字符串引用(即类似 "#: en/titletoc.sgml:9460" 的行)将
         是错误的。

         这是因为我对文件进行了预处理,以保护条件包含 (即 "<! [ %foo [" and "]]>" 内容) 和某些实
         体 (如 &version;) 不受 onsgmls 的影响,因为我希望它们与生成的文档保持原样。为此,我创建
         了输入文件的临时副本,并在将其传递给 onsgmls 进行解析之前对其进行了所有我想要的更改。

         为了使其正常工作,我将请求包含文件的实体替换为给定文件的内容 (这样我也可以保护子文件中需
         要的内容)。但是到目前为止,没有采取任何措施来纠正后面的引用 (即文件名和行号)。我不确定最
         好的办法是什么。

作者

       此模块是 sgmlspl (用于 ONSGMLS 解析器的 SGML 后处理器) 的改编版本,它是:

        版权所有 © 1995 David Megginson <dmeggins@aix1.uottawa.ca>

       对 po4a 的改编是通过以下方式完成的:

        Denis Barbier <barbier@linuxfr.org>
        Martin Quinson (mquinson#debian.org)

版权和许可

        版权所有 © 1995 David Megginson <dmeggins@aix1.uottawa.ca>。
        版权所有 © 2002-2005 SPI, Inc.

       此程序是自由软件;您可以根据 GPL 条款重新分发和/或修改它(请参阅复制文件)。