blob: f538977dd12d4e9926333b67f2162a736d7123d1 [file] [log] [blame]
Beichuan Zhang55b8ed42014-04-26 22:25:44 -07001# inspired by code by Hans-Martin von Gaudecker, 2012
Alexander Afanasyev49272f72014-04-06 21:49:46 -07002
Davide Pesavento0d89d412024-03-13 14:20:02 -04003"""Support for Sphinx documentation"""
4
Alexander Afanasyev49272f72014-04-06 21:49:46 -07005import os
Davide Pesavento0e7f7342024-03-13 14:00:36 -04006from waflib import Node, Task, TaskGen, Utils
7
Alexander Afanasyev49272f72014-04-06 21:49:46 -07008
9class sphinx_build(Task.Task):
10 color = 'BLUE'
Beichuan Zhang55b8ed42014-04-26 22:25:44 -070011 run_str = '${SPHINX_BUILD} -D ${VERSION} -D ${RELEASE} -q -b ${BUILDERNAME} -d ${DOCTREEDIR} ${SRCDIR} ${OUTDIR}'
Alexander Afanasyev49272f72014-04-06 21:49:46 -070012
13 def __str__(self):
14 env = self.env
Alexander Afanasyev58ea4582014-05-30 08:38:56 +030015 src_str = ' '.join([a.path_from(a.ctx.launch_node()) for a in self.inputs])
16 tgt_str = ' '.join([a.path_from(a.ctx.launch_node()) for a in self.outputs])
Alexander Afanasyev49272f72014-04-06 21:49:46 -070017 if self.outputs: sep = ' -> '
18 else: sep = ''
19 return'%s [%s]: %s%s%s\n'%(self.__class__.__name__.replace('_task',''),
20 self.env['BUILDERNAME'], src_str, sep, tgt_str)
21
Davide Pesavento0e7f7342024-03-13 14:00:36 -040022
23# from https://docs.python.org/3.12/whatsnew/3.12.html#imp
24def load_source(modname, filename):
25 import importlib.util
26 from importlib.machinery import SourceFileLoader
27 loader = SourceFileLoader(modname, filename)
28 spec = importlib.util.spec_from_file_location(modname, filename, loader=loader)
29 module = importlib.util.module_from_spec(spec)
30 loader.exec_module(module)
31 return module
32
33
Alexander Afanasyev49272f72014-04-06 21:49:46 -070034@TaskGen.extension('.py', '.rst')
35def sig_hook(self, node):
36 node.sig=Utils.h_file(node.abspath())
37
Davide Pesavento0e7f7342024-03-13 14:00:36 -040038
Davide Pesavento0d89d412024-03-13 14:20:02 -040039@TaskGen.feature('sphinx')
40@TaskGen.before_method('process_source')
Alexander Afanasyev49272f72014-04-06 21:49:46 -070041def apply_sphinx(self):
42 """Set up the task generator with a Sphinx instance and create a task."""
43
44 inputs = []
45 for i in Utils.to_list(self.source):
46 if not isinstance(i, Node.Node):
47 node = self.path.find_node(node)
48 else:
49 node = i
50 if not node:
51 raise ValueError('[%s] file not found' % i)
52 inputs.append(node)
53
54 task = self.create_task('sphinx_build', inputs)
55
56 conf = self.path.find_node(self.config)
57 task.inputs.append(conf)
58
59 confdir = conf.parent.abspath()
Davide Pesavento08b91c82019-04-13 19:42:10 -040060 buildername = getattr(self, 'builder', 'html')
61 srcdir = getattr(self, 'srcdir', confdir)
62 outdir = self.path.find_or_declare(getattr(self, 'outdir', buildername)).get_bld()
63 doctreedir = getattr(self, 'doctreedir', os.path.join(outdir.abspath(), '.doctrees'))
Alexander Afanasyev49272f72014-04-06 21:49:46 -070064
65 task.env['BUILDERNAME'] = buildername
66 task.env['SRCDIR'] = srcdir
Alexander Afanasyev49272f72014-04-06 21:49:46 -070067 task.env['OUTDIR'] = outdir.abspath()
Davide Pesavento0e7f7342024-03-13 14:00:36 -040068 task.env['DOCTREEDIR'] = doctreedir
Davide Pesavento08b91c82019-04-13 19:42:10 -040069 task.env['VERSION'] = 'version=%s' % self.version
70 task.env['RELEASE'] = 'release=%s' % getattr(self, 'release', self.version)
Alexander Afanasyev49272f72014-04-06 21:49:46 -070071
Davide Pesavento08b91c82019-04-13 19:42:10 -040072 if buildername == 'man':
Davide Pesavento0e7f7342024-03-13 14:00:36 -040073 confdata = load_source('sphinx_conf', conf.abspath())
74 for i in confdata.man_pages:
Alexander Afanasyev49272f72014-04-06 21:49:46 -070075 target = outdir.find_or_declare('%s.%d' % (i[1], i[4]))
76 task.outputs.append(target)
77
78 if self.install_path:
Davide Pesavento08b91c82019-04-13 19:42:10 -040079 self.bld.install_files('%s/man%d/' % (self.install_path, i[4]), target)
Alexander Afanasyev49272f72014-04-06 21:49:46 -070080 else:
81 task.outputs.append(outdir)
82
Davide Pesavento0e7f7342024-03-13 14:00:36 -040083
Alexander Afanasyev49272f72014-04-06 21:49:46 -070084def configure(conf):
Davide Pesavento0d89d412024-03-13 14:20:02 -040085 """Check if sphinx-build program is available."""
Alexander Afanasyev49272f72014-04-06 21:49:46 -070086 conf.find_program('sphinx-build', var='SPHINX_BUILD', mandatory=False)
87
Davide Pesavento0e7f7342024-03-13 14:00:36 -040088
Davide Pesavento0d89d412024-03-13 14:20:02 -040089# sphinx command
Alexander Afanasyev49272f72014-04-06 21:49:46 -070090from waflib.Build import BuildContext
91class sphinx(BuildContext):
Davide Pesavento0d89d412024-03-13 14:20:02 -040092 cmd = 'sphinx'
93 fun = 'sphinx'