add compositor crop resize/shrink, rework 3rd-party build for pkg-cfg cflags/libs
[goodguy/cinelerra.git] / cinelerra-5.1 / thirdparty / Makefile
index 42211838aae214e58238dc22604c8f8cfe250a8b..846a843fca468e0eeb2a63ecf14bca02a0c68978 100644 (file)
@@ -21,6 +21,7 @@
 #     add $(call rules,$(call std-build,<name>,<dep>...))
 #     add deps to other call rules if they require the new library
 #     add config enables if other libraries use the new library
+#     add pc_<pkg>=<pkgcfg names> if needed for system build
 #
 
 TOPDIR ?= $(CURDIR)/..
@@ -52,10 +53,14 @@ unpack_bz2=tar -xjf $(1)
 unpack_xz=tar -xJf $(1)
 bld_depends=$(if $(ver_$(1)),$(call pkg-built,$(1)))
 bld_path=$(ver_$(1))/$(2)
-if_pkg=$(if $(ver_$(1)),$(2))
+if_pkg=$(if $(ver_$(1)),$(2),$(3))
 if_npkg=$(if $(ver_$(1)),,$(2))
-inc_path=$(call if_pkg,$(1),$(inc_$(1)))
+if_shr=$(if $(findstring $(1),$(shared_pkgs)),$(2),$(3))
+pkg_conf=$(call if_shr,$(1),$(foreach p,$(pc_$(1)), $(shell pkg-config 2> /dev/null $(2) $(p))))
+inc_path=$(call if_pkg,$(1),$(inc_$(1)), $(call pkg_conf,$(1),--cflags))
 ld_path=$(call if_pkg,$(1),-L$(call bld_path,$(1),$(2)) $(lib_$(1)))
+if_ena=$(if $(or $(ver_$(1)),$(findstring $(1),$(shared_pkgs))),$(2))
+if_want=$(if $(findstring x$(WANT_$(1)),xyes),$(2),$(3))
 
 #$(eval $(call std-build,pkg,deps...))
 #$(pkg.cflags) added as CFLAGS+=$(cflags) to pkg.vars
@@ -101,9 +106,20 @@ $(TARGETS):        $(BLD)
 $(BLD):
        mkdir $(BLD)
 
+# pkg-config names
+pc_libaom=aom
+pc_dav1d=dav1d
+pc_libwebp=libwebp libwebpmux
+pc_opus=opus
+pc_openjpeg=libopenjp2
+pc_libvorbis=vorbis vorbisenc
+pc_libvpx=vpx
+pc_x264=x264
+pc_x265=x265
+
 # vars first
 encore.cfg_vars= true ||
-esound.cfg_vars:= AUDIOFILE_CFLAGS="$(call inc_path,audiofile,libaudiofile) -laudiofile"
+esound.cfg_vars:= AUDIOFILE_CFLAGS="$(call inc_path,audiofile) -laudiofile"
 esound.cfg_vars+= AUDIOFILE_LIBS="$(call ld_path,audiofile,libaudiofile/.libs)"
 esound.cfg_params= --enable-shared=no --with-pic
 esound.mak_vars+= CFLAGS="" 
@@ -111,41 +127,43 @@ esound.ldflags=" -lm -lstdc++"
 fftw.cfg_params= --disable-fortran --enable-shared=no
 ffmpeg.cfg_params= \
        --enable-pthreads --enable-gpl --disable-ffplay \
