|
|
|
@ -7,18 +7,21 @@ package("ffmpeg") |
|
|
|
|
add_urls("https://github.com/FFmpeg/FFmpeg/archive/n$(version).zip", {alias = "github"}) |
|
|
|
|
add_urls("https://git.ffmpeg.org/ffmpeg.git", "https://github.com/FFmpeg/FFmpeg.git", {alias = "git"}) |
|
|
|
|
|
|
|
|
|
add_versions("home:7.0", "a24d9074bf5523a65aaa9e7bd02afe4109ce79d69bd77d104fed3dab4b934d7a") |
|
|
|
|
add_versions("home:6.1", "eb7da3de7dd3ce48a9946ab447a7346bd11a3a85e6efb8f2c2ce637e7f547611") |
|
|
|
|
add_versions("home:6.0.1", "2c6e294569d1ba8e99cbf1acbe49e060a23454228a540a0f45d679d72ec69a06") |
|
|
|
|
add_versions("home:5.1.2", "39a0bcc8d98549f16c570624678246a6ac736c066cebdb409f9502e915b22f2b") |
|
|
|
|
add_versions("home:5.1.1", "cd0e16f903421266d5ccddedf7b83b9e5754aef4b9f7a7f06ce9e4c802f0545b") |
|
|
|
|
add_versions("home:5.0.1", "28df33d400a1c1c1b20d07a99197809a3b88ef765f5f07dc1ff067fac64c59d6") |
|
|
|
|
add_versions("home:4.0.2", "346c51735f42c37e0712e0b3d2f6476c86ac15863e4445d9e823fe396420d056") |
|
|
|
|
add_versions("github:7.0", "9ea4f1e934b1655c9a6dad579fd52fa299cd4f6a5f2b82be97daa98ff2e798d0") |
|
|
|
|
add_versions("github:6.1", "7da07ff7e30bca95c0593db20442becba13ec446dd9c3331ca3d1b40eecd3c93") |
|
|
|
|
add_versions("github:6.0.1", "2acb5738a1b4b262633ac2d646340403ae47120d9eb289ecad23fc90093c0d6c") |
|
|
|
|
add_versions("github:5.1.2", "0c99f3609160f40946e2531804175eea16416320c4b6365ad075e390600539db") |
|
|
|
|
add_versions("github:5.1.1", "a886fcc94792764c27c88ebe71dffbe5f0d37df8f06f01efac4833ac080c11bf") |
|
|
|
|
add_versions("github:5.0.1", "f9c2e06cafa4381df8d5c9c9e14d85d9afcbc10c516c6a206f821997cc7f6440") |
|
|
|
|
add_versions("github:4.0.2", "4df1ef0bf73b7148caea1270539ef7bd06607e0ea8aa2fbf1bb34062a097f026") |
|
|
|
|
add_versions("git:7.0", "n7.0") |
|
|
|
|
add_versions("git:6.1", "n6.1") |
|
|
|
|
add_versions("git:6.0.1", "n6.0.1") |
|
|
|
|
add_versions("git:5.1.2", "n5.1.2") |
|
|
|
@ -39,12 +42,22 @@ package("ffmpeg") |
|
|
|
|
add_configs("vaapi", {description = "Enable vaapi library.", default = false, type = "boolean"}) |
|
|
|
|
add_configs("vdpau", {description = "Enable vdpau library.", default = false, type = "boolean"}) |
|
|
|
|
add_configs("hardcoded-tables", {description = "Enable hardcoded tables.", default = true, type = "boolean"}) |
|
|
|
|
if is_plat("linux") then |
|
|
|
|
add_configs("libdrm", {description = "Enable libdrm hardware acceleration", default = true, type = "boolean"}) |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
add_links("avfilter", "avdevice", "avformat", "avcodec", "swscale", "swresample", "avutil") |
|
|
|
|
if is_plat("macosx") then |
|
|
|
|
add_frameworks("CoreFoundation", "Foundation", "CoreVideo", "CoreMedia", "AudioToolbox", "VideoToolbox", "Security") |
|
|
|
|
if is_plat("macosx", "iphoneos") then |
|
|
|
|
add_frameworks("CoreFoundation", "Foundation", "CoreVideo", "CoreMedia", "VideoToolbox", "Security") |
|
|
|
|
if is_plat("iphoneos") then |
|
|
|
|
add_frameworks("AVFoundation") |
|
|
|
|
else |
|
|
|
|
add_frameworks("AudioToolbox") |
|
|
|
|
end |
|
|
|
|
elseif is_plat("linux") then |
|
|
|
|
add_syslinks("pthread") |
|
|
|
|
elseif is_plat("android") then |
|
|
|
|
add_syslinks("android") |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
add_deps("nasm") |
|
|
|
@ -80,21 +93,22 @@ package("ffmpeg") |
|
|
|
|
lzma = "xz", |
|
|
|
|
libx264 = "x264", |
|
|
|
|
libx265 = "x265", |
|
|
|
|
iconv = "libiconv"} |
|
|
|
|
iconv = "libiconv", |
|
|
|
|
libdrm = "libdrm"} |
|
|
|
|
for name, dep in pairs(configdeps) do |
|
|
|
|
if package:config(name) then |
|
|
|
|
package:add("deps", dep) |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
-- https://www.ffmpeg.org/platform.html#toc-Advanced-linking-configuration |
|
|
|
|
if package:config("pic") ~= false and not package:is_plat("windows", "macosx") then |
|
|
|
|
if package:config("pic") ~= false and not package:is_plat("windows", "macosx", "iphoneos") then |
|
|
|
|
package:add("shflags", "-Wl,-Bsymbolic") |
|
|
|
|
package:add("ldflags", "-Wl,-Bsymbolic") |
|
|
|
|
end |
|
|
|
|
if not package:config("gpl") then |
|
|
|
|
package:set("license", "LGPL-3.0") |
|
|
|
|
end |
|
|
|
|
if is_plat("windows", "mingw") and not package:config("shared") then |
|
|
|
|
if package:is_plat("windows", "mingw") and not package:config("shared") then |
|
|
|
|
package:add("syslinks", "Bcrypt", "Mfplat", "mfuuid", "Ole32", "Secur32", "Strmiids", "User32", "ws2_32") |
|
|
|
|
end |
|
|
|
|
if is_subhost("windows") and os.arch() == "x64" then |
|
|
|
@ -106,7 +120,7 @@ package("ffmpeg") |
|
|
|
|
end |
|
|
|
|
end) |
|
|
|
|
|
|
|
|
|
on_install("windows", "mingw@windows,linux,cygwin,msys", "linux", "macosx", "android", function (package) |
|
|
|
|
on_install("windows", "mingw@windows,linux,cygwin,msys", "linux", "macosx", "android", "iphoneos", function (package) |
|
|
|
|
local configs = {"--enable-version3", |
|
|
|
|
"--disable-doc"} |
|
|
|
|
configs.host = "" -- prevents xmake to add a --host=xx parameter (unsupported by ffmpeg configure script) |
|
|
|
@ -152,8 +166,13 @@ package("ffmpeg") |
|
|
|
|
table.insert(configs, "--enable-pthreads") |
|
|
|
|
elseif package:is_plat("macosx", "iphoneos") then |
|
|
|
|
table.insert(configs, "--target-os=darwin") |
|
|
|
|
table.insert(configs, "--enable-appkit") |
|
|
|
|
table.insert(configs, "--enable-audiotoolbox") |
|
|
|
|
if package:is_plat("macosx") then |
|
|
|
|
table.insert(configs, "--enable-appkit") |
|
|
|
|
table.insert(configs, "--enable-audiotoolbox") |
|
|
|
|
else |
|
|
|
|
-- ffmpeg does not support audiotoolbox on iOS: https://github.com/kewlbear/FFmpeg-iOS-build-script/issues/158 |
|
|
|
|
table.insert(configs, "--disable-audiotoolbox") |
|
|
|
|
end |
|
|
|
|
if macos.version():ge("10.7") then |
|
|
|
|
table.insert(configs, "--enable-avfoundation") |
|
|
|
|
end |
|
|
|
@ -168,6 +187,7 @@ package("ffmpeg") |
|
|
|
|
table.insert(configs, "--enable-neon") |
|
|
|
|
table.insert(configs, "--enable-asm") |
|
|
|
|
table.insert(configs, "--enable-jni") |
|
|
|
|
table.insert(configs, "--enable-mediacodec") |
|
|
|
|
else |
|
|
|
|
raise("unexpected platform") |
|
|
|
|
end |
|
|
|
@ -264,11 +284,11 @@ package("ffmpeg") |
|
|
|
|
else |
|
|
|
|
raise("unknown arch(%s) for android!", package:arch()) |
|
|
|
|
end |
|
|
|
|
local function _translate_path(p) |
|
|
|
|
if p and is_host("windows") then |
|
|
|
|
return p:gsub("\\", "/") |
|
|
|
|
end |
|
|
|
|
return p |
|
|
|
|
local _translate_path |
|
|
|
|
if is_host("windows") then |
|
|
|
|
_translate_path = function (p) return p and p:gsub("\\", "/") or p end |
|
|
|
|
else |
|
|
|
|
_translate_path = function (p) return p end |
|
|
|
|
end |
|
|
|
|
local sysroot = path.join(path.directory(bin), "sysroot") |
|
|
|
|
local cflags = table.join(table.wrap(package:config("cxflags")), table.wrap(package:config("cflags")), table.wrap(get_config("cxflags")), get_config("cflags")) |
|
|
|
@ -303,7 +323,13 @@ package("ffmpeg") |
|
|
|
|
os.vrunv("make", argv) |
|
|
|
|
os.vrun("make install") |
|
|
|
|
else |
|
|
|
|
import("package.tools.autoconf").install(package, configs) |
|
|
|
|
local opt |
|
|
|
|
if package:is_plat("macosx") and package:config("shared") then |
|
|
|
|
opt = {} |
|
|
|
|
-- https://github.com/spack/spack/issues/40159 |
|
|
|
|
opt.shflags = "-Wl,-ld_classic" |
|
|
|
|
end |
|
|
|
|
import("package.tools.autoconf").install(package, configs, opt) |
|
|
|
|
end |
|
|
|
|
package:addenv("PATH", "bin") |
|
|
|
|
end) |
|
|
|
|