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.
 
 
 
 
 
 

566 lines
16 KiB

#
# VLC plugins
# This file contains the top-level build definition for VLC
# plugins, in the subdirectories are the actual build definitions
# for the individual plugins.
#
# Module dependencies
# The following section contains dependencies that are needed
# by multiple module types. (There is no need to put dependencies
# here that are used by multiple modules in the same subdirectory)
# Check for X C bindings (XCB)
xcb_auto_option = get_option('xcb').disable_auto_if(host_system == 'darwin' or host_system == 'windows')
xcb_dep = dependency('xcb', version: '>= 1.6', required: xcb_auto_option)
xcb_composite_dep = dependency('xcb-composite', required: xcb_auto_option)
xcb_randr_dep = dependency('xcb-randr', version: '>= 1.3', required: xcb_auto_option)
xcb_render_dep = dependency('xcb-render', required: xcb_auto_option)
xcb_shm_dep = dependency('xcb-shm', version: '>= 1.9.2', required: xcb_auto_option)
xcb_xkb_dep = dependency('xcb-xkb', required: xcb_auto_option)
xcb_keysyms_dep = dependency('xcb-keysyms', version: '>= 0.3.4', required: xcb_auto_option)
xproto_dep = dependency('xproto', required: xcb_auto_option)
xcb_damage_dep = dependency('xcb-damage', required: xcb_auto_option)
xcb_xfixes_dep = dependency('xcb-xfixes', required: xcb_auto_option)
# Check for Wayland
if (host_system != 'darwin' and host_system != 'windows') or get_option('xcb').enabled()
wayland_scanner_dep = dependency('wayland-scanner', version: '>= 1.15',
required: get_option('wayland'), native: true)
wayland_protocols_dep = dependency('wayland-protocols', version: '>= 1.15',
required: get_option('wayland'))
wayland_deps = [
dependency('wayland-client', version: '>= 1.5.91', required: get_option('wayland')),
dependency('wayland-cursor', required: get_option('wayland')),
dependency('wayland-egl', required: get_option('wayland')),
wayland_scanner_dep,
wayland_protocols_dep
]
have_wayland = true
foreach iter_wayland_dep : wayland_deps
if (iter_wayland_dep.found() == false)
message('Wayland disabled. (not all needed dependencies found)')
have_wayland = false
break
endif
endforeach
if have_wayland
wayland_scanner = find_program(
wayland_scanner_dep.get_variable(pkgconfig: 'wayland_scanner'),
native: true
)
wayland_protocols_dir = wayland_protocols_dep.get_variable(pkgconfig: 'pkgdatadir')
endif
else
have_wayland = false
wayland_deps = [disabler()]
endif
# PipeWire
pipewire_dep = dependency('libpipewire-0.3', version: '>= 0.3.64', required: get_option('pipewire'))
# Pulse audio
pulse_dep = dependency('libpulse', version: '>= 6.0', required: get_option('pulse'))
# ALSA
alsa_dep = dependency('alsa', version: '>= 1.0.24', required: get_option('alsa'))
# JACK (TODO: set required based on a get_option())
jack_dep = dependency('jack', version: '>= 1.9.7', required: false)
if not jack_dep.found()
# Try jack1 instead
jack_dep = dependency('jack', version: ['>= 0.120.1', '< 1.0'],
required: false)
endif
frameworks = {}
framework_conditions = [
{
'frameworks': [
'Foundation',
'CoreFoundation',
'Security',
'CoreMedia',
'AVFoundation',
'CoreVideo',
'VideoToolbox',
'AudioToolbox',
'IOKit',
'QuartzCore',
'CoreText',
'CoreAudio',
'CoreImage',
'CoreGraphics',
'AVKit',
],
'condition': host_system == 'darwin'
},
{
'frameworks': [
'Cocoa',
'OpenGL',
'AudioUnit',
],
'condition': have_osx
},
{
'frameworks': [
'UIKit',
'OpenGLES',
],
'condition': have_ios or have_tvos
},
]
foreach framework_spec : framework_conditions
foreach framework_name : framework_spec['frameworks']
if not framework_spec['condition']
# Not-found dependency
frameworks += { framework_name: disabler() }
else
frameworks += { framework_name: dependency(framework_name, required: framework_spec['condition']) }
endif
endforeach
endforeach
# Darwin-specific dependencies
security_dep = frameworks['Security']
coremedia_dep = frameworks['CoreMedia']
avfoundation_dep = frameworks['AVFoundation']
corevideo_dep = frameworks['CoreVideo']
videotoolbox_dep = frameworks['VideoToolbox']
audiotoolbox_dep = frameworks['AudioToolbox']
iokit_dep = frameworks['IOKit']
quartz_dep = frameworks['QuartzCore']
coretext_dep = frameworks['CoreText']
coreaudio_dep = frameworks['CoreAudio']
coreimage_dep = frameworks['CoreImage']
coregraphics_dep = frameworks['CoreGraphics']
avkit_dep = frameworks['AVKit']
# macOS specific dependencies
cocoa_dep = frameworks['Cocoa']
opengl_dep = frameworks['OpenGL']
audiounit_dep = frameworks['AudioUnit']
# iOS/tvOS specific dependencies
uikit_dep = frameworks['UIKit']
opengles_dep = frameworks['OpenGLES']
# Windows-specific dependencies
# WASAPI-related dependency
ksuser_lib = cc.find_library('ksuser',
has_headers: ['audioclient.h'],
required: host_system == 'windows' and get_option('wasapi').enabled())
# Helper libraries for modules
# These are helper libraries used by some modules
# PipeWire helper library
if pipewire_dep.found()
libvlc_pipewire = library('vlc_pipewire',
files('audio_output/vlc_pipewire.c'),
include_directories: [include_directories('audio_output'), vlc_include_dirs],
dependencies: [libvlccore_dep, pipewire_dep],
link_with: [vlc_libcompat],
install: true,
install_dir: libdir_path,
)
else
libvlc_pipewire = disabler()
endif
# Pulse audio helper library
if pulse_dep.found()
libvlc_pulse = library('vlc_pulse',
files('audio_output/vlcpulse.c'),
include_directories: [include_directories('audio_output'), vlc_include_dirs],
dependencies: [libvlccore_dep, pulse_dep],
link_with: [vlc_libcompat],
install: true,
install_dir: libdir_path,
)
else
libvlc_pulse = disabler()
endif
# SRT
srt_dep = dependency('srt', version: '>=1.3.0', required: get_option('srt'))
# libRist
librist_dep = dependency('librist', required: get_option('rist'))
# MTP
mtp_dep = dependency('libmtp', version: '>=1.0.0', required: get_option('mtp'))
# FFmpeg
avformat_dep = dependency('libavformat', version: '>= 58.76.100', required: get_option('avformat'))
avcodec_dep = dependency('libavcodec', version: '>= 58.134.100', required: get_option('avcodec'))
avutil_dep = dependency('libavutil', version: '>= 56.70.100', required: false)
# Freetype, used by text_renderer and ASS access
freetype_dep = dependency('freetype2', 'freetype', required: get_option('freetype'))
# ZVBI, used by Linsys SDI access and VBI/Teletext decoders
zvbi_dep = dependency('zvbi-0.2', version: '>= 0.2.28', required: false)
# rsvg, used by SVG codec and text renderer
rsvg_dep = dependency('librsvg-2.0', version: '>= 2.9.0', required: get_option('rsvg'))
# Rust support
cargo_bin = find_program('cargo', required: get_option('rust'))
# hxxx common helper lib
hxxxhelper_lib = static_library(
'hxxxhelper',
files(
'codec/hxxx_helper.c',
'packetizer/hxxx_nal.c',
'packetizer/hxxx_sei.c',
'packetizer/h264_slice.c',
'packetizer/h264_nal.c',
'packetizer/hevc_nal.c',
),
include_directories: [vlc_include_dirs],
pic: true,
install: false
)
# JSON library
json_bison_files = bison_gen.process('demux/json/grammar.y')
json_lex_files = flex_gen.process('demux/json/lexicon.l')
vlc_json_lib = static_library('vlc_json',
sources: [
json_bison_files,
json_lex_files,
'demux/json/json.c',
],
include_directories: [vlc_include_dirs, 'demux/json/'],
install: false,
pic: true
)
# deinterlace common helper lib
deinterlacecommon_lib = static_library(
'deinterlace_common',
files('video_filter/deinterlace/common.c'),
include_directories: [vlc_include_dirs],
pic: true,
install: false
)
# Array that holds all enabled VLC module dicts
vlc_modules = []
vlc_rust_modules = []
libandroid_env = []
libandroid_utils = []
if host_system == 'android'
libandroid_env = static_library(
'libvlc_android_env',
include_directories: [vlc_include_dirs],
install: false,
pic: true,
sources: [
'video_output/android/env.c',
'video_output/android/env.h',
],
)
libandroid_utils = static_library(
'libvlc_android_utils',
include_directories: [vlc_include_dirs],
install: false,
pic: true,
sources: [
'video_output/android/utils.c',
'video_output/android/utils.h',
],
)
endif
# video chroma modules
subdir('video_chroma')
# codec modules
subdir('codec')
# access modules
subdir('access')
# demux modules
subdir('demux')
# access_output modules
subdir('access_output')
# audio filter modules
subdir('audio_filter')
# audio mixer
subdir('audio_mixer')
# audio output modules
subdir('audio_output')
# control modules
subdir('control')
# gui modules
subdir('gui')
# keystore modules
subdir('keystore')
# logger modules
subdir('logger')
# misc modules
subdir('misc')
# meta engine modules
subdir('meta_engine')
# packetizer modules
subdir('packetizer')
# service discovery modules
subdir('services_discovery')
# stream output modules
subdir('stream_out')
# stream extractor modules
subdir('stream_extractor')
# stream filter modules
subdir('stream_filter')
# spu modules
subdir('spu')
# text renderer modules
subdir('text_renderer')
# video output modules
subdir('video_output')
# video filter modules
subdir('video_filter')
# hardware modules
subdir('hw')
# video splitter modules
subdir('video_splitter')
# visualization modules
subdir('visualization')
# lua module
subdir('lua')
# muxer modules
if get_option('stream_outputs')
subdir('mux')
endif
# Qt check executable
# This has to be declared here as it needs to end up
# in the modules folder, not in gui/qt/ subfolder as
# vlc-static would not find it there.
if qt6_dep.found()
executable('vlc-qt-check',
files('gui/qt/vlc-qt-check.cpp'),
dependencies: [qt6_dep, qt_extra_deps],
include_directories: [vlc_include_dirs],
build_by_default: true,
install: true,
install_dir: pkglibexecdir_path,
c_args : qt_extra_flags,
cpp_args : qt_extra_flags,
link_args : qt_link_args,
)
endif
#
# Common module handling code
#
# In order to reduce boilerplate code, plugins are defined by a
# dictionary which is added to the `vlc_modules` array. This
# array is then iterated over and a library is defined for each
# entry with the needed build definition for a VLC plugin.
#
vlc_plugins_targets = {}
vlc_plugins_targets_array = []
vlc_plugins_manifest = {}
foreach module : vlc_modules
if not module.has_key('name')
error('Got invalid vlc_modules entry without \'name\' key')
endif
if not module.has_key('sources')
error('The vlc_modules entry for ' + module['name'] + ' has no sources')
endif
# This list MUST be kept in sync with the keys used below!
valid_dict_keys = [
'name',
'sources',
'link_with',
'link_args',
'link_depends',
'link_language',
'include_directories',
'dependencies',
'c_args',
'cpp_args',
'objc_args',
'nasm_args',
'extra_files',
'enabled',
'shortname',
]
foreach key : module.keys()
if key not in valid_dict_keys
error('Invalid key \'@0@\' found in vlc_modules entry for \'@1@\''
.format(key, module['name']))
endif
endforeach
vlc_plugins_manifest += {
module['name']: module
}
if not module.get('enabled', true)
continue
endif
common_args = [
'-DMODULE_STRING="@0@"'.format(module['name']),
'-DVLC_DYNAMIC_PLUGIN'
]
kwargs = {}
if module.has_key('link_language')
kwargs += { link_language: module.get('link_language') }
endif
shortname = ''
if module.has_key('shortname')
shortname = module['shortname']
endif
vlc_plugin = library(
module['name'] + '_plugin',
module['sources'],
link_with: [module.get('link_with', []), vlc_libcompat],
link_args: module.get('link_args', []),
link_depends: module.get('link_depends', []),
include_directories: [module.get('include_directories', []), vlc_include_dirs],
dependencies: [module.get('dependencies', []), libvlccore_dep],
c_args: [module.get('c_args', []), common_args],
cpp_args: [module.get('cpp_args', []), common_args],
objc_args: [module.get('objc_args', []), common_args],
nasm_args: [module.get('nasm_args', []), []],
extra_files: module.get('extra_files', []),
build_by_default: true,
install: true,
install_dir: pkglibdir_path / 'plugins',
kwargs: kwargs,
shortname: shortname,
)
vlc_plugins_targets += {
module['name']: vlc_plugin
}
vlc_plugins_targets_array += vlc_plugin
endforeach
# Rust/cargo common handling code
if get_option('rust').enabled()
if get_option('vendored_rust_deps') != 'no'
if get_option('vendored_rust_deps') == 'yes'
cargo_fetch_deps_tgt = custom_target('cargo_fetch_deps',
capture: false,
console: true,
build_by_default: true,
input: files('Cargo.lock'),
output: 'cargo_vendored_deps',
command: [cargo_bin, 'vendor', '--locked', '--versioned-dirs', '--manifest-path',
files('Cargo.toml'), '@OUTPUT@'],
)
vendored_rust_deps_sources = cargo_fetch_deps_tgt.full_path()
module_cargo_depends = [cargo_fetch_deps_tgt]
else
vendored_rust_deps_sources = get_option('vendored_rust_deps')
endif
extra_cargo_args += ['--offline',
'--config', 'source.crates-io.replace-with="vendored-sources"',
'--config', f'source.vendored-sources.directory="@vendored_rust_deps_sources@"']
endif
foreach module : vlc_rust_modules
if not module.has_key('name')
error('Got invalid vlc_rust_modules entry without \'name\' key')
endif
if not module.has_key('sources')
error('The vlc_rust_modules entry for ' + module['name'] + ' has no sources')
endif
if not module.has_key('cargo_toml')
error('The vlc_rust_modules entry for ' + module['name'] + ' has no cargo_toml')
endif
# This list MUST be kept in sync with the keys used below!
valid_dict_keys = [
'name',
'sources',
'cargo_toml',
'link_with',
'link_depends',
'dependencies',
]
foreach key : module.keys()
if key not in valid_dict_keys
error('Invalid key \'@0@\' found in vlc_rust_modules entry for \'@1@\''
.format(key, module['name']))
endif
endforeach
module_cargo = custom_target(module['name'] + '_cargo',
build_by_default: true,
input: module['cargo_toml'],
depends: module_cargo_depends,
depfile: 'lib' + module['name'] + '.d',
output: 'lib' + module['name'] + '.a',
env: {
'RUSTFLAGS': rust_flags,
'CARGO_TARGET_DIR': cargo_target_dir,
},
command: [cargo_output, '--output', '@OUTDIR@', '--depfile',
cargo_bin, 'rustc', '--quiet', '--color=always', '--crate-type=staticlib',
'--locked', extra_cargo_args, '--manifest-path', module['cargo_toml']]
)
library(module['name'] + '_plugin',
# FIXME(meson): `module_cargo` shouldn't be in `link_whole` because it prevents dead code
# elimination but meson doesn't yet have any way of setting the symbols to export and since
# `module_cargo` is an archive file everything is exported so nothing is really.
link_whole: module_cargo,
link_with: module.get('link_with', []),
link_args: [module.get('link_args', []), rust_common_link_args],
link_depends: module.get('link_depends', []),
dependencies: [module.get('dependencies', []), libvlccore_dep],
build_by_default: true,
)
endforeach
endif