2018-12-08 21:31:25 +00:00
|
|
|
project('GStreamer manuals and tutorials', 'c',
|
2019-04-24 14:05:52 +00:00
|
|
|
version: '1.17.0.1',
|
2018-12-08 21:31:25 +00:00
|
|
|
meson_version: '>=0.48.0')
|
2018-11-13 14:29:37 +00:00
|
|
|
|
|
|
|
hotdoc = import('hotdoc')
|
2019-04-26 01:05:06 +00:00
|
|
|
hotdoc_subprojects = []
|
2018-11-13 14:29:37 +00:00
|
|
|
|
|
|
|
apiversion = '1.0'
|
2019-04-26 01:05:06 +00:00
|
|
|
if host_machine.system() == 'windows'
|
|
|
|
pathsep = ';'
|
|
|
|
else
|
|
|
|
pathsep = ':'
|
|
|
|
endif
|
|
|
|
|
2020-04-23 03:51:03 +00:00
|
|
|
python3 = import('python').find_installation()
|
|
|
|
|
|
|
|
built_subprojects = get_option('built_subprojects')
|
|
|
|
if built_subprojects != ''
|
|
|
|
message('Have subprojects list from options')
|
|
|
|
else
|
|
|
|
read_file_contents = '''
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
assert len(sys.argv) >= 2
|
|
|
|
fname = sys.argv[1]
|
|
|
|
|
|
|
|
with open(fname, 'r') as f:
|
|
|
|
for l in f:
|
|
|
|
print(l)
|
|
|
|
'''
|
|
|
|
|
|
|
|
# gst-build will generate this file for us to consume so that subproject
|
|
|
|
# changes can still work
|
|
|
|
fname = join_paths(meson.build_root(), 'GstDocumentedSubprojects')
|
|
|
|
cmdres = run_command(
|
|
|
|
python3,
|
|
|
|
'-c', read_file_contents,
|
|
|
|
fname,
|
|
|
|
)
|
|
|
|
if cmdres.returncode() == 0
|
|
|
|
built_subprojects = cmdres.stdout().strip()
|
|
|
|
message('Have subprojects from file: @0@'.format(fname))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2019-04-26 01:05:06 +00:00
|
|
|
libs = ''
|
|
|
|
plugins_doc = ''
|
|
|
|
deps = []
|
|
|
|
plugins_sitemap = ''
|
2020-04-23 03:51:03 +00:00
|
|
|
if built_subprojects != ''
|
|
|
|
foreach project_name: built_subprojects.split(',')
|
2019-04-26 01:05:06 +00:00
|
|
|
sub = subproject(project_name)
|
|
|
|
if sub.get_variable('build_hotdoc')
|
|
|
|
message('Building @0@ documentation'.format(project_name))
|
|
|
|
|
|
|
|
foreach lib: sub.get_variable('libs_doc')
|
|
|
|
hotdoc_subprojects += [lib]
|
|
|
|
libs += lib.full_path() + pathsep
|
|
|
|
deps += [lib]
|
|
|
|
endforeach
|
|
|
|
|
|
|
|
foreach plugin_doc: sub.get_variable('plugins_doc')
|
|
|
|
plugins_doc += plugin_doc.full_path() + pathsep
|
|
|
|
hotdoc_subprojects += [plugin_doc]
|
|
|
|
deps += [plugin_doc]
|
|
|
|
endforeach
|
|
|
|
else
|
|
|
|
message('@0@ did not build hotdoc documentation, can\'t build API doc'.format(project_name))
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
endif
|
2019-03-06 12:24:19 +00:00
|
|
|
deps += [dependency('gstreamer-' + apiversion, fallback: ['gstreamer', 'gst_dep'])]
|
2019-04-26 01:05:06 +00:00
|
|
|
|
|
|
|
if get_option('use_portal_index')
|
|
|
|
index = 'markdown/index.md'
|
|
|
|
else
|
|
|
|
index = 'markdown/simple-index.md'
|
|
|
|
endif
|
|
|
|
sitemap_gen = find_program('scripts/generate_sitemap.py')
|
|
|
|
sitemap = configure_file(command: [sitemap_gen, '@INPUT@', '@OUTPUT@',
|
2019-11-04 16:01:57 +00:00
|
|
|
'gi-index', libs, plugins_doc],
|
2019-04-26 01:05:06 +00:00
|
|
|
input: 'sitemap.txt',
|
|
|
|
output: 'sitemap.txt')
|
2018-11-13 14:29:37 +00:00
|
|
|
|
2019-08-27 23:07:55 +00:00
|
|
|
html_theme = 'https://github.com/hotdoc/hotdoc_lumen_theme/releases/download/0.999/hotdoc_lumen_theme-0.999.tar.xz?sha256=61088e983e7a5d171f2afc4e270c82f1ca251e38e375658ef230666691418629'
|
2018-11-13 14:29:37 +00:00
|
|
|
|
|
|
|
gstreamer_doc = hotdoc.generate_doc('GStreamer',
|
|
|
|
project_version: apiversion,
|
2019-04-26 01:05:06 +00:00
|
|
|
sitemap: sitemap,
|
|
|
|
index: index,
|
2019-11-04 16:01:57 +00:00
|
|
|
gi_index: index,
|
2018-11-13 14:29:37 +00:00
|
|
|
install: true,
|
|
|
|
extra_assets: [join_paths(meson.current_source_dir(), 'images')],
|
|
|
|
syntax_highlighting_activate: true,
|
|
|
|
html_theme: html_theme,
|
|
|
|
include_paths: join_paths(meson.current_source_dir(), 'examples'),
|
|
|
|
html_extra_theme: join_paths(meson.current_source_dir(), 'theme/extra'),
|
2019-04-26 01:05:06 +00:00
|
|
|
dependencies: deps,
|
|
|
|
subprojects: hotdoc_subprojects,
|
2018-11-13 14:29:37 +00:00
|
|
|
disable_incremental_build: true,
|
2019-05-21 12:18:53 +00:00
|
|
|
gst_list_plugins_page: 'gst-index',
|
|
|
|
gst_index: join_paths(meson.current_source_dir(), 'markdown/plugins_doc.md'),
|
2018-11-13 14:29:37 +00:00
|
|
|
devhelp_activate: true,
|
2019-05-26 10:38:38 +00:00
|
|
|
devhelp_online: 'https://gstreamer.freedesktop.org/documentation/',
|
2019-04-26 01:05:06 +00:00
|
|
|
build_always_stale: true,
|
|
|
|
edit_on_github_repository: 'https://gitlab.freedesktop.org/gstreamer/gst-docs/',
|
2018-12-08 23:28:57 +00:00
|
|
|
)
|
2018-08-15 16:59:25 +00:00
|
|
|
|
|
|
|
cdata = configuration_data()
|
|
|
|
cdata.set('GST_API_VERSION', apiversion)
|
|
|
|
readme = configure_file(input: 'scripts/RELEASE_README.md',
|
|
|
|
output: 'README.md',
|
|
|
|
configuration : cdata)
|
|
|
|
|
|
|
|
run_target('release',
|
|
|
|
command: [find_program('scripts/release.py'),
|
|
|
|
gstreamer_doc.full_path(),
|
|
|
|
'GStreamer-doc-@0@.tar.xz'.format(meson.project_version()),
|
|
|
|
join_paths(meson.current_build_dir(), 'README.md')],
|
|
|
|
depends: [gstreamer_doc]
|
|
|
|
)
|