enlightenment.efl: 1.22.5 -> 1.23.1

- Update to version 1.23.1
- Switch to meson build system
- Add new dependencies: avahi, ibus, check
This commit is contained in:
José Romildo Malaquias 2019-10-15 21:29:48 -03:00
parent 95f1a9a034
commit dfb26389ce

View File

@ -1,6 +1,6 @@
{ stdenv, fetchurl, pkgconfig, SDL, SDL2, alsaLib, bullet, curl, dbus, { stdenv, fetchurl, meson, ninja, pkgconfig, SDL, SDL2, alsaLib, avahi, bullet, check, curl, dbus,
doxygen, expat, fontconfig, freetype, fribidi, ghostscript, giflib, doxygen, expat, fontconfig, freetype, fribidi, ghostscript, giflib,
glib, gst_all_1, gtk3, harfbuzz, jbig2dec, libGL, libdrm, libinput, glib, gst_all_1, gtk3, harfbuzz, ibus, jbig2dec, libGL, libdrm, libinput,
libjpeg, libpng, libpulseaudio, libraw, librsvg, libsndfile, libjpeg, libpng, libpulseaudio, libraw, librsvg, libsndfile,
libspectre, libtiff, libwebp, libxkbcommon, luajit, lz4, mesa, libspectre, libtiff, libwebp, libxkbcommon, luajit, lz4, mesa,
openjpeg, openssl, poppler, python27Packages, systemd, udev, openjpeg, openssl, poppler, python27Packages, systemd, udev,
@ -9,20 +9,24 @@
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
pname = "efl"; pname = "efl";
version = "1.22.5"; version = "1.23.1";
src = fetchurl { src = fetchurl {
url = "http://download.enlightenment.org/rel/libs/${pname}/${pname}-${version}.tar.xz"; url = "http://download.enlightenment.org/rel/libs/${pname}/${pname}-${version}.tar.xz";
sha256 = "1cjk56z0whpzcqwg3xdq23kyp1g83xa67m9dlp7ywmb36bn4ca59"; sha256 = "0q9g4j7k10s1a8rv2ca9v9lydh7ml3zsrqvgncc4qhvdl76208nn";
}; };
nativeBuildInputs = [ nativeBuildInputs = [
meson
ninja
gtk3 gtk3
pkgconfig pkgconfig
check
]; ];
buildInputs = [ buildInputs = [
SDL SDL
avahi
fontconfig fontconfig
freetype freetype
giflib giflib
@ -31,6 +35,7 @@ stdenv.mkDerivation rec {
gst_all_1.gst-plugins-base gst_all_1.gst-plugins-base
gst_all_1.gst-plugins-good gst_all_1.gst-plugins-good
gst_all_1.gstreamer gst_all_1.gstreamer
ibus
libGL libGL
libpng libpng
libpulseaudio libpulseaudio
@ -90,30 +95,25 @@ stdenv.mkDerivation rec {
xorg.xcbutilkeysyms xorg.xcbutilkeysyms
]; ];
# ac_ct_CXX must be set to random value, because then it skips some magic which does alternative searching for g++ mesonFlags = [
configureFlags = [ "--buildtype=release"
"--enable-sdl" "-D build-tests=false" # disable build tests, which are not working
"--enable-drm" "-D drm=true"
"--enable-elput" "-D embedded-lz4=false"
"--with-opengl=full" "-D evas-loaders-disabler=json"
"--enable-image-loader-jp2k" "-D fb=true"
"--enable-xinput22" "-D opengl=full"
"--enable-multisense" "-D sdl=true"
"--enable-liblz4"
"--enable-systemd"
"--enable-image-loader-webp"
"--enable-harfbuzz"
"--enable-xine"
"--enable-fb"
"--disable-tslib"
"--with-systemdunitdir=$out/systemd/user"
"ac_ct_CXX=foo"
]; ];
patches = [ ./efl-elua.patch ]; patches = [ ./efl-elua.patch ];
postPatch = '' postPatch = ''
patchShebangs src/lib/elementary/config_embed patchShebangs src/lib/elementary/config_embed
# fix destination of systemd unit and dbus service
substituteInPlace systemd-services/meson.build --replace "dep.get_pkgconfig_variable('systemduserunitdir')" "'$out/systemd/user'"
substituteInPlace dbus-services/meson.build --replace "dep.get_pkgconfig_variable('session_bus_services_dir')" "'$out/share/dbus-1/services'"
''; '';
# bin/edje_cc creates $HOME/.run, which would break build of reverse dependencies. # bin/edje_cc creates $HOME/.run, which would break build of reverse dependencies.
@ -122,30 +122,33 @@ stdenv.mkDerivation rec {
''; '';
preConfigure = '' preConfigure = ''
export LD_LIBRARY_PATH="$(pwd)/src/lib/eina/.libs:$LD_LIBRARY_PATH" # allow ecore_con to find libcurl.so, which is a runtime dependency (it is dlopened)
export LD_LIBRARY_PATH="${curl.out}/lib:$LD_LIBRARY_PATH"
source "$setupHook" source "$setupHook"
''; '';
NIX_CFLAGS_COMPILE = [ "-DluaL_reg=luaL_Reg" ]; # needed since luajit-2.1.0-beta3 NIX_CFLAGS_COMPILE = [ "-DluaL_reg=luaL_Reg" ]; # needed since luajit-2.1.0-beta3
postInstall = '' postInstall = ''
# fix use of $out variable
substituteInPlace "$out/share/elua/core/util.lua" --replace '$out' "$out" substituteInPlace "$out/share/elua/core/util.lua" --replace '$out' "$out"
# add all module include dirs to the Cflags field in efl.pc
modules=$(for i in "$out/include/"*/; do printf ' -I''${includedir}/'`basename $i`; done) modules=$(for i in "$out/include/"*/; do printf ' -I''${includedir}/'`basename $i`; done)
substituteInPlace "$out/lib/pkgconfig/efl.pc" --replace 'Cflags: -I''${includedir}/efl-1' \ substituteInPlace "$out/lib/pkgconfig/efl.pc" \
'Cflags: -I''${includedir}/eina-1/eina'"$modules" --replace 'Cflags: -I''${includedir}/efl-1' \
'Cflags: -I''${includedir}/eina-1/eina'"$modules"
# build icon cache # build icon cache
gtk-update-icon-cache "$out"/share/icons/Enlightenment-X gtk-update-icon-cache "$out"/share/icons/Enlightenment-X
''; '';
# EFL applications depend on libcurl, although it is linked at
# runtime by hand in code (it is dlopened).
postFixup = '' postFixup = ''
# EFL applications depend on libcurl, which is linked at runtime by hand in code (it is dlopened)
patchelf --add-needed ${curl.out}/lib/libcurl.so $out/lib/libecore_con.so patchelf --add-needed ${curl.out}/lib/libcurl.so $out/lib/libecore_con.so
''; '';
enableParallelBuilding = true;
meta = { meta = {
description = "Enlightenment foundation libraries"; description = "Enlightenment foundation libraries";
homepage = https://enlightenment.org/; homepage = https://enlightenment.org/;