project('mpv', 'c', license: ['GPL2+', 'LGPL2.1+'], version: files('./VERSION'), meson_version: '>=0.60.0', default_options: [ 'buildtype=debugoptimized', 'b_lundef=false', 'c_std=c11', 'warning_level=1', ] ) build_root = meson.project_build_root() source_root = meson.project_source_root() python = find_program('python3') ffmpeg = { 'name': 'ffmpeg', 'deps': [dependency('libavutil', version: '>= 56.12.100'), dependency('libavcodec', version: '>= 58.12.100'), dependency('libavformat', version: '>= 58.9.100'), dependency('libswscale', version: '>= 5.0.101'), dependency('libavfilter', version: '>= 7.14.100'), dependency('libswresample', version: '>= 3.0.100')], } libass = dependency('libass', version: '>= 0.12.2') pthreads = dependency('threads') dependencies = [ffmpeg['deps'], libass, pthreads] features = [ffmpeg['name'], libass.name(), pthreads.name()] # Builtin options we'd like to add to features. if get_option('optimization') != '0' features += 'optimize' endif if get_option('debug') features += 'debug' endif # generic sources sources = files( ## Audio 'audio/aframe.c', 'audio/chmap.c', 'audio/chmap_sel.c', 'audio/decode/ad_lavc.c', 'audio/decode/ad_spdif.c', 'audio/filter/af_drop.c', 'audio/filter/af_format.c', 'audio/filter/af_lavcac3enc.c', 'audio/filter/af_scaletempo.c', 'audio/filter/af_scaletempo2.c', 'audio/filter/af_scaletempo2_internals.c', 'audio/fmt-conversion.c', 'audio/format.c', 'audio/out/ao.c', 'audio/out/ao_lavc.c', 'audio/out/ao_null.c', 'audio/out/ao_pcm.c', 'audio/out/buffer.c', ## Core 'common/av_common.c', 'common/av_log.c', 'common/codecs.c', 'common/common.c', 'common/encode_lavc.c', 'common/msg.c', 'common/playlist.c', 'common/recorder.c', 'common/stats.c', 'common/tags.c', 'common/version.c', ## Demuxers 'demux/codec_tags.c', 'demux/cue.c', 'demux/cache.c', 'demux/demux.c', 'demux/demux_cue.c', 'demux/demux_disc.c', 'demux/demux_edl.c', 'demux/demux_lavf.c', 'demux/demux_mf.c', 'demux/demux_mkv.c', 'demux/demux_mkv_timeline.c', 'demux/demux_null.c', 'demux/demux_playlist.c', 'demux/demux_raw.c', 'demux/demux_timeline.c', 'demux/ebml.c', 'demux/packet.c', 'demux/timeline.c', ## Filters 'filters/f_async_queue.c', 'filters/f_autoconvert.c', 'filters/f_auto_filters.c', 'filters/f_decoder_wrapper.c', 'filters/f_demux_in.c', 'filters/f_hwtransfer.c', 'filters/f_lavfi.c', 'filters/f_output_chain.c', 'filters/f_swresample.c', 'filters/f_swscale.c', 'filters/f_utils.c', 'filters/filter.c', 'filters/frame.c', 'filters/user_filters.c', ## Input 'input/cmd.c', 'input/event.c', 'input/input.c', 'input/ipc.c', 'input/keycodes.c', ## Misc 'misc/bstr.c', 'misc/charset_conv.c', 'misc/dispatch.c', 'misc/json.c', 'misc/natural_sort.c', 'misc/node.c', 'misc/rendezvous.c', 'misc/thread_pool.c', 'misc/thread_tools.c', ## Options 'options/m_config_core.c', 'options/m_config_frontend.c', 'options/m_option.c', 'options/m_property.c', 'options/options.c', 'options/parse_commandline.c', 'options/parse_configfile.c', 'options/path.c', ## Player 'player/audio.c', 'player/client.c', 'player/command.c', 'player/configfiles.c', 'player/external_files.c', 'player/loadfile.c', 'player/main.c', 'player/misc.c', 'player/osd.c', 'player/playloop.c', 'player/screenshot.c', 'player/scripting.c', 'player/sub.c', 'player/video.c', ## Streams 'stream/cookies.c', 'stream/stream.c', 'stream/stream_avdevice.c', 'stream/stream_cb.c', 'stream/stream_concat.c', 'stream/stream_edl.c', 'stream/stream_file.c', 'stream/stream_lavf.c', 'stream/stream_memory.c', 'stream/stream_mf.c', 'stream/stream_null.c', 'stream/stream_slice.c', ## Subtitles 'sub/ass_mp.c', 'sub/dec_sub.c', 'sub/draw_bmp.c', 'sub/filter_sdh.c', 'sub/img_convert.c', 'sub/lavc_conv.c', 'sub/osd.c', 'sub/osd_libass.c', 'sub/sd_ass.c', 'sub/sd_lavc.c', ## Video 'video/csputils.c', 'video/decode/vd_lavc.c', 'video/filter/refqueue.c', 'video/filter/vf_format.c', 'video/filter/vf_sub.c', 'video/fmt-conversion.c', 'video/hwdec.c', 'video/image_loader.c', 'video/image_writer.c', 'video/img_format.c', 'video/mp_image.c', 'video/mp_image_pool.c', 'video/out/aspect.c', 'video/out/bitmap_packer.c', 'video/out/dither.c', 'video/out/dr_helper.c', 'video/out/filter_kernels.c', 'video/out/gpu/context.c', 'video/out/gpu/error_diffusion.c', 'video/out/gpu/hwdec.c', 'video/out/gpu/lcms.c', 'video/out/gpu/libmpv_gpu.c', 'video/out/gpu/osd.c', 'video/out/gpu/ra.c', 'video/out/gpu/shader_cache.c', 'video/out/gpu/spirv.c', 'video/out/gpu/user_shaders.c', 'video/out/gpu/utils.c', 'video/out/gpu/video.c', 'video/out/gpu/video_shaders.c', 'video/out/libmpv_sw.c', 'video/out/vo.c', 'video/out/vo_gpu.c', 'video/out/vo_image.c', 'video/out/vo_lavc.c', 'video/out/vo_libmpv.c', 'video/out/vo_null.c', 'video/out/vo_tct.c', 'video/out/win_state.c', 'video/repack.c', 'video/sws_utils.c', ## osdep 'osdep/io.c', 'osdep/semaphore_osx.c', 'osdep/subprocess.c', 'osdep/threads.c', 'osdep/timer.c', ## tree_allocator 'ta/ta.c', 'ta/ta_talloc.c', 'ta/ta_utils.c' ) # compiler stuff cc = meson.get_compiler('c') flags = ['-D_ISOC99_SOURCE', '-D_GNU_SOURCE', '-D_FILE_OFFSET_BITS=64'] link_flags = [] test_flags = ['-Werror=implicit-function-declaration', '-Wno-error=deprecated-declarations', '-Wno-error=unused-function', '-Wempty-body', '-Wdisabled-optimization', '-Wstrict-prototypes', '-Wno-format-zero-length', '-Werror=format-security', '-Wno-redundant-decls', '-Wvla', '-Wno-format-truncation', '-Wimplicit-fallthrough', '-fno-math-errno'] flags += cc.get_supported_arguments(test_flags) if cc.get_id() == 'gcc' gcc_flags = ['-Wundef', '-Wmissing-prototypes', '-Wshadow', '-Wno-switch', '-Wparentheses', '-Wpointer-arith', '-Wno-pointer-sign', # GCC bug 66425 '-Wno-unused-result'] flags += gcc_flags endif if cc.get_id() == 'clang' clang_flags = ['-Wno-logical-op-parentheses', '-Wno-tautological-compare', '-Wno-tautological-constant-out-of-range-compare'] flags += clang_flags endif darwin = host_machine.system() == 'darwin' win32 = host_machine.system() == 'cygwin' or host_machine.system() == 'windows' posix = false if not win32 posix = true features += 'posix' else features += 'win32' endif mswin_flags = ['-D_WIN32_WINNT=0x0602', '-DUNICODE', '-DCOBJMACROS', '-DINITGUID', '-U__STRICT_ANSI__'] mswin_linkflags = ['-Wl,--major-os-version=6,--minor-os-version=0', '-Wl,--major-subsystem-version=6,--minor-subsystem-version=0'] if host_machine.system() == 'windows' flags += [mswin_flags, '-D__USE_MINGW_ANSI_STDIO=1'] link_flags += [mswin_linkflags, '-mwindows'] endif if host_machine.system() == 'cygwin' features += 'cygwin' flags += [mswin_flags, '-mwin32'] link_flags += mswin_linkflags endif noexecstack = false if cc.has_link_argument('-Wl,-z,noexecstack') link_flags += '-Wl,-z,noexecstack' noexecstack = true endif if cc.has_link_argument('-Wl,--nxcompat,--no-seh,--dynamicbase') link_flags += '-Wl,--nxcompat,--no-seh,--dynamicbase' noexecstack = true endif if noexecstack features += 'noexecstack' endif if not get_option('build-date') flags += '-DNO_BUILD_TIMESTAMPS' else features += 'build-date' endif if get_option('ta-leak-report') features += 'ta-leak-report' endif libdl = cc.find_library('libdl', required: false) if libdl.found() dependencies += libdl features += 'libdl' endif cplugins = get_option('cplugins').require( libdl.found() and not win32 and cc.has_link_argument('-rdynamic'), error_message: 'cplugins not supported by the os or compiler!', ) if cplugins.allowed() features += 'cplugins' link_flags += '-rdynamic' endif if get_option('tests') features += 'tests' sources += files('test/champ.c', 'test/gl_video.c', 'test/img_format.c', 'test/json.c', 'test/linked_list.c', 'test/paths.c', 'test/scale_sws.c', 'test/scale_test.c', 'test/tests.c') endif includedir = [] win32_pthreads = get_option('win32-internal-pthreads').require( win32 and not posix, error_message: 'the os is not win32!', ) if win32_pthreads.allowed() features += 'win32-internal-pthreads' flags += ['-isystem', '-I', '-DIN_WINPTHREAD'] # Note: Adding this include causes POSIX_TIMERS to be defined for # unclear reasons (some confusion with probably). # Hack around it by using HAVE_WIN32_INTERNAL_PTHREADS. includedir += include_directories('osdep/win32/include') sources += files('osdep/win32/pthread.c') endif pthread_debug = get_option('pthread-debug').require( win32_pthreads.disabled(), error_message: 'win32-internal-pthreads was found!', ) if pthread_debug.allowed() features += 'pthread-debug' flags += '-DMP_PTHREAD_DEBUG' endif add_project_arguments(flags, language: 'c') add_project_link_arguments(link_flags, language: ['c', 'objc']) # osdep cocoa = dependency('appleframeworks', modules: ['Cocoa', 'IOKit', 'QuartzCore'], required: get_option('cocoa')) if cocoa.found() dependencies += cocoa features += 'cocoa' sources += files('osdep/macosx_application.m', 'osdep/macosx_events.m', 'osdep/macosx_menubar.m', 'osdep/main-fn-cocoa.c', 'osdep/path-macosx.m', 'video/out/cocoa_common.m', 'video/out/cocoa/events_view.m', 'video/out/cocoa/video_view.m', 'video/out/cocoa/window.m') endif if posix sources += files('input/ipc-unix.c', 'osdep/path-unix.c', 'osdep/polldev.c', 'osdep/subprocess-posix.c', 'osdep/terminal-unix.c', 'sub/filter_regex.c') endif if posix and not cocoa.found() sources += files('osdep/main-fn-unix.c') endif if darwin sources += files('osdep/timer-darwin.c') endif if posix and not darwin sources += files('osdep/timer-linux.c') endif cd_devices = { 'windows': 'D:', 'cygwin': 'D:', 'darwin': '/dev/disk1', 'freebsd': '/dev/cd0', 'openbsd': '/dev/rcd0c', 'linux': '/dev/sr0', } if host_machine.system() in cd_devices cd_device = cd_devices[host_machine.system()] else cd_device = '/dev/cdrom' endif dvd_devices = { 'windows': 'D:', 'cygwin': 'D:', 'darwin': '/dev/diskN', 'freebsd': '/dev/cd0', 'openbsd': '/dev/rcd0c', 'linux': '/dev/sr0', } if host_machine.system() in cd_devices dvd_device = dvd_devices[host_machine.system()] else dvd_device = '/dev/dvd' endif android = host_machine.system() == 'android' if android features += 'android' sources += files('audio/out/ao_audiotrack.c', 'video/out/android_common.c', 'video/out/vo_mediacodec_embed.c') endif uwp_opt = get_option('uwp').require( not get_option('cplayer'), error_message: 'cplayer is not false!', ) uwp = cc.find_library('windowsapp', required: uwp_opt) if uwp.found() dependencies += uwp features += 'uwp' sources += files('osdep/path-uwp.c') endif if win32 sources += files('osdep/timer-win2.c', 'osdep/w32_keyboard.c', 'osdep/windows_utils.c') endif win32_desktop = win32 and not uwp.found() if win32_desktop win32_desktop_libs = [cc.find_library('avrt'), cc.find_library('dwmapi'), cc.find_library('gdi32'), cc.find_library('ole32'), cc.find_library('uuid'), cc.find_library('version'), cc.find_library('winmm')] dependencies += win32_desktop_libs features += 'win32-desktop' sources += files('input/ipc-win.c', 'osdep/main-fn-win.c', 'osdep/path-win.c', 'osdep/subprocess-win.c', 'osdep/terminal-win.c', 'video/out/w32_common.c', 'video/out/win32/displayconfig.c', 'video/out/win32/droptarget.c') endif if not posix and not win32_desktop sources += files('input/ipc-dummy.c', 'osdep/subprocess-dummy.c', 'osdep/terminal-dummy.c') endif glob_posix = cc.has_function('glob', prefix: '#include ') if glob_posix features += 'glob_posix' endif glob_win32 = win32 and not posix if glob_win32 features += 'glob_win32' sources += files('osdep/glob-win.c') endif glob = glob_posix or glob_win32 if glob features += 'glob' endif vt_h = cc.has_header_symbol('sys/vt.h', 'VT_GETMODE') if vt_h features += 'vt.h' endif consio_h = cc.has_header_symbol('sys/consio.h', 'VT_GETMODE') if consio_h features += 'consio.h' endif fragments = join_paths(source_root, 'waftools', 'fragments') glibc_thread_name = cc.compiles(files(join_paths(fragments, 'glibc_thread_name.c')), name: 'glibc-thread-name check') if glibc_thread_name and posix features += 'glibc-thread-name' endif osx_thread_name = false if not glibc_thread_name osx_thread_name = cc.compiles(files(join_paths(fragments, 'osx_thread_name.c')), name: 'osx-thread-name check') if osx_thread_name features += 'osx-thread-name' endif endif bsd_thread_name = false if not osx_thread_name and not glibc_thread_name bsd_thread_name = cc.compiles(files(join_paths(fragments, 'bsd_thread_name.c')), name: 'bsd-thread-name check') if bsd_thread_name and posix features += 'bsd-thread-name' endif endif vector = cc.compiles(files(join_paths(fragments, 'vector.c')), name: 'vector check') if vector features += 'vector' elif get_option('vector').enabled() error('vector enabled but it could not be found!') endif bsd_fstatfs = cc.has_function('fstatfs', prefix: '#include \n#include ') if bsd_fstatfs features += 'bsd-fstatfs' endif linux_fstatfs = cc.has_function('fstatfs', prefix: '#include ') if linux_fstatfs features += 'linux-fstatfs' endif # various file generations tools_directory = join_paths(source_root, 'TOOLS') file2string = find_program(join_paths(tools_directory, 'file2string.py')) matroska = find_program(join_paths(tools_directory, 'matroska.py')) version_py = find_program(join_paths(source_root, 'version.py')) subdir('generated') subdir(join_paths('generated', 'etc')) subdir(join_paths('generated', 'sub')) if darwin subdir(join_paths('generated', 'TOOLS', 'osxbundle', 'mpv.app', 'Contents', 'Resources')) endif # The following should be removed in 2022 or if libavformat requirement # is bumped to >= 59.8.100 aviocontext_bytes_read = cc.has_member('AVIOContext', 'bytes_read', prefix: '#include ') # misc dependencies cdda_opt = get_option('cdda').require( get_option('gpl'), error_message: 'the build is not GPL!', ) cdda = dependency('libcdio_paranoia', required: cdda_opt) if cdda.found() dependencies += cdda features += 'cdda' sources += files('stream/stream_cdda.c') endif dvbin = get_option('dvbin').require( get_option('gpl'), error_message: 'the build is not GPL!', ) if dvbin.allowed() features += 'dvbin' sources += files('stream/dvb_tune.c', 'stream/stream_dvb.c') endif dvdnav_opt = get_option('dvdnav').require( get_option('gpl'), error_message: 'the build is not GPL!', ) dvdnav = dependency('dvdnav', version: '>= 4.2.0', required: dvdnav_opt) dvdread = dependency('dvdread', version: '>= 4.1.0', required: dvdnav_opt) if dvdnav.found() and dvdread.found() dependencies += [dvdnav, dvdread] features += 'dvdnav' sources += files('stream/stream_dvdnav.c') endif iconv = dependency('iconv', required: get_option('iconv')) if iconv.found() # It is possible for FreeBSD to also have GNU's libiconv installed. # We don't need this since mpv does not use any GNU-specific features. # Get iconv via the system method instead in this case. if host_machine.system() == 'freebsd' iconv = dependency('iconv', method: 'system') endif dependencies += iconv features += 'iconv' endif javascript = dependency('mujs', version: '>= 1.0.0', required: get_option('javascript')) if javascript.found() dependencies += javascript features += 'javascript' sources += files('player/javascript.c', 'sub/filter_jsre.c') subdir(join_paths('generated', 'player', 'javascript')) endif lcms2 = dependency('lcms2', version: '>= 2.6', required: get_option('lcms2')) if lcms2.found() dependencies += lcms2 features += 'lcms2' endif libarchive = dependency('libarchive', version: '>= 3.4.0', required: get_option('libarchive')) if libarchive.found() dependencies += libarchive features += 'libarchive' sources += files('demux/demux_libarchive.c', 'stream/stream_libarchive.c') endif libavdevice = dependency('libavdevice', version: '>= 57.0.0', required: get_option('libavdevice')) if libavdevice.found() dependencies += libavdevice features += 'libavdevice' endif libbluray = dependency('libbluray', version: '>= 0.3.0', required: get_option('libbluray')) if libbluray.found() dependencies += libbluray features += 'libbluray' sources += files('stream/stream_bluray.c') endif libm = cc.find_library('m', required: false) if libm.found() dependencies += libm features += 'libm' endif librt = cc.find_library('rt', required: false) if librt.found() dependencies += librt features += 'librt' endif lua = { 'name': 'lua', 'use': false, } lua_opt = get_option('lua') if lua_opt != 'disabled' lua_version = [['lua52', '>= 5.2.0'], ['lua5.2', '>= 5.2.0'], ['lua-5.2', '>= 5.2.0'], ['luajit', '>= 2.0.0'], ['lua51', '>= 5.1.0'], ['lua5.1', '>= 5.1.0'], ['lua-5.1', '>= 5.1.0']] foreach version : lua_version if lua_opt == 'auto' or lua_opt == 'enabled' lua += {'deps': dependency(version[0], version: version[1], required: false)} if lua['deps'].found() lua += {'use': true} break endif elif lua_opt == version[0] lua += {'deps': dependency(version[0], version: version[1])} if lua['deps'].found() lua += {'use': true} break endif endif endforeach endif # Dumb hack for macOS if we're using luajit so the shared libary compiles. # The partial dependency is only used for libmpv and not mpv itself. # https://github.com/Homebrew/homebrew-core/issues/37169 luajit_full = dependency('', required: false) luajit_partial = dependency('', required: false) if lua['use'] if darwin and lua['deps'].name() == 'luajit' luajit_full = lua['deps'] luajit_partial = lua['deps'].partial_dependency(compile_args: true, link_args: false, links: true, includes: true, sources: true) else dependencies += lua['deps'] endif features += lua['deps'].name() sources += files('player/lua.c') subdir(join_paths('generated', 'player', 'lua')) endif if not lua['use'] and lua_opt == 'enabled' error('lua enabled but no suitable lua version could be found!') endif rubberband = dependency('rubberband', version: '>= 1.8.0', required: get_option('rubberband')) if rubberband.found() dependencies += rubberband features += 'rubberband' sources += files('audio/filter/af_rubberband.c') endif sdl2 = dependency('sdl2', required: get_option('sdl2')) if sdl2.found() dependencies += sdl2 features += 'sdl2' endif sdl2_gamepad = get_option('sdl2-gamepad').require( sdl2.found(), error_message: 'sdl2 was not found!', ) if sdl2_gamepad.allowed() features += 'sdl2-gamepad' sources += files('input/sdl_gamepad.c') endif stdatomic = cc.find_library('atomic', required: get_option('stdatomic')) if stdatomic.found() dependencies += stdatomic features += 'stdatomic' endif uchardet = dependency('uchardet', required: get_option('uchardet')) if iconv.found() and uchardet.found() dependencies += uchardet features += 'uchardet' endif vapoursynth = dependency('vapoursynth', version: '>= 24', required: get_option('vapoursynth')) vapoursynth_script = dependency('vapoursynth-script', version: '>= 23', required: get_option('vapoursynth')) if vapoursynth.found() and vapoursynth_script.found() dependencies += [vapoursynth, vapoursynth_script] features += 'vapoursynth' sources += files('video/filter/vf_vapoursynth.c') endif zimg = dependency('zimg', version: '>= 2.9', required: get_option('zimg')) if zimg.found() dependencies += zimg features += 'zimg' sources += files('video/filter/vf_fingerprint.c', 'video/zimg.c') if get_option('tests') sources += files('test/repack.c', 'test/scale_zimg.c') endif endif zlib = dependency('zlib', required: get_option('zlib')) if zlib.found() dependencies += zlib features += 'zlib' endif # audio output dependencies alsa = dependency('alsa', version: '>= 1.0.18', required: get_option('alsa')) if alsa.found() dependencies += alsa features += 'alsa' sources += files('audio/out/ao_alsa.c') endif audiounit = { 'name': 'audiounit', 'deps': dependency('appleframeworks', modules: ['Foundation', 'AudioToolbox'], required: get_option('audiounit')), 'symbol': cc.has_header_symbol('AudioToolbox/AudioToolbox.h', 'kAudioUnitSubType_RemoteIO', required: get_option('audiounit')), 'use': false, } if audiounit['deps'].found() and audiounit['symbol'] dependencies += audiounit['deps'] features += 'audiounit' sources += files('audio/out/ao_audiounit.m') audiounit += {'use': true} endif coreaudio = dependency('appleframeworks', modules: ['CoreFoundation', 'CoreAudio', 'AudioUnit', 'AudioToolbox'], required: get_option('coreaudio')) if coreaudio.found() dependencies += coreaudio features += 'coreaudio' sources += files('audio/out/ao_coreaudio.c', 'audio/out/ao_coreaudio_exclusive.c', 'audio/out/ao_coreaudio_properties.c') endif if audiounit['use'] or coreaudio.found() sources += files('audio/out/ao_coreaudio_chmap.c', 'audio/out/ao_coreaudio_utils.c') endif jack_opt = get_option('jack').require( get_option('gpl'), error_message: 'the build is not GPL!', ) jack = dependency('jack', required: jack_opt) if jack.found() dependencies += jack features += 'jack' sources += files('audio/out/ao_jack.c') endif openal = dependency('openal', version: '>= 1.13', required: get_option('openal')) if openal.found() dependencies += openal features += 'openal' sources += files('audio/out/ao_openal.c') endif opensles = cc.find_library('OpenSLES', required: get_option('opensles')) if opensles.found() dependencies += opensles features += 'opensles' sources += files('audio/out/ao_opensles.c') endif oss_opt = get_option('oss-audio').require( get_option('gpl'), error_message: 'the build is not GPL!', ) oss = cc.has_header_symbol('sys/soundcard.h', 'SNDCTL_DSP_SETPLAYVOL', required: oss_opt) if oss features += 'oss-audio' sources += files('audio/out/ao_oss.c') endif pulse = dependency('libpulse', version: '>= 1.0', required: get_option('pulse')) if pulse.found() dependencies += pulse features += 'pulse' sources += files('audio/out/ao_pulse.c') endif sdl2_audio = get_option('sdl2-audio').require( sdl2.found(), error_message: 'sdl2 was not found!', ) if sdl2_audio.allowed() features += 'sdl2-audio' sources += files('audio/out/ao_sdl.c') endif wasapi = cc.has_header_symbol('audioclient.h', 'IAudioClient', required: get_option('wasapi')) if wasapi features += 'wasapi' sources += files('audio/out/ao_wasapi.c', 'audio/out/ao_wasapi_changenotify.c', 'audio/out/ao_wasapi_utils.c') endif # video output dependencies caca_opt = get_option('caca').require( get_option('gpl'), error_message: 'the build is not GPL!', ) caca = dependency('caca', version: '>= 0.99.beta18', required: caca_opt) if caca.found() dependencies += caca features += 'caca' sources += files('video/out/vo_caca.c') endif direct3d_opt = get_option('direct3d').require( get_option('gpl') and win32_desktop, error_message: 'the build is not GPL or this is not a win32 desktop!', ) direct3d = cc.check_header('d3d9.h', required: direct3d_opt) if direct3d features += 'direct3d' sources += files('video/out/vo_direct3d.c') endif drm = { 'name': 'drm', 'deps': dependency('libdrm', version: '>= 2.4.75', required: get_option('drm')), 'header': vt_h or consio_h, } drm += {'use': drm['deps'].found() and drm['header']} if drm['use'] dependencies += drm['deps'] features += drm['name'] sources += files('video/out/drm_atomic.c', 'video/out/drm_common.c', 'video/out/drm_prime.c', 'video/out/opengl/hwdec_drmprime_drm.c', 'video/out/vo_drm.c') endif gbm = dependency('gbm', version: '>=17.1.0', required: get_option('gbm')) if gbm.found() dependencies += gbm features += 'gbm' endif jpeg = dependency('libjpeg', required: get_option('jpeg')) if jpeg.found() dependencies += jpeg features += 'jpeg' endif libplacebo_v4 = false libplacebo = dependency('libplacebo', version: '>=3.104.0', required: get_option('libplacebo')) if libplacebo.found() dependencies += libplacebo features += 'libplacebo' sources += files('video/out/placebo/ra_pl.c', 'video/out/placebo/utils.c') pl_api_ver = libplacebo.version().split('.')[1] if pl_api_ver.version_compare('>=170') features += 'libplacebo-v4' libplacebo_v4 = true sources += files('video/out/vo_gpu_next.c') endif endif sdl2_video = get_option('sdl2-video').require( sdl2.found(), error_message: 'sdl2 was not found!', ) if sdl2_video.allowed() features += 'sdl2-video' sources += files('video/out/vo_sdl.c') endif shaderc = dependency('shaderc', 'shaderc_static', required: get_option('shaderc')) if shaderc.found() dependencies += shaderc features += shaderc.name() sources += files('video/out/gpu/spirv_shaderc.c') endif sixel = dependency('libsixel', version: '>= 1.5', required: get_option('sixel')) if sixel.found() dependencies += sixel features += 'sixel' sources += files('video/out/vo_sixel.c') endif spirv_cross = dependency('spirv-cross-c-shared', required: get_option('spirv-cross')) if spirv_cross.found() features += 'spirv-cross' dependencies += spirv_cross endif d3d11 = { 'name': 'd3d11', 'use': win32_desktop and shaderc.found() and spirv_cross.found() and get_option('d3d11').allowed(), } d3d11 = get_option('d3d11').require( win32_desktop and shaderc.found() and spirv_cross.found(), error_message: 'Either is not a win32 desktop or shaderc nor spirv-cross were found!', ) if d3d11.allowed() features += 'd3d11' sources += files('video/out/d3d11/context.c', 'video/out/d3d11/ra_d3d11.c') endif wayland = { 'name': 'wayland', 'deps': [dependency('wayland-client', version: '>= 1.15.0', required: get_option('wayland')), dependency('wayland-cursor', version: '>= 1.15.0', required: get_option('wayland')), dependency('wayland-protocols', required: get_option('wayland')), dependency('xkbcommon', version: '>= 0.3.0', required: get_option('wayland'))], 'header': cc.check_header('linux/input-event-codes.h', required: get_option('wayland')), 'scanner': find_program('wayland-scanner', required: get_option('wayland')), 'use': true, } foreach dep: wayland['deps'] if not dep.found() wayland += {'use': false} break endif endforeach if not wayland['header'] or not wayland['scanner'].found() wayland += {'use': false} endif if wayland['use'] features += wayland['name'] subdir(join_paths('generated', 'wayland')) endif memfd_create = false if wayland['use'] memfd_create = cc.has_function('memfd_create', prefix: '#define _GNU_SOURCE\n#include ') endif if wayland['use'] and memfd_create features += 'memfd_create' sources += files('video/out/vo_wlshm.c') endif x11_opt = get_option('x11').require( get_option('gpl'), error_message: 'the build is not GPL!', ) x11 = { 'name': 'x11', 'deps': [dependency('x11', version: '>= 1.0.0', required: x11_opt), dependency('xscrnsaver', version: '>= 1.0.0', required: x11_opt), dependency('xext', version: '>= 1.0.0', required: x11_opt), dependency('xinerama', version: '>= 1.0.0', required: x11_opt), dependency('xrandr', version: '>= 1.2.0', required: x11_opt)], 'use': true, } foreach dep: x11['deps'] if not dep.found() x11 += {'use': false} break endif endforeach if x11['use'] dependencies += x11['deps'] features += x11['name'] sources += files('video/out/vo_x11.c', 'video/out/x11_common.c') endif xv = dependency('xv', required: get_option('xv')) if xv.found() dependencies += xv features += 'xv' sources += files('video/out/vo_xv.c') endif # OpenGL feature checking gl = { 'name': 'gl', 'opt': get_option('gl').allowed(), 'use': false, } GL = dependency('', required: false) if darwin GL = dependency('appleframeworks', modules: 'OpenGL', required: get_option('gl-cocoa')) elif win32_desktop GL = dependency('GL', required: get_option('gl-win32')) elif x11['use'] GL = dependency('GL', required: get_option('gl-x11')) endif gl_cocoa = get_option('gl-cocoa').require( cocoa.found() and GL.found() and gl['opt'], error_message: 'cocoa and GL were not found!', ) if gl_cocoa.allowed() dependencies += GL features += 'gl-cocoa' gl += {'use': true} sources += files('video/out/opengl/context_cocoa.c') endif gl_win32 = get_option('gl-win32').require( GL.found() and gl['opt'] and win32_desktop, error_message: 'GL and win32 desktop were not found!', ) if gl_win32.allowed() dependencies += GL features += 'gl-win32' gl += {'use': true} sources += files('video/out/opengl/context_win.c') endif gl_x11 = get_option('gl-x11').require( GL.found() and gl['opt'] and x11['use'], error_message: 'GL and x11 were not found!', ) if gl_x11.allowed() dependencies += GL features += 'gl-x11' gl += {'use': true} sources += files('video/out/opengl/context_glx.c') endif gl_dxinterop_d3d = cc.has_header_symbol('GL/wglext.h', 'WGL_ACCESS_READ_ONLY_NV', prefix: '#include ') gl_dxinterop_gl = cc.has_header_symbol('d3d9.h', 'IDirect3D9Ex') gl_dxinterop = get_option('gl-dxinterop').require( gl_dxinterop_d3d and gl_dxinterop_gl and gl_win32.allowed(), error_message: 'gl-dxinterop could not be found!', ) if gl_dxinterop.allowed() features += 'gl-dxinterop' sources += files('video/out/opengl/context_dxinterop.c') endif egl_angle = get_option('egl-angle').require( cc.has_header_symbol('GL/eglext.h', 'EGL_D3D_TEXTURE_2D_SHARE_HANDLE_ANGLE', prefix: '#include ') and gl_win32.allowed(), error_message: 'egl-angle could not be found!', ) if egl_angle.allowed() features += 'egl-angle' sources += files('video/out/opengl/angle_dynamic.c') endif egl_angle_lib = get_option('egl-angle-lib').require( cc.has_function('eglCreateWindowSurface', prefix: '#include ') and \ egl_angle.allowed(), error_message: 'egl-angle-lib could not be found!', ) if egl_angle_lib.allowed() features += 'egl-angle-lib' endif egl_angle_win32 = get_option('egl-angle-win32').require( egl_angle.allowed() and win32_desktop, error_message: 'either this is not a win32 desktop or egl-angle was not found!', ) if egl_angle_win32.allowed() features += 'egl-angle-win32' sources += files('video/out/opengl/context_angle.c') endif if d3d11.allowed() or egl_angle_win32.allowed() sources += files('video/out/gpu/d3d11_helpers.c') endif egl = { 'name': 'egl', 'deps': dependency('egl', version: '> 1.4.0', required: get_option('egl')), 'use': false, } egl += {'use': egl['deps'].found() and gl['opt']} if egl['use'] dependencies += egl['deps'] features += egl['name'] endif egl_android = get_option('egl-android').require( android and egl['use'] and gl['opt'], error_message: 'either this os is not android or egl was not found!', ) if egl_android.allowed() features += 'egl-android' gl += {'use': true} sources += files('video/out/opengl/context_android.c') endif egl_drm = get_option('egl-drm').require( drm['use'] and egl['use'] and gbm.found() and gl['opt'], error_message: 'either drm, egl, or gbm could not be found!', ) if egl_drm.allowed() features += 'egl-drm' gl += {'use': true} sources += files('video/out/opengl/context_drm_egl.c') endif egl_wayland = { 'name': 'egl-wayland', 'deps': dependency('wayland-egl', version: '>= 9.0.0', required: get_option('egl-wayland')), 'use': false, } egl_wayland += {'use': egl['use'] and egl_wayland['deps'].found() and gl['opt'] and wayland['use']} if egl_wayland['use'] dependencies += egl_wayland['deps'] features += egl_wayland['name'] gl += {'use': true} sources += files('video/out/opengl/context_wayland.c') endif egl_x11 = get_option('egl-x11').require( egl['use'] and gl['opt'] and x11['use'], error_message: 'either egl or x11 could not be found!', ) if egl_x11.allowed() features += 'egl-x11' gl += {'use': true} sources += files('video/out/opengl/context_x11egl.c') endif if egl_x11.allowed() or gl_x11.allowed() sources += files('video/out/opengl/oml_sync.c') endif plain_gl = get_option('plain-gl').require( get_option('libmpv') and gl['opt'], error_message: 'libmpv was not enabled!', ) if plain_gl.allowed() features += 'plain-gl' gl += {'use': true} endif rpi = { 'name': 'rpi', 'deps': dependency('/opt/vc/lib/pkgconfig/brcmegl.pc', 'brcmegl', required: get_option('rpi')), 'use': false, } rpi += {'use': gl['opt'] and rpi['deps'].found()} if rpi['use'] dependencies += rpi['deps'] features += rpi['name'] gl += {'use': true} sources += files('video/out/opengl/context_rpi.c') endif egl_helpers = egl['use'] or egl_angle_win32.allowed() or rpi['use'] if egl_helpers features += 'egl-helpers' sources += files('video/out/opengl/egl_helpers.c') endif if egl['use'] and egl_helpers sources += files('video/filter/vf_gpu.c') endif if gl['use'] features += 'gl' sources += files('video/out/opengl/common.c', 'video/out/opengl/context.c', 'video/out/opengl/formats.c', 'video/out/opengl/libmpv_gl.c', 'video/out/opengl/ra_gl.c', 'video/out/opengl/utils.c') elif not gl['use'] and get_option('gl').enabled() error('gl enabled but no OpenGL video output could be found!') endif # vulkan vulkan = dependency('vulkan', required: get_option('vulkan')) if vulkan.found() and libplacebo.found() dependencies += vulkan features += 'vulkan' sources += files('video/out/vulkan/context.c', 'video/out/vulkan/context_display.c', 'video/out/vulkan/utils.c') endif if vulkan.found() and libplacebo.found() and android sources += files('video/out/vulkan/context_android.c') endif if vulkan.found() and libplacebo.found() and wayland['use'] sources += files('video/out/vulkan/context_wayland.c') endif if vulkan.found() and libplacebo.found() and win32_desktop sources += files('video/out/vulkan/context_win.c') endif if vulkan.found() and libplacebo.found() and x11['use'] sources += files('video/out/vulkan/context_xlib.c') endif # hwaccel ffnvcodec = dependency('ffnvcodec', version: '>= 8.2.15.7', required: false) if ffnvcodec.found() dependencies += ffnvcodec features += 'ffnvcodec' sources += files('video/cuda.c') endif cuda_hwaccel = get_option('cuda-hwaccel').require( ffnvcodec.found(), error_message: 'ffnvcodec was not found!', ) if cuda_hwaccel.allowed() features += 'cuda-hwaccel' sources += files('video/out/hwdec/hwdec_cuda.c') endif cuda_interop = get_option('cuda-interop').require( cuda_hwaccel.allowed() and (gl['use'] or libplacebo.found() and vulkan.found()), error_message: 'cuda-hwaccel and either gl or vulkan were not found!', ) if cuda_interop.allowed() and gl['use'] features += 'cuda-interop' sources += files('video/out/hwdec/hwdec_cuda_gl.c') endif if cuda_interop.allowed() and vulkan.found() and libplacebo.found() sources += files('video/out/hwdec/hwdec_cuda_vk.c') endif d3d_hwaccel = get_option('d3d-hwaccel').require( win32, error_message: 'the os is not win32!', ) if d3d_hwaccel.allowed() features += 'd3d_hwaccel' sources += files('video/d3d.c', 'video/filter/vf_d3d11vpp.c') endif if d3d_hwaccel.allowed() and egl_angle.allowed() sources += files('video/out/opengl/hwdec_d3d11egl.c') endif if d3d_hwaccel.allowed() and d3d11.allowed() sources += files('video/out/d3d11/hwdec_d3d11va.c') endif d3d9_hwaccel = get_option('d3d9-hwaccel').require( d3d_hwaccel.allowed(), error_message: 'd3d-hwaccel was not found!', ) if d3d9_hwaccel.allowed() and egl_angle.allowed() features += 'd3d9_hwaccel' sources += files('video/out/opengl/hwdec_dxva2egl.c') endif if d3d9_hwaccel.allowed() and d3d11.allowed() sources += files('video/out/d3d11/hwdec_dxva2dxgi.c') endif gl_dxinterop_d3d9 = get_option('gl-dxinterop-d3d9').require( gl_dxinterop.allowed() and d3d9_hwaccel.allowed(), error_message: 'gl-dxinterop and d3d9-hwaccel were not found!', ) if gl_dxinterop_d3d9.allowed() features += 'gl-dxinterop-d3d9' sources += files('video/out/opengl/hwdec_dxva2gldx.c') endif ios_gl = cc.has_header_symbol('OpenGLES/ES3/glext.h', 'GL_RGB32F', required: get_option('ios-gl')) if ios_gl features += 'ios-gl' sources += files('video/out/opengl/hwdec_ios.m') endif rpi_mmal = dependency('/opt/vc/lib/pkgconfig/mmal.pc', 'mmal', required: get_option('rpi-mmal')) if rpi['use'] and rpi_mmal.found() dependencies += rpi_mmal features += 'rpi-mmal' sources += files('video/out/opengl/hwdec_rpi.c', 'video/out/vo_rpi.c') endif vaapi = { 'name': 'vaapi', 'deps': dependency('libva', version: '>= 1.1.0', required: get_option('vaapi')), } vaapi += {'use': vaapi['deps'].found() and libdl.found() and (x11['use'] or wayland['use'] or egl_drm['use'])} if vaapi['use'] dependencies += vaapi['deps'] features += vaapi['name'] sources += files('video/filter/vf_vavpp.c', 'video/vaapi.c') endif vaapi_drm = { 'name': 'vaapi-drm', 'deps': dependency('libva-drm', version: '>= 1.1.0', required: get_option('vaapi-drm')), } vaapi_drm += {'use': vaapi['use'] and egl_drm.allowed() and vaapi_drm['deps'].found()} if vaapi_drm['use'] features += vaapi_drm['name'] endif vaapi_wayland = { 'name': 'vaapi-wayland', 'deps': dependency('libva-wayland', version: '>= 1.1.0', required: get_option('vaapi-wayland')), } vaapi_wayland += {'use': vaapi['use'] and egl_wayland['use'] and vaapi_wayland['deps'].found()} if vaapi_wayland['use'] features += vaapi_wayland['name'] endif vaapi_x11 = { 'name': 'vaapi-x11', 'deps': dependency('libva-x11', version: '>= 1.1.0', required: get_option('vaapi-x11')), } vaapi_x11 += {'use': vaapi['use'] and x11['use'] and vaapi_x11['deps'].found()} if vaapi_x11['use'] dependencies += vaapi_x11['deps'] features += vaapi_x11['name'] sources += files('video/out/vo_vaapi.c') endif vaapi_x_egl = { 'name': 'vaapi-x-egl', 'use': vaapi_x11['use'] and egl_x11.allowed(), } if vaapi_x_egl['use'] features += vaapi_x_egl['name'] endif vaapi_egl = { 'name': 'vaapi-egl', 'use': vaapi_x_egl['use'] or vaapi_wayland['use'] or vaapi_drm['use'], } if vaapi_egl['use'] dependencies += [vaapi_wayland['deps'], vaapi_drm['deps']] features += vaapi_egl['name'] sources += files('video/out/hwdec/hwdec_vaapi_gl.c') endif vaapi_vulkan = { 'name': 'vaapi-vulkan', 'use': vaapi['use'] and libplacebo.found() and vulkan.found(), } if vaapi_vulkan['use'] features += vaapi_vulkan['name'] sources += files('video/out/hwdec/hwdec_vaapi_vk.c') endif if vaapi_egl['use'] or vaapi_vulkan['use'] sources += files('video/out/hwdec/hwdec_vaapi.c') endif vdpau = dependency('vdpau', version: '>= 0.2', required: get_option('vdpau')) if vdpau.found() and x11['use'] dependencies += vdpau features += 'vdpau' sources += files('video/filter/vf_vdpaupp.c', 'video/out/vo_vdpau.c', 'video/vdpau.c', 'video/vdpau_mixer.c') endif if vdpau.found() and gl_x11.allowed() features += 'vdpau-gl-x11' sources += files('video/out/opengl/hwdec_vdpau.c') endif videotoolbox_gl = get_option('videotoolbox-gl').require( gl_cocoa.allowed() or ios_gl, error_message: 'gl-cocoa nor ios-gl could be found!', ) if videotoolbox_gl.allowed() features += 'videobox-gl' sources += files('video/out/opengl/hwdec_osx.c') endif # macOS features macos_sdk_version_py = find_program(join_paths(source_root, 'TOOLS', 'macos-sdk-version.py')) macos_sdk_info = run_command(macos_sdk_version_py).stdout().split(',') macos_sdk_path = macos_sdk_info[0].strip() macos_sdk_version = macos_sdk_info[1] message('Detected macOS sdk path: ' + macos_sdk_path) if macos_sdk_version != '0.0' message('Detected macOS SDK: ' + macos_sdk_version) add_languages('objc') objc_link_flags = ['-isysroot', macos_sdk_path, '-L/usr/lib', '-L/usr/local/lib'] add_project_link_arguments(objc_link_flags, language: ['c', 'objc']) endif macos_10_11_features = get_option('macos-10-11-features').require( macos_sdk_version.version_compare('>=10.11'), error_message: 'a suitable macos sdk version could not be found!', ) macos_10_12_2_features = get_option('macos-10-12-2-features').require( macos_sdk_version.version_compare('>=10.12.2'), error_message: 'a suitable macos sdk version could not be found!', ) macos_10_14_features = get_option('macos-10-14-features').require( macos_sdk_version.version_compare('>=10.14'), error_message: 'a suitable macos sdk version could not be found!', ) xcrun = find_program('xcrun', required: get_option('swift-build')) swift_ver = '0.0' if xcrun.found() swift_prog = find_program(run_command(xcrun, '-find', 'swift').stdout().strip()) swift_ver_string = run_command(swift_prog, '-version').stdout() verRe = ''' #!/usr/bin/env python3 import re import sys verRe = re.compile("(?i)version\s?([\d.]+)") swift_ver = verRe.search(sys.argv[1]).group(1) sys.stdout.write(swift_ver) ''' swift_ver = run_command(python, '-c', verRe, swift_ver_string).stdout() message('Detected Swift version: ' + swift_ver) endif swift = get_option('swift-build').require( darwin and macos_sdk_version.version_compare('>=10.10') and swift_ver.version_compare('>=4.1'), error_message: 'A suitable macos sdk version or swift version could not be found!', ) swift_sources = [] if cocoa.found() and swift.allowed() swift_sources += files('osdep/macos/libmpv_helper.swift', 'osdep/macos/log_helper.swift', 'osdep/macos/mpv_helper.swift', 'osdep/macos/swift_compat.swift', 'osdep/macos/swift_extensions.swift', 'video/out/mac/common.swift', 'video/out/mac/title_bar.swift', 'video/out/mac/view.swift', 'video/out/mac/window.swift') endif macos_cocoa_cb = get_option('macos-cocoa-cb').require( cocoa.found() and swift.allowed(), error_message: 'Either cocoa or swift could not be found!', ) if macos_cocoa_cb.allowed() features += 'macos-cocoa-cb' swift_sources += files('video/out/cocoa_cb_common.swift', 'video/out/mac/gl_layer.swift') endif macos_media_player = get_option('macos-media-player').require( macos_10_12_2_features.allowed() and swift.allowed(), error_message: 'Either the macos sdk version is not at least 10.12.2 or swift was not found!', ) if macos_media_player.allowed() features += 'macos-media-player' swift_sources += files('osdep/macos/remote_command_center.swift') endif if swift.allowed() subdir(join_paths('generated', 'osdep')) endif macos_touchbar = { 'name': 'macos-touchbar', 'deps': dependency('appleframeworks', modules: 'AppKit', required: get_option('macos-touchbar')), 'fragment': files(join_paths(fragments, 'touchbar.m')), 'use': false, } macos_touchbar += {'use': cc.compiles(macos_touchbar['fragment'], name: 'macos-touchbar check')} if macos_touchbar['use'] features += 'macos-touchbar' sources += files('osdep/macosx_touchbar.m') elif get_option('macos-touchbar').enabled() error('macos-touchbar enabled but it could not be found!') endif # manpages manpage = 'DOCS/man/mpv.rst' rst2man = find_program('rst2man', required: get_option('manpage-build')) if rst2man.found() features += 'manpage-build' mandir = get_option('mandir') custom_target('rst2man', input: manpage, output: 'mpv.1', command: [rst2man, '--strip-elements-with-class=contents', '@INPUT@', '@OUTPUT@'], install: true, install_dir: join_paths(mandir, 'man1') ) endif rst2html = find_program('rst2html', required: get_option('html-build')) if rst2html.found() datadir = get_option('datadir') features += 'html-build' custom_target('rst2html', input: manpage, output: 'mpv.html', command: [rst2html, manpage, '@INPUT@', '@OUTPUT@'], install: true, install_dir: join_paths(datadir, 'doc', 'mpv') ) endif rst2pdf = find_program('rst2pdf', required: get_option('pdf-build')) if rst2pdf.found() datadir = get_option('datadir') features += 'pdf-build' custom_target('rst2pdf', input: manpage, output: 'mpv.pdf', command: [rst2pdf, '-c', '-b', '1', '--repeat-table-rows', '@INPUT@', '-o', '@OUTPUT@'], install: true, install_dir: join_paths(datadir, 'doc', 'mpv') ) endif # We can't easily get every single thing a user might have passed on the cli, # but we might as well add prefix (even if it's not specifically set) since # it's highly relevant and useful. configuration = 'meson build ' configuration += '-Dprefix=' + get_option('prefix') if get_option('cplayer') features += 'cplayer' endif if get_option('libmpv') features += 'libmpv-' + get_option('default_library') endif # Script to sort the features object. feature_sort = ''' #!/usr/bin/env python3 import sys sys.argv.pop(0) features = sys.argv features.sort() features_str = " ".join(features) sys.stdout.write(features_str) ''' feature_str = run_command(python, '-c', feature_sort, features).stdout() # Set config.h conf_data = configuration_data() conf_data.set_quoted('CONFIGURATION', configuration) conf_data.set_quoted('DEFAULT_DVD_DEVICE', dvd_device) conf_data.set_quoted('DEFAULT_CDROM_DEVICE', cd_device) conf_data.set_quoted('FULLCONFIG', feature_str) conf_data.set10('HAVE_ALSA', alsa.found()) conf_data.set10('HAVE_ANDROID', android) conf_data.set10('HAVE_AUDIOUNIT', audiounit['use']) conf_data.set10('HAVE_BSD_FSTATFS', bsd_fstatfs) conf_data.set10('HAVE_BSD_THREAD_NAME', bsd_thread_name) conf_data.set10('HAVE_CACA', caca.found()) conf_data.set10('HAVE_CDDA', cdda.found()) conf_data.set10('HAVE_COCOA', cocoa.found()) conf_data.set10('HAVE_CONSIO_H', consio_h) conf_data.set10('HAVE_COREAUDIO', coreaudio.found()) conf_data.set10('HAVE_CPLUGINS', cplugins.allowed()) conf_data.set10('HAVE_CUDA_HWACCEL', cuda_hwaccel.allowed()) conf_data.set10('HAVE_CUDA_INTEROP', cuda_interop.allowed()) conf_data.set10('HAVE_D3D_HWACCEL', d3d_hwaccel.allowed()) conf_data.set10('HAVE_D3D9_HWACCEL', d3d9_hwaccel.allowed()) conf_data.set10('HAVE_D3D11', d3d11.allowed()) conf_data.set10('HAVE_DIRECT3D', direct3d) conf_data.set10('HAVE_DOS_PATHS', win32) conf_data.set10('HAVE_DRM', drm['use']) conf_data.set10('HAVE_DVBIN', dvbin.allowed()) conf_data.set10('HAVE_DVDNAV', dvdnav.found() and dvdread.found()) conf_data.set10('HAVE_EGL', egl['use']) conf_data.set10('HAVE_EGL_ANDROID', egl_android.allowed()) conf_data.set10('HAVE_EGL_ANGLE', egl_angle.allowed()) conf_data.set10('HAVE_EGL_ANGLE_LIB', egl_angle_lib.allowed()) conf_data.set10('HAVE_EGL_ANGLE_WIN32', egl_angle_win32.allowed()) conf_data.set10('HAVE_EGL_DRM', egl_drm.allowed()) conf_data.set10('HAVE_EGL_HELPERS', egl_helpers) conf_data.set10('HAVE_EGL_X11', egl_x11.allowed()) conf_data.set10('HAVE_FFMPEG_AVIOCONTEXT_BYTES_READ', aviocontext_bytes_read) conf_data.set10('HAVE_GLIBC_THREAD_NAME', glibc_thread_name and posix) conf_data.set10('HAVE_GL', gl['use']) conf_data.set10('HAVE_GL_COCOA', gl_cocoa.allowed()) conf_data.set10('HAVE_GL_DXINTEROP', gl_dxinterop.allowed()) conf_data.set10('HAVE_GL_DXINTEROP_D3D9', gl_dxinterop_d3d9.allowed()) conf_data.set10('HAVE_GL_WAYLAND', egl_wayland['use']) conf_data.set10('HAVE_GL_WIN32', gl_win32.allowed()) conf_data.set10('HAVE_GL_X11', gl_x11.allowed()) conf_data.set10('HAVE_GLOB', glob) conf_data.set10('HAVE_GLOB_POSIX', glob_posix) conf_data.set10('HAVE_GPL', get_option('gpl')) conf_data.set10('HAVE_ICONV', iconv.found()) conf_data.set10('HAVE_IOS_GL', ios_gl) conf_data.set10('HAVE_JACK', jack.found()) conf_data.set10('HAVE_JAVASCRIPT', javascript.found()) conf_data.set10('HAVE_JPEG', jpeg.found()) conf_data.set10('HAVE_LCMS2', lcms2.found()) conf_data.set10('HAVE_LIBARCHIVE', libarchive.found()) conf_data.set10('HAVE_LIBAVDEVICE', libavdevice.found()) conf_data.set10('HAVE_LIBDL', libdl.found()) conf_data.set10('HAVE_LIBBLURAY', libbluray.found()) conf_data.set10('HAVE_LIBPLACEBO_V4', libplacebo_v4) conf_data.set10('HAVE_LINUX_FSTATFS', linux_fstatfs) conf_data.set10('HAVE_LUA', lua['use']) conf_data.set10('HAVE_MACOS_10_11_FEATURES', macos_10_11_features.allowed()) conf_data.set10('HAVE_MACOS_10_14_FEATURES', macos_10_14_features.allowed()) conf_data.set10('HAVE_MACOS_COCOA_CB', macos_cocoa_cb.allowed()) conf_data.set10('HAVE_MACOS_MEDIA_PLAYER', macos_media_player.allowed()) conf_data.set10('HAVE_MACOS_TOUCHBAR', macos_touchbar['use']) conf_data.set10('HAVE_MEMFD_CREATE', memfd_create) conf_data.set10('HAVE_OPENAL', openal.found()) conf_data.set10('HAVE_OPENSLES', opensles.found()) conf_data.set10('HAVE_OSS_AUDIO', oss) conf_data.set10('HAVE_OSX_THREAD_NAME', osx_thread_name) conf_data.set10('HAVE_POSIX', posix) conf_data.set10('HAVE_PULSE', pulse.found()) conf_data.set10('HAVE_RPI', rpi['use']) conf_data.set10('HAVE_RPI_MMAL', rpi['use'] and rpi_mmal.found()) conf_data.set10('HAVE_RUBBERBAND', rubberband.found()) conf_data.set10('HAVE_SDL2', sdl2.found()) conf_data.set10('HAVE_SDL2_AUDIO', sdl2_audio.allowed()) conf_data.set10('HAVE_SDL2_GAMEPAD', sdl2_gamepad.allowed()) conf_data.set10('HAVE_SDL2_VIDEO', sdl2_video.allowed()) conf_data.set10('HAVE_SHADERC', shaderc.found()) conf_data.set10('HAVE_SIXEL', sixel.found()) conf_data.set10('HAVE_STDATOMIC', stdatomic.found()) conf_data.set10('HAVE_TA_LEAK_REPORT', get_option('ta-leak-report')) conf_data.set10('HAVE_TESTS', get_option('tests')) conf_data.set10('HAVE_UCHARDET', iconv.found() and uchardet.found()) conf_data.set10('HAVE_UWP', uwp.found()) conf_data.set10('HAVE_VAAPI', vaapi['use']) conf_data.set10('HAVE_VAAPI_DRM', vaapi_drm['use']) conf_data.set10('HAVE_VAAPI_EGL', vaapi_egl['use']) conf_data.set10('HAVE_VAAPI_VULKAN', vaapi_vulkan['use']) conf_data.set10('HAVE_VAAPI_WAYLAND', vaapi_wayland['use']) conf_data.set10('HAVE_VAAPI_X11', vaapi_x11['use']) conf_data.set10('HAVE_VAPOURSYNTH', vapoursynth.found() and vapoursynth_script.found()) conf_data.set10('HAVE_VECTOR', vector) conf_data.set10('HAVE_VDPAU', vdpau.found() and x11['use']) conf_data.set10('HAVE_VDPAU_GL_X11', vdpau.found() and gl_x11.allowed()) conf_data.set10('HAVE_VIDEOTOOLBOX_GL', videotoolbox_gl.allowed()) conf_data.set10('HAVE_VULKAN', libplacebo.found() and vulkan.found()) conf_data.set10('HAVE_WASAPI', wasapi) conf_data.set10('HAVE_WAYLAND', wayland['use']) conf_data.set10('HAVE_WIN32_DESKTOP', win32_desktop) conf_data.set10('HAVE_WIN32_INTERNAL_PTHREADS', win32_pthreads.allowed()) conf_data.set10('HAVE_X11', x11['use']) conf_data.set10('HAVE_XV', xv.found()) conf_data.set10('HAVE_ZIMG', zimg.found()) conf_data.set10('HAVE_ZLIB', zlib.found()) conf_data.set_quoted('MPV_CONFDIR', join_paths(get_option('sysconfdir'), 'mpv')) configure_file(output : 'config.h', configuration : conf_data) message('List of enabled features: ' + feature_str) # build targets if win32 windows = import('windows') res_flags = ['--codepage=65001'] # Unintuitively, this compile operates out of the osdep subdirectory. # Hence, these includes are needed. res_includes = [source_root, build_root] resources = ['etc/mpv-icon-8bit-16x16.png', 'etc/mpv-icon-8bit-32x32.png', 'etc/mpv-icon-8bit-64x64.png', 'etc/mpv-icon-8bit-128x128.png', 'etc/mpv-icon.ico', 'osdep/mpv.exe.manifest'] sources += windows.compile_resources('osdep/mpv.rc', args: res_flags, depend_files: resources, depends: version_h, include_directories: res_includes) endif if get_option('libmpv') client_h_define = cc.get_define('MPV_CLIENT_API_VERSION', prefix: '#include "libmpv/client.h"', include_directories: include_directories('.')) major = client_h_define.split('|')[0][3] minor = client_h_define.split('|')[1].substring(2,5) client_api_version = major + '.' + minor + '.0' libmpv = library('mpv', sources, dependencies: [dependencies, luajit_partial], version: client_api_version, include_directories: includedir, install: true) pkg = import('pkgconfig') pkg.generate(libmpv, version: client_api_version, description: 'mpv media player client library') headers = ['libmpv/client.h', 'libmpv/opengl_cb.h', 'libmpv/render.h', 'libmpv/render_gl.h', 'libmpv/stream_cb.h'] install_headers(headers, subdir: 'mpv') endif if get_option('cplayer') datadir = get_option('datadir') confdir = get_option('sysconfdir') conf_files = ['etc/mpv.conf', 'etc/input.conf', 'etc/mplayer-input.conf', 'etc/restore-old-bindings.conf'] install_data(conf_files, install_dir: join_paths(datadir, 'doc', 'mpv')) bash_install_dir = join_paths(datadir, 'bash-completion', 'completions') install_data('etc/mpv.bash-completion', install_dir: bash_install_dir, rename: 'mpv') zsh_install_dir = join_paths(datadir, 'zsh', 'site-functions') install_data('etc/_mpv.zsh', install_dir: zsh_install_dir, rename: '_mpv') install_data('etc/mpv.desktop', install_dir: join_paths(datadir, 'applications')) install_data('etc/encoding-profiles.conf', install_dir: join_paths(confdir, 'mpv')) foreach size: ['16x16', '32x32', '64x64', '128x128'] icon_dir = join_paths(datadir, 'icons', 'hicolor', size, 'apps') install_data('etc/mpv-icon-8bit-' + size + '.png', install_dir: icon_dir, rename: 'mpv.png') endforeach hicolor_dir = join_paths(datadir, 'icons', 'hicolor') install_data('etc/mpv-gradient.svg', install_dir: join_paths(hicolor_dir, 'scalable', 'apps'), rename: 'mpv.svg') install_data('etc/mpv-symbolic.svg', install_dir: join_paths(hicolor_dir, 'symbolic', 'apps')) executable('mpv', sources, dependencies: [dependencies, luajit_full], include_directories: includedir, install: true) endif