You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gentoo-overlay/net-misc/ntpsec/files/ntpsec-1.1.8-fix-asciidoc-v...

373 lines
14 KiB

diff --git a/wafhelpers/asciidoc.py b/wafhelpers/asciidoc.py
index b6aa1f116..a2218bb69 100644
--- a/wafhelpers/asciidoc.py
+++ b/wafhelpers/asciidoc.py
@@ -1,73 +1,173 @@
-import re
-
-from waflib import Task
-from waflib.TaskGen import extension
-
-# asciidoc -b html5 -a linkcss -a stylesdir=/mnt/devel/ntp/commit/docs \
-# -o asd driver32.adoc
-
-# Borrowed from waf/docs/book/wscript in the Waf Project.
-re_xi = re.compile('''^(include|image)::(.*?.(adoc|\\{PIC\\}))\[''', re.M)
-
-
-def ascii_doc_scan(self):
- p = self.inputs[0].parent
- node_lst = [self.inputs[0]]
- seen = []
- depnodes = []
-
- while node_lst:
- nd = node_lst.pop(0)
- if nd in seen:
- continue
- seen.append(nd)
-
- code = nd.read()
- for m in re_xi.finditer(code):
- name = m.group(2)
- if m.group(3) == '{PIC}':
-
- ext = '.eps'
- if self.generator.rule.rfind('A2X') > 0:
- ext = '.png'
-
- k = p.find_resource(name.replace('{PIC}', ext))
- if k:
- depnodes.append(k)
- else:
- k = self.inputs[0].find_resource(name)
- if k:
- depnodes.append(k)
- node_lst.append(k)
- return [depnodes, ()]
+'''Most of the functionality for building HTML and man pages from AsciiDoc.'''
+import re
-# ASCIIDOC_FLAGS are almost always needed and need to be set by the user.
-class asciidoc(Task.Task):
- color = "BLUE"
- run_str = '${BIN_ASCIIDOC} -b html5 -a linkcss ${ASCIIDOC_FLAGS} ' \
- '-o ${TGT[0].name} ${SRC[0].abspath()}'
- ext_out = ".html"
+from waflib import Task # pylint: disable=import-error
+from waflib.TaskGen import extension # pylint: disable=import-error
+
+
+def options(opt):
+ 'Add command line options for AsciiDoc processing.'
+ grp = opt.add_option_group('NTP documentation configure options')
+ grp.add_option('--disable-doc', action='store_true',
+ default=False, help='Disable HTML document building.')
+ grp.add_option('--enable-doc', action='store_true',
+ default=False, help='Enable HTML document building.')
+ grp.add_option('--disable-manpage', action='store_true',
+ default=False, help='Disable manpage building.')
+ grp.add_option('--enable-manpage', action='store_true',
+ default=False, help='Enable manpage building.')
+
+
+def configure(ctx):
+ 'Set options from the extended environment and command line arguments.'
+
+ if ctx.options.disable_doc and ctx.options.enable_doc:
+ ctx.fatal('--disable-doc and --enable-doc conflict.')
+ if ctx.options.disable_manpage and ctx.options.enable_manpage:
+ ctx.fatal('--disable-manpage and --enable-manpage conflict.')
+
+ ctx.env.BUILD_DOC = False
+ ctx.env.BUILD_MAN = False
+ if ctx.options.disable_doc and ctx.options.disable_manpage:
+ ctx.msg('AsciiDoc processor', 'unnecessary')
+ return
+
+ # asciidoctor versions < 1.5.8 throw warnings for manpages and driver_shm.
+ # asciidoc versions 8.6.5-8.6.7 throw warnings for warp.adoc and versions
+ # < 8.6.4 have no HTML5 backend.
+ # asciidoc3 versions < 3.0.2 throw errors.
+ adoc_list = [['asciidoctor', (1, 5, 8)],
+ ['asciidoc', (8, 6, 8)],
+ ['asciidoc3', (3, 0, 2)],
+ ]
+ for progname, asciidocminver in adoc_list:
+ if 'BIN_ASCIIDOC' not in ctx.env or ctx.env.BIN_ASCIIDOC == []:
+ # used to make man and HTML pages
+ ctx.find_program(progname, var='BIN_ASCIIDOC', mandatory=False)
+ # make sure asciidoc is new enough.
+ # based on check_python_version() from waf
+
+ if ctx.env.BIN_ASCIIDOC:
+ # https://lists.ntpsec.org/pipermail/devel/2016-July/001778.html
+ # Get asciidoc version string
+ cmd = ctx.env.BIN_ASCIIDOC + ['--version']
+ # example output: asciidoc 8.6.9
+ version_string = ctx.cmd_and_log(cmd).split()[1]
+ match = re.match(r'^(\d+)\.(\d+)\.(\d+)', version_string)
+ if match:
+ version_tuple = tuple(map(int, match.groups()))
+ if version_tuple >= asciidocminver:
+ if progname == 'asciidoc':
+ ctx.find_program('a2x', var='BIN_A2X', mandatory=False)
+ ctx.find_program('xsltproc', var='BIN_XSLTPROC',
+ mandatory=False)
+ elif progname == 'asciidoc3':
+ ctx.find_program('a2x3', var='BIN_A2X', mandatory=False)
+ ctx.find_program('xsltproc', var='BIN_XSLTPROC',
+ mandatory=False)
+
+ if version_tuple >= asciidocminver:
+ color = 'GREEN'
+ else:
+ color = 'YELLOW'
+ ctx.env.BIN_ASCIIDOC = []
+ ctx.msg('Checking for %s version >= %s' %
+ (progname, '%d.%d.%d' % asciidocminver),
+ version_string, color=color)
+
+ if not ctx.env.BIN_ASCIIDOC:
+ if not (ctx.options.enable_doc or ctx.options.enable_manpage):
+ # The user did not require either, so this is fine.
+ return
+
+ error = 'no AsciiDoc processor qualified'
+ if ctx.options.enable_doc:
+ error += ', remove --enable-doc'
+ if ctx.options.enable_manpage:
+ error += ', remove --enable-manpage'
+ ctx.fatal(error)
+
+ ctx.env.BUILD_DOC = not ctx.options.disable_doc
+ ctx.env.BUILD_MAN = not ctx.options.disable_manpage
+
+ if 'asciidoctor' in ctx.env.BIN_ASCIIDOC[0]:
+ ctx.env.ARGS_DOC = [
+ ctx.env.BIN_ASCIIDOC[0],
+ '-a', 'attribute-missing=warn',
+ # To eliminate compat-mode:
+ # 'italics' needs to be changed to _italics_
+ # +monospace+ needs to be changed to `monospace`
+ # https://asciidoctor.org/docs/migration/#migration-cheatsheet
+ '-a', 'compat-mode',
+ ]
+ ctx.env.ARGS_MAN = ctx.env.ARGS_DOC + [
+ '-b', 'manpage',
+ ]
+ ctx.env.ARGS_DOC += [
+ '-b', 'xhtml5', '-a', 'linkcss',
+ '-a', 'stylesheet=asciidoc.css',
+ ]
+ elif 'asciidoc' in ctx.env.BIN_ASCIIDOC[0]:
+ ctx.env.ARGS_DOC = [
+ ctx.env.BIN_ASCIIDOC[0],
+ '-a', 'attribute-missing=warn',
+ '-b', 'html5', '-a', 'linkcss',
+ '-a', 'stylesheet=asciidoc.css',
+ ]
+ if ctx.env.BIN_A2X and ctx.env.BIN_XSLTPROC:
+ ctx.env.ARGS_MAN = [
+ ctx.env.BIN_A2X[0],
+ '-a', 'attribute-missing=warn',
+ '-f', 'manpage', '--no-xmllint',
+ ]
+ else:
+ if ctx.options.enable_manpage:
+ ctx.fatal('a2x/xsltproc not found, remove --enable-manpage')
+ ctx.env.BUILD_MAN = False
+
+
+def build(ctx):
+ 'Set processor noise level and set HTML pages to build.'
+ from waflib.Logs import verbose # pylint: disable=import-error
+ if verbose > 1: # Pass verbosity to AsciiDoc toolchain
+ if ctx.env.ARGS_DOC:
+ ctx.env.ARGS_DOC += ['-v']
+ if ctx.env.ARGS_MAN:
+ ctx.env.ARGS_MAN += ['-v']
+ if ctx.env.BUILD_DOC and ctx.variant == 'main':
+ ctx.recurse('docs')
+
+
+class html(Task.Task):
+ 'Define HTML build process.'
+ # Optional weight to tune the priority for task instances.
+ # The higher, the earlier. The weight only applies to single task objects.
+ weight = 3 # set arbitrarily high to be first as to not slow down later tasks
+ run_str = '${ARGS_DOC} -o ${TGT[0].name} ${SRC[0].abspath()}'
+ ext_out = '.html'
+
+
+class man(Task.Task):
+ 'Define manpage build process.'
+ weight = 2 # set arbitrarily high to be second as to not slow down later tasks (Failed)
+ run_str = '${ARGS_MAN} ${SRC[0].abspath()}'
@extension('.adoc')
-def run_asciidoc(self, node):
- out = node.change_ext(".html")
- tsk = self.create_task("asciidoc", node, [out])
+def run_html(self, node):
+ 'Add HTML build caller function.'
+ out = node.change_ext('.html')
+ tsk = self.create_task('html', node, [out])
tsk.cwd = node.parent.get_bld().abspath()
-class a2x(Task.Task):
- color = "YELLOW"
- shell = True
- run_str = '${BIN_A2X} ${A2X_FLAGS} ${SRC[0].abspath()}'
- scan = ascii_doc_scan
-
-
@extension('.man-tmp')
-def run_a2x(self, node):
+def run_manpage(self, node):
+ 'Add manpage build caller function.'
n_file = node.path_from(self.bld.bldnode)
- out = "%s.%s" % (n_file.replace("-man.adoc.man-tmp", ""), self.section)
+ out = '%s.%s' % (n_file.replace('-man.adoc.man-tmp', ''), self.section)
out_n = self.bld.path.find_or_declare(out)
- self.create_task('a2x', node, out_n)
- self.bld.install_files("${MANDIR}/man%s/" % self.section, out_n)
+ self.create_task('man', node, out_n)
+ self.bld.install_files('${MANDIR}/man%s/' % self.section, out_n)
+ weight = 3
diff --git a/wafhelpers/waf.py b/wafhelpers/waf.py
index 96f753ecb..4f2d562a4 100644
--- a/wafhelpers/waf.py
+++ b/wafhelpers/waf.py
@@ -41,10 +41,7 @@ def manpage_subst_fun(self, code):
@conf
def manpage(ctx, section, source):
- # ctx.install_files('${MANDIR}' + "/man%s/" % section,
- # source.replace("-man.adoc", ".%s" % section))
-
- if not ctx.env.ENABLE_DOC or ctx.env.DISABLE_MANPAGE:
+ if not ctx.env.BUILD_MAN:
return
ctx(features="subst",
diff --git a/wscript b/wscript
index c7c5468b1..601edaacd 100644
--- a/wscript
+++ b/wscript
@@ -55,10 +55,12 @@ Usage: waf <command>
def options(ctx):
options_cmd(ctx, config)
+ ctx.load('asciidoc', tooldir='wafhelpers/')
ctx.recurse("pylib")
def configure(ctx):
+ ctx.load('asciidoc', tooldir='wafhelpers/')
class oc(Build.BuildContext):
cmd = 'oc'
@@ -93,7 +95,6 @@ def configure(ctx):
ctx.run_build_cls = 'check'
ctx.load('waf', tooldir='wafhelpers/')
ctx.load('waf_unit_test')
- ctx.load('pytest')
ctx.load('gnu_dirs')
with open("VERSION", "r") as f:
@@ -148,55 +149,6 @@ def configure(ctx):
ctx.find_program("awk", var="BIN_AWK", mandatory=False)
ctx.find_program("sh", var="BIN_SH", mandatory=False)
- # used to make man and html pages
- ctx.find_program("asciidoc", var="BIN_ASCIIDOC", mandatory=False)
- # make sure asciidoc is new enough.
- # based on check_python_version() from waf
- if ctx.env.BIN_ASCIIDOC:
- # https://lists.ntpsec.org/pipermail/devel/2016-July/001778.html
- asciidocminver = (8, 6, 0)
- # Get asciidoc version string
- cmd = ctx.env.BIN_ASCIIDOC + ['--version']
- # example output: asciidoc 8.6.9
- lines = ctx.cmd_and_log(cmd).split()[1].split(".")
- assert len(lines) == 3, "found %r lines, expected 3: %r" \
- % (len(lines), lines)
- asciidocver_tuple = (int(lines[0]), int(lines[1]), int(lines[2]))
-
- # Compare asciidoc version with the minimum required
- result = (asciidocver_tuple >= asciidocminver)
-
- asciidocver_full = '.'.join(map(str, asciidocver_tuple[:3]))
- asciidocminver_str = '.'.join(map(str, asciidocminver))
- ctx.msg('Checking for asciidoc version >= %s' % (asciidocminver_str,),
- asciidocver_full, color=result and 'GREEN' or 'YELLOW')
-
- if not result:
- del ctx.env.BIN_ASCIIDOC
- ctx.find_program("a2x", var="BIN_A2X", mandatory=False)
- ctx.find_program("xsltproc", var="BIN_XSLTPROC", mandatory=False)
-
- ctx.env.ENABLE_DOC = False
- if ctx.env.BIN_ASCIIDOC and ctx.env.BIN_XSLTPROC and ctx.env.BIN_A2X:
- ctx.env.ENABLE_DOC = True
-
- if ctx.options.enable_doc and not ctx.env.ENABLE_DOC:
- ctx.fatal("asciidoc and xsltproc are required in order "
- "to build documentation")
- elif ctx.options.enable_doc:
- ctx.env.ASCIIDOC_FLAGS = []
- ctx.env.ENABLE_DOC_USER = ctx.options.enable_doc
-
- # XXX: conditionally build this with --disable-man?
- # Should it build without docs enabled?
- ctx.env.A2X_FLAGS = ["--format", "manpage"]
- if not ctx.options.enable_a2x_xmllint:
- ctx.env.A2X_FLAGS += ["--no-xmllint"]
-
- # Disable manpages within build()
- if ctx.options.disable_manpage:
- ctx.env.DISABLE_MANPAGE = True
-
ctx.check_cfg(
package='systemd', variables=['systemdsystemunitdir'],
uselib_store='SYSTEMD', mandatory=False,
@@ -662,7 +614,7 @@ int main(int argc, char **argv) {
('strlcat', ["string.h"])
)
for ft in optional_functions:
- probe_function(ctx, function=ft[0], prerequisites=ft[1])
+ probe_function(ctx, function=ft[0], prerequisites=ft[1])
# This area is still work in progress
# Need to disable making symbols
@@ -897,8 +848,8 @@ int main(int argc, char **argv) {
msg_setting("Droproot Support", droproot_type)
msg_setting("Debug Support", yesno(ctx.options.enable_debug))
msg_setting("Refclocks", ", ".join(sorted(ctx.env.REFCLOCK_LIST)))
- msg_setting("Build Manpages",
- yesno(ctx.env.ENABLE_DOC and not ctx.env.DISABLE_MANPAGE))
+ msg_setting("Build Docs", yesno(ctx.env.BUILD_DOC))
+ msg_setting("Build Manpages", yesno(ctx.env.BUILD_MAN))
ctx.recurse("pylib")
# Convert the Python directories to absolute paths.
@@ -1035,14 +986,6 @@ def build(ctx):
# the build directory never happens. This is how we foil that.
ctx.add_pre_fun(lambda ctx: ctx.exec_command("rm -f pylib/*.py[co]"))
- if verbose > 0: # Pass Verbosity to asciidoc and a2x
- ctx.env.A2X_FLAGS += ["-v"]
- ctx.env.ASCIIDOC_FLAGS += ["-v"]
-
- if ctx.env.ENABLE_DOC_USER:
- if ctx.variant != "main":
- ctx.recurse("docs")
-
if ctx.variant == "host":
ctx.recurse("ntpd")
return