-       $(if $(WANT_VAAPI),--enable-vaapi,--disable-vaapi) \
-       $(if $(WANT_VDPAU),--enable-vdpau,--disable-vdpau) \
-       $(if $(WANT_NV), --enable-nvenc --enable-nvdec) \
-       $(call if_pkg,twolame,--enable-libtwolame) \
-       $(call if_pkg,openjpeg,--enable-libopenjpeg) \
-       $(call if_pkg,lame,--enable-libmp3lame) \
-       $(call if_pkg,libaom,--enable-libaom) \
-       $(call if_pkg,libwebp,--enable-libwebp) \
-       $(call if_pkg,opus,--enable-libopus) \
-       $(call if_pkg,libvorbis,--enable-libvorbis) \
-       $(call if_pkg,libtheora,--enable-libtheora) \
-       $(call if_pkg,libvpx,--enable-libvpx) \
-       $(call if_pkg,x264,--enable-libx264) \
-       $(call if_pkg,x265,--enable-libx265) \
+       $(call if_want,VAAPI,--enable-vaapi,--disable-vaapi) \
+       $(call if_want,VDPAU,--enable-vdpau,--disable-vdpau) \
+       $(call if_want,NV, --enable-nvenc --enable-nvdec --enable-ffnvcodec) \
+       $(call if_ena,twolame,--enable-libtwolame) \
+       $(call if_ena,openjpeg,--enable-libopenjpeg) \
+       $(call if_ena,lame,--enable-libmp3lame) \
+       $(call if_ena,libaom,--enable-libaom) \
+       $(call if_ena,dav1d,--enable-libdav1d) \
+       $(call if_ena,libwebp,--enable-libwebp) \
+       $(call if_ena,opus,--enable-libopus) \
+       $(call if_ena,libvorbis,--enable-libvorbis) \
+       $(call if_ena,libtheora,--enable-libtheora) \
+       $(call if_ena,libvpx,--enable-libvpx) \
+       $(call if_ena,x264,--enable-libx264) \
+       $(call if_ena,x265,--enable-libx265) \
        --extra-cflags="-Wno-attributes \
-               $(if $(WANT_NV), $(inc_ffnvcodec)) \
-               $(call inc_path,twolame,libtwolame) \
-               $(call inc_path,lame,include) \
-               $(call inc_path,libaom,usr/local/include) \
-               $(call inc_path,libwebp,usr/local/include) \
-               $(call inc_path,openjpeg,src/lib/openjp2) \
-               $(call inc_path,libogg,include) \
-               $(call inc_path,opus,include) \
-               $(call inc_path,libvorbis,include) \
-               $(call inc_path,libtheora,include) \
+               $(call if_want,NV,$(inc_ffnvcodec)) \
+               $(call inc_path,twolame) \
+               $(call inc_path,lame) \
+               $(call inc_path,libaom) \
+               $(call inc_path,dav1d) \
+               $(call inc_path,libwebp) \
+               $(call inc_path,openjpeg) \
+               $(call inc_path,libogg) \
+               $(call inc_path,opus) \
+               $(call inc_path,libvorbis) \
+               $(call inc_path,libtheora) \
                $(call inc_path,libvpx) \
                $(call inc_path,x264) \
-               $(call inc_path,x265) \
-               $(call inc_path,x265,source)" \
+               $(call inc_path,x265)" \
        --extra-cxxflags="-D__STDC_CONSTANT_MACROS" \
        --pkg-config=true \
        --extra-libs="-Wl,--start-group \
                $(call ld_path,twolame,libtwolame/.libs) \
                $(call ld_path,lame,libmp3lame/.libs) \
                $(call ld_path,libaom,usr/local/lib) \
+               $(call ld_path,dav1d,usr/local/lib) \
                $(call ld_path,libwebp,usr/local/lib) \
                $(call ld_path,openjpeg,bin) \
                $(call ld_path,opus,.libs) \
@@ -155,11 +173,12 @@ ffmpeg.cfg_params= \
                $(call ld_path,libvpx) \
                $(call ld_path,x264) \
                $(call ld_path,x265) \
+               $(shared_libs) \
                -Wl,--end-group -lm -lstdc++ -pthread \
                $(EXTRA_LIBS)" $(FFMPEG_EXTRA_CFG) \
 
 #cmake_config=echo "exec cmake \$$$$@ $(1)" > ./configure; chmod +x ./configure;
-cmake_config=echo "exec cmake $(1) \$$$$@" > ./configure; chmod +x ./configure;
+cmake_config=echo 'cmake "$$$$@" "$(1)"' > ./configure; chmod +x ./configure;
 a52dec.mak_params?= ; cd $(call bld_path,a52dec,include); ln -sf . a52dec
 a52dec.cfg_vars?= CFLAGS+=" -U__FreeBSD__ $(call inc_path,djbfft)" LIBS+=" $(call ld_path,djbfft)"
 a52dec.cfg_params?=--enable-djbfft
