diff options
author | Oliver Smith <osmith@sysmocom.de> | 2018-11-12 12:17:13 +0100 |
---|---|---|
committer | Oliver Smith <osmith@sysmocom.de> | 2018-11-12 12:18:41 +0100 |
commit | 161365fa6f1bed8e1309f85fa27d0f53f88fbd73 (patch) | |
tree | df017567e2a159591678c2701d7d50bda5efbd09 | |
parent | 10ffc822374c73d2204aff362cb8da20baab48ab (diff) |
merge_doc.xsl: move from libosmocore.git
Allow building manuals without the libosmocore source.
Related: OS#3385
Change-Id: Ifb81b18422987cdf36b75993d2782abf93b5f48c
-rw-r--r-- | Makefile | 6 | ||||
-rw-r--r-- | build/Makefile.vty-reference.inc | 3 | ||||
-rw-r--r-- | merge_doc.xsl | 48 |
3 files changed, 49 insertions, 8 deletions
@@ -1,5 +1,3 @@ -LIBOSMO_DIR ?= ~/source/gsm/libosmocore - all: check-deps cd OsmoBTS; $(MAKE) cd OsmoNITB; $(MAKE) @@ -80,9 +78,6 @@ endef define check_dep_python2_module @echo "import $(1)" | python2 - >/dev/null 2>&1 || { echo >&2 "Failed to import '$(1)' module, please install $(2)."; exit 1; } endef -define check_dep_dir - @test -d $(1) || { echo >&2 "Directory '$(1)' not found, please set $(2) to the path of your libosmocom source tree: make LIBOSMO_DIR=/path/to/libosmocore"; exit 1; } -endef check-deps: $(call check_dep_bin,mscgen,mscgen) @@ -95,4 +90,3 @@ check-deps: $(call check_dep_bin,dot,graphviz) $(call check_dep_bin,python2,python2) $(call check_dep_python2_module,pychart,python2-pychart) - $(call check_dep_dir,$(LIBOSMO_DIR),LIBOSMO_DIR) diff --git a/build/Makefile.vty-reference.inc b/build/Makefile.vty-reference.inc index 6607ae5..1528d32 100644 --- a/build/Makefile.vty-reference.inc +++ b/build/Makefile.vty-reference.inc @@ -25,8 +25,7 @@ DOCBOOKS = $(VTY_REFERENCE) DOCBOOKS_DEPS = generated/docbook_vty.xml include $(TOPDIR)/build/Makefile.docbook.inc -LIBOSMO_DIR ?= ~/source/gsm/libosmocore -MERGE_DOC = $(shell realpath $(LIBOSMO_DIR)/doc/vty/merge_doc.xsl) +MERGE_DOC = $(shell realpath $(TOPDIR)/merge_doc.xsl) CLEAN_FILES += generated diff --git a/merge_doc.xsl b/merge_doc.xsl new file mode 100644 index 0000000..d75c499 --- /dev/null +++ b/merge_doc.xsl @@ -0,0 +1,48 @@ +<?xml version="1.0" encoding="ISO-8859-1"?> +<xsl:transform version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" + xmlns:vty="urn:osmocom:xml:libosmocore:vty:doc:1.0"> + <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes" /> + + + <xsl:template match="@*|node()"> + <xsl:copy> + <xsl:apply-templates select="@*|node()" /> + </xsl:copy> + </xsl:template> + + + <!-- Copy the name of the node --> + <xsl:template match="vty:node"> + <xsl:variable name="info" select="document($with)/vty:vtydoc/vty:node[@id=current()/@id]/." /> + <xsl:if test="not($info/vty:hide)"> + <xsl:copy> + <xsl:apply-templates select="@*|node()" /> + <xsl:for-each select="$info/*"> + <xsl:copy-of select="." /> + </xsl:for-each> + </xsl:copy> + </xsl:if> + </xsl:template> + + + <!-- Copy command and add nodes --> + <xsl:template match="vty:command"> + <xsl:variable name="info" select="document($with)/vty:vtydoc/vty:node[@id=current()/../@id]/vty:command[@id=current()/@id]/." /> + <xsl:variable name="info_generic" select="document($with)/vty:vtydoc/vty:common/vty:command[@id=current()/@id]/." /> + <xsl:copy> + <xsl:apply-templates select="@*|node()" /> + + <!-- Copy the specific issue... --> + <xsl:for-each select="$info/*"> + <xsl:copy-of select="." /> + </xsl:for-each> + + <xsl:if test="not($info)"> + <xsl:for-each select="$info_generic/*"> + <xsl:copy-of select="." /> + </xsl:for-each> + </xsl:if> + </xsl:copy> + </xsl:template> +</xsl:transform> + |