Макросы DocBook?
Есть ли какой-либо способ определения макросов (например, текстовые макросы или определения латекса) в документах DocBook?
DocBook очень многословен, и макросы очень помогли бы. Я не нашел их в кратких руководствах.
Если да, может ли кто-нибудь привести простой пример или ссылку на?
Спасибо
3 ответа
Не уверен, если это именно то, что вы хотите / если он полностью соответствует вашим требованиям, но я думаю о сущностях. Вы можете определить их в верхней части (вашего XML-документа, то есть общего XML, но не DocBook). Как видно здесь для "doc.release.number" и "doc.release.date". Но они также могут быть включены через отдельный файл. Как видно в 3-м ряду ENTITY. Здесь СИСТЕМА означает, что происходит из другого файла "entity.ent".
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN"
"http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
<!ENTITY doc.release.number "1.0.0.beta-1" >
<!ENTITY doc.release.date "April 2010" >
<!ENTITY % entities SYSTEM "entities.ent" >
%entities;
]>
<!-- This document is based on http://readyset.tigris.org/nonav/templates/userguide.html -->
<article lang="en">
<articleinfo>
<title>&project.impl.title; - User Manual</title>
<subtitle></subtitle>
<date>&project.impl.release.date;</date>
<copyright>
<year>doc.release.year</year>
<holder>Team - &project.impl.title;</holder>
</copyright>
<releaseinfo>&doc.release.number;</releaseinfo>
</articleinfo>
<section>
<title>Introduction</title>
<para>
The &project.impl.title; has been created to clean up (X)HTML and XML documents as part of
</para>
<section>
</article>
В документе вы ссылаетесь на сущности через &
и окончание ;
как в &project.impl.title;
В файле entity.ent вы указываете элементы ENTITY аналогичным образом:
<?xml version="1.0" encoding="UTF-8"?>
<!ENTITY project.impl.title 'Maven Tidy Plug-in' >
<!ENTITY project.impl.group-id 'net.sourceforge.docbook-utils.maven-plugin' >
<!ENTITY project.impl.artifact-id 'maven-tidy-plugin' >
<!ENTITY project.impl.release.number '1.0.0.beta-1' >
<!ENTITY project.impl.release.date 'April 2010' >
<!ENTITY project.impl.release.year '2010' >
<!ENTITY project.impl.url '../' >
<!ENTITY project.spec.title '' >
<!ENTITY project.spec.release.number '' >
<!ENTITY project.spec.release.date '' >
<!ENTITY doc.release.year '2010' >
Not exactly what you asked for, but perhaps helpful for some of your cases: you can define templates in your wrapper stylesheet where you define fo
команды. Некоторые примеры:
Код:
<xsl:template match="symbolchar">
<fo:inline font-family="Symbol">
<xsl:choose>
<xsl:when test=".='ge'">≥</xsl:when>
<xsl:when test=".='le'">≤</xsl:when>
<xsl:when test=".='sqrt'">√</xsl:when>
<xsl:otherwise>?!?</xsl:otherwise>
</xsl:choose>
</fo:inline>
</xsl:template>
Использование:
<symbolchar>le</symbolchar>
Код:
<xsl:template match="processing-instruction('linebreak')">
<fo:block/>
</xsl:template>
Использование:
<?linebreak?>
Рассматривали ли вы создание DocBook из другого формата (например, reStructuredText?)
Я нашел это довольно хорошо для документации.
Кроме того, вы можете написать макропроцессор (или заглянуть в m4) довольно быстро. Если вы используете XML-версию DocBook, подойдет простой XSLT. Просто сделайте несколько тегов и преобразуйте их. Иметь шаблонные материалы добавляются автоматически. И будьте готовы злиться на XSLT. За то, что не все, что могло быть. Для того, чтобы сделать ваше мышление деформированным