@@ -170,7 +189,7 @@ djbfft.mak_params?=; cd $(call bld_path,djbfft); ln -sf djbfft.a libdjbfft.a
 audiofile.cfg_params?=--enable-shared=no
 audiofile.mak_params?=LIBS="-lm -lstdc++"
 flac.cfg_params?= --enable-shared=no
-flac.cflags?="$(call inc_path,libogg,include) $(call ld_path,libogg,src/.libs)"
+flac.cflags?="$(call inc_path,libogg) $(call ld_path,libogg,src/.libs)"
 giflib.cfg_params=echo "exec true" > ./configure; chmod +x ./configure;
 ilmbase.cfg_vars= CFLAGS+=" -Wno-narrowing" CXXFLAGS+=" -Wno-narrowing"
 ilmbase.cfg_params?=--prefix=$(call bld_path,ilmbase,usr)
@@ -182,6 +201,8 @@ libaom.cfg_vars?=$(call cmake_config,aom-master)
 libaom.cfg_params?= -DENABLE_SHARED=no -DCMAKE_INSTALL_LIBDIR=lib \
  -DCMAKE_INSTALL_PREFIX=$(call bld_path,libaom)/usr/local
 libaom.mak_params?= ; $(MAKE) -C libaom* install
+dav1d.cfg_vars?=echo "echo dav1d custom make" >> configure; chmod +x ./configure;
+dav1d.mak_params?=; $(MAKE) -C dav1d* install DESTDIR="$(call bld_path,dav1d)"
 libwebp.cfg_vars?= mkdir build && cd build && $(call cmake_config,..)
 libwebp.mak_params?= -C build all install DESTDIR=$(call bld_path,libwebp)
 mjpegtools.cflags?="$(call inc_path,libjpeg) $(call ld_path,libjpeg,.libs)"
@@ -204,7 +225,7 @@ libjpeg.cfg_params?= --enable-shared=no
 libogg.cfg_params?= --enable-shared=no
 libraw1394.cfg_params?=  --enable-shared=no; ln -sf src libraw1394
 libtheora.cfg_vars?=PKG_CONFIG_PATH=$(call bld_path,libogg):$(call bld_path,libvorbis)
-libtheora.cflags?="$(call inc_path,libogg,include) $(call inc_path,libogg,src) $(call inc_path,libvorbis,include)"
+libtheora.cflags?="$(call inc_path,libogg) $(call inc_path,libvorbis)"
 libtheora.ldflags?="$(call ld_path,libvorbis,lib/.libs) $(call ld_path,libogg,src/.libs)"
 libtheora.cfg_params?= --disable-examples --disable-spec --enable-shared=no
 libuuid.cfg_params?=--enable-shared=no
@@ -292,8 +313,8 @@ $(call rules,$(call std-build,audiofile))
 $(call rules,$(call std-build,encore))
 $(call rules,$(call std-build,esound,audiofile))
 $(call rules,$(call std-build,ffmpeg, twolame lame openjpeg opus \
-       libtheora x264 x265 libvpx libaom libwebp \
-       $(if $(WANT_NV), ffnvcodec)))
+       libtheora x264 x265 libvpx libaom dav1d libwebp \
+       $(call if_want,NV, ffnvcodec)))
 $(call rules,$(call std-build,fftw))
 $(call rules,$(call std-build,flac,libogg))
 $(call rules,$(call std-build,giflib))
@@ -301,6 +322,7 @@ $(call rules,$(call std-build,ilmbase))
 $(call rules,$(call std-build,ladspa))
 $(call rules,$(call std-build,lame))
 $(call rules,$(call std-build,libaom))
+$(call rules,$(call std-build,dav1d))
 $(call rules,$(call std-build,libwebp))
 $(call rules,$(call std-build,libavc1394,libraw1394))
 $(call rules,$(call std-build,libdv))