131 lines
3.5 KiB
Meson
131 lines
3.5 KiB
Meson
sphinx_p = find_program('sphinx-build', required: get_option('doc'))
|
|
if not sphinx_p.found()
|
|
message('Sphinx not found, not building the documentation')
|
|
subdir_done()
|
|
endif
|
|
|
|
if not doxygen_p.found()
|
|
message('Doxygen not found, not building the documentation')
|
|
subdir_done()
|
|
endif
|
|
|
|
breathe_p = find_program('breathe-apidoc', required: get_option('doc'))
|
|
if not breathe_p.found()
|
|
message('Breathe not found, not building the documentation')
|
|
subdir_done()
|
|
endif
|
|
|
|
pymod = import('python')
|
|
lxml_p = pymod.find_installation(
|
|
modules: [
|
|
'lxml',
|
|
],
|
|
required: get_option('doc')
|
|
)
|
|
if not lxml_p.found()
|
|
message('lxml not found, not building gtk documentation from Doxygen')
|
|
subdir_done()
|
|
endif
|
|
|
|
sphinx_c = run_command(sphinx_p, '--version')
|
|
breathe_c = run_command(breathe_p, '--version')
|
|
doxygen_c = run_command(doxygen_p, '--version')
|
|
|
|
sphinx_v = sphinx_c.stdout().split(' ')[1].strip()
|
|
breathe_v = breathe_c.stdout().split(' ')[2].strip()
|
|
doxygen_v = doxygen_c.stdout().strip()
|
|
|
|
if sphinx_v.version_compare('< 2.1.0')
|
|
error('Use at least sphinx version 2.1.0, found ' + sphinx_v)
|
|
endif
|
|
|
|
if breathe_v.version_compare('< 4.11')
|
|
error('Use at least breathe version 4.11, found ' + breathe_v)
|
|
endif
|
|
|
|
if doxygen_v.version_compare('< 1.8')
|
|
error('Use at least doxygen version 1.8, found ' + doxygen_v)
|
|
endif
|
|
|
|
if not build_gir
|
|
if get_option('doc').enabled()
|
|
error('Documentation enabled but introspection not built.')
|
|
endif
|
|
endif
|
|
|
|
doxygen_database = meson.current_build_dir() + '/doxygen_doc'
|
|
|
|
# modify the sphinx configuration and the breathe doxygen XML database
|
|
# to point where its being generated by doxygen
|
|
sphinx_conf_data = configuration_data()
|
|
sphinx_conf_data.set('BUILD_ROOT', doxygen_database)
|
|
sphinx_conf_data.set('VERSION', meson.project_version())
|
|
sphinx_conf = configure_file(
|
|
input: 'conf.py.in',
|
|
output: 'conf.py',
|
|
configuration: sphinx_conf_data
|
|
)
|
|
|
|
# build gir
|
|
|
|
doxy_conf_data = configuration_data()
|
|
doxy_conf_data.set('SRC_ROOT', meson.source_root())
|
|
doxy_conf_data.set('OUTPUT_DIR', doxygen_database)
|
|
doxygen_conf_wireplumber = configure_file(
|
|
input: 'doxyfile.in',
|
|
output: 'doxyfile',
|
|
configuration: doxy_conf_data
|
|
)
|
|
|
|
dir_prefix = get_option('prefix')
|
|
dir_data = join_paths(dir_prefix, get_option('datadir'))
|
|
|
|
script_data = configuration_data()
|
|
script_data.set('SRCDIR', meson.current_build_dir())
|
|
script_data.set('OUTDIR', meson.current_build_dir() + '/docs')
|
|
|
|
# Set a different directory for doctrees to avoid installing them
|
|
script_data.set('DOCTREES_DIR', meson.current_build_dir() + '/doctrees')
|
|
|
|
script_data.set('SPHINX_CMD', sphinx_p.path())
|
|
|
|
script_doxy_sphinx = configure_file(
|
|
input: 'run_doxygen_sphinx.sh.in',
|
|
output: 'run_doxygen_sphinx.sh',
|
|
configuration: script_data
|
|
)
|
|
|
|
# copy everything to build_dir, if you plan on adding other files in the top
|
|
# rootdir of sourcedir, please add them here as well, otherwise use 'toc/'s
|
|
# meson.build file
|
|
|
|
sphinx_files = ['index.rst']
|
|
foreach file : sphinx_files
|
|
configure_file(input: file, output: file, copy: true)
|
|
endforeach
|
|
|
|
# and those in toc and api
|
|
subdir('toc')
|
|
subdir('api')
|
|
|
|
sphinx_doc = custom_target(
|
|
'breathe',
|
|
command: script_doxy_sphinx,
|
|
output: 'docs',
|
|
build_by_default: true,
|
|
)
|
|
|
|
# we need this because we will have a stale 'docs' directory
|
|
# and this forces it to be rebuilt
|
|
docs = run_target(
|
|
'docs',
|
|
command: script_doxy_sphinx,
|
|
)
|
|
|
|
install_subdir(
|
|
sphinx_doc.full_path(),
|
|
install_dir: join_paths(dir_data, 'doc', 'wireplumber', 'html'),
|
|
exclude_files: '.buildinfo',
|
|
strip_directory: true,
|
|
)
|