meson:doc: Build libraries documentations
authorThibault Saunier <tsaunier@gnome.org>
Fri, 16 Dec 2016 12:59:25 +0000 (09:59 -0300)
committerThibault Saunier <tsaunier@gnome.org>
Fri, 16 Dec 2016 14:27:31 +0000 (11:27 -0300)
docs/libs/meson.build [new file with mode: 0644]
docs/meson.build [new file with mode: 0644]
meson.build
meson_options.txt

diff --git a/docs/libs/meson.build b/docs/libs/meson.build
new file mode 100644 (file)
index 0000000..94638e6
--- /dev/null
@@ -0,0 +1,24 @@
+types = configure_file(input : 'gst-plugins-base-libs.types',
+  output : 'gst-plugins-base-libs.types',
+  configuration : configuration_data())
+
+ignored_headers = ['pbutils-private.h', 'gsttageditingprivate.h', 'id3v2.h',
+  'kiss_fft_f32.h', 'kiss_fft_f64.h', 'kiss_fftr_f32.h', 'kiss_fftr_f64.h',
+  'kiss_fftr_s16.h', 'kiss_fftr_s32.h', 'kiss_fft_s16.h', 'kiss_fft_s32.h',
+  '_kiss_fft_guts_f32.h', '_kiss_fft_guts_f64.h', '_kiss_fft_guts_s16.h',
+  '_kiss_fft_guts_s16.h', '_kiss_fft_guts_s32.h', '_kiss_fft_guts_s32.h',
+  'pbutils-marshal.h']
+
+gnome.gtkdoc('gst-plugins-base-libs',
+  main_sgml : 'gst-plugins-base-libs-docs.sgml',
+  src_dir : '@0@/../../gst-libs/gst'.format(meson.current_source_dir()),
+  scan_args : ['--deprecated-guards=GST_DISABLE_DEPRECATED',
+               '--ignore-decorators=GST_EXPORT'],
+  ignore_headers : ignored_headers,
+  scanobjs_args : ['--type-init-func=gst_init(NULL,NULL)'],
+  gobject_typesfile : types,
+  content_files : [version_entities],
+  dependencies : [gst_base_dep, app_dep, allocators_dep, audio_dep,
+    fft_dep, pbutils_dep, riff_dep, rtp_dep, rtsp_dep, sdp_dep,
+    tag_dep, video_dep],
+  install : true)
diff --git a/docs/meson.build b/docs/meson.build
new file mode 100644 (file)
index 0000000..a44c239
--- /dev/null
@@ -0,0 +1,11 @@
+docconf = configuration_data()
+
+docconf.set('GST_API_VERSION', api_version)
+docconf.set('PACKAGE_VERSION', gst_version)
+docconf.set('PLUGINDIR', '@0@/lib/gstreamer-1.0'.format(get_option('prefix')))
+
+version_entities = configure_file(input : 'version.entities.in',
+  output : 'version.entities',
+  configuration : docconf)
+
+subdir('libs')
index 2bf2ac7a4a7eed5303e69cdacc2fd8d702f52e27..4f2502d6c35642173c697054069caac0827e1c5c 100644 (file)
@@ -242,6 +242,18 @@ subdir('tools')
 subdir('tests')
 subdir('pkgconfig')
 
+if build_machine.system() == 'windows'
+  message('Disabling gtk-doc while building on Windows')
+elif get_option('disable_gtkdoc')
+  message('gtk-doc is disabled via options')
+else
+  if find_program('gtkdoc-scan', required : false).found()
+    subdir('docs')
+  else
+    message('Not building documentation as gtk-doc was not found')
+  endif
+endif
+
 # Use core_conf after all subdirs have set values
 configure_file(input : 'config.h.meson',
   output : 'config.h',
index b6137906341307866a22347f9dd9db785ef2fa61..f4c9c46410fc2da2f987119782fde0b4d73ab7c6 100644 (file)
@@ -4,3 +4,4 @@ option('use_orc', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto
 option('disable_introspection',
         type : 'boolean', value : false,
         description : 'Whether to disable the introspection generation')
+option('disable_gtkdoc', type : 'boolean', value : false)