diff options
Diffstat (limited to 'nixpkgs/pkgs/development/libraries/folks')
-rw-r--r-- | nixpkgs/pkgs/development/libraries/folks/default.nix | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/development/libraries/folks/default.nix b/nixpkgs/pkgs/development/libraries/folks/default.nix new file mode 100644 index 000000000000..45d3f128c01c --- /dev/null +++ b/nixpkgs/pkgs/development/libraries/folks/default.nix @@ -0,0 +1,140 @@ +{ stdenv +, lib +, fetchurl +, fetchpatch +, pkg-config +, meson +, ninja +, glib +, gnome +, nspr +, gettext +, gobject-introspection +, vala +, sqlite +, libxml2 +, dbus-glib +, libsoup +, nss +, dbus +, libgee +, evolution-data-server +, libgdata +, libsecret +, db +, python3 +, readline +, gtk3 +, gtk-doc +, docbook-xsl-nons +, docbook_xml_dtd_43 +, telepathy-glib +, telepathySupport ? false +}: + +# TODO: enable more folks backends + +stdenv.mkDerivation rec { + pname = "folks"; + version = "0.15.3"; + + outputs = [ "out" "dev" "devdoc" ]; + + src = fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + sha256 = "Idc3+vCT9L4GVHPucMogiFuaLDaFlB26JMIjn9PFRKU="; + }; + + patches = [ + # Fix build with evolution-data-server ≥ 3.41 + # https://gitlab.gnome.org/GNOME/folks/-/merge_requests/52 + (fetchpatch { + url = "https://gitlab.gnome.org/GNOME/folks/-/commit/62d588b0c609de17df5b4d1ebfbc67c456267efc.patch"; + sha256 = "TDL/5kvVwHnvDMuKDdPLQmpmE1FTZhY+7HG8NxKqt5w="; + }) + ]; + + nativeBuildInputs = [ + gettext + gobject-introspection + gtk3 + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + meson + ninja + pkg-config + python3 + vala + ]; + + buildInputs = [ + db + dbus-glib + evolution-data-server + libgdata # required for some backends transitively + libsecret + libsoup + libxml2 + nspr + nss + readline + ] ++ lib.optional telepathySupport telepathy-glib; + + propagatedBuildInputs = [ + glib + libgee + sqlite + ]; + + checkInputs = [ + dbus + (python3.withPackages (pp: with pp; [ + python-dbusmock + # The following possibly need to be propagated by dbusmock + # if they are not optional + dbus-python + pygobject3 + ])) + ]; + + mesonFlags = [ + "-Ddocs=true" + "-Dtelepathy_backend=${lib.boolToString telepathySupport}" + # For some reason, the tests are getting stuck on 31/32, + # even though the one missing test finishes just fine on next run, + # when tests are permuted differently. And another test that + # previously passed will be stuck instead. + "-Dtests=false" + ]; + + doCheck = false; + + # Prevents e-d-s add-contacts-stress-test from timing out + checkPhase = '' + runHook preCheck + meson test --timeout-multiplier 4 + runHook postCheck + ''; + + postPatch = '' + chmod +x meson_post_install.py + patchShebangs meson_post_install.py + patchShebangs tests/tools/manager-file.py + ''; + + passthru = { + updateScript = gnome.updateScript { + packageName = pname; + versionPolicy = "none"; + }; + }; + + meta = with lib; { + description = "A library that aggregates people from multiple sources to create metacontacts"; + homepage = "https://wiki.gnome.org/Projects/Folks"; + license = licenses.lgpl2Plus; + maintainers = teams.gnome.members; + platforms = platforms.gnu ++ platforms.linux; # arbitrary choice + }; +} |