nixpkgs/pkgs/by-name/gn/gnome-maps/package.nix
Artturin e0464e4788 treewide: replace stdenv.is with stdenv.hostPlatform.is
In preparation for the deprecation of `stdenv.isX`.

These shorthands are not conducive to cross-compilation because they
hide the platforms.

Darwin might get cross-compilation for which the continued usage of `stdenv.isDarwin` will get in the way

One example of why this is bad and especially affects compiler packages
https://www.github.com/NixOS/nixpkgs/pull/343059

There are too many files to go through manually but a treewide should
get users thinking when they see a `hostPlatform.isX` in a place where it
doesn't make sense.

```
fd --type f "\.nix" | xargs sd --fixed-strings "stdenv.is" "stdenv.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "stdenv'.is" "stdenv'.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "clangStdenv.is" "clangStdenv.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "gccStdenv.is" "gccStdenv.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "stdenvNoCC.is" "stdenvNoCC.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "inherit (stdenv) is" "inherit (stdenv.hostPlatform) is"
fd --type f "\.nix" | xargs sd --fixed-strings "buildStdenv.is" "buildStdenv.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "effectiveStdenv.is" "effectiveStdenv.hostPlatform.is"
fd --type f "\.nix" | xargs sd --fixed-strings "originalStdenv.is" "originalStdenv.hostPlatform.is"
```
2024-09-25 00:04:37 +03:00

113 lines
2.7 KiB
Nix

{
stdenv,
lib,
fetchurl,
meson,
ninja,
gettext,
python3,
pkg-config,
gnome,
glib,
gtk4,
gobject-introspection,
gdk-pixbuf,
librest_1_0,
libgweather,
geoclue2,
wrapGAppsHook4,
desktop-file-utils,
libportal,
libshumate,
libsecret,
libsoup_3,
gsettings-desktop-schemas,
gjs,
libadwaita,
geocode-glib_2,
tzdata,
}:
stdenv.mkDerivation (finalAttrs: {
pname = "gnome-maps";
version = "46.11";
src = fetchurl {
url = "mirror://gnome/sources/gnome-maps/${lib.versions.major finalAttrs.version}/gnome-maps-${finalAttrs.version}.tar.xz";
hash = "sha256-lAtBuXQLCBMyXjkWdYcWz4+g7k4MkZHyYM7AbZITWDU=";
};
doCheck = !stdenv.hostPlatform.isDarwin;
nativeBuildInputs = [
gettext
meson
ninja
pkg-config
wrapGAppsHook4
gobject-introspection
# For post install script
desktop-file-utils
glib
gtk4
];
buildInputs = [
gdk-pixbuf
glib
geoclue2
geocode-glib_2
gjs
gsettings-desktop-schemas
gtk4
libportal
libshumate
libgweather
libadwaita
librest_1_0
libsecret
libsoup_3
];
postPatch = ''
# The .service file isn't wrapped with the correct environment
# so misses GIR files when started. By re-pointing from the gjs
# entry point to the wrapped binary we get back to a wrapped
# binary.
substituteInPlace "data/org.gnome.Maps.service.in" \
--replace "Exec=@pkgdatadir@/@app-id@" \
"Exec=$out/bin/gnome-maps"
'';
preCheck = ''
# time.js included by timeTest and translationsTest depends on org.gnome.desktop.interface schema.
export XDG_DATA_DIRS="${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}:$XDG_DATA_DIRS"
export HOME=$(mktemp -d)
export TZDIR=${tzdata}/share/zoneinfo
# Our gobject-introspection patches make the shared library paths absolute
# in the GIR files. When running tests, the library is not yet installed,
# though, so we need to replace the absolute path with a local one during build.
# We are using a symlink that we will delete before installation.
mkdir -p $out/lib/gnome-maps
ln -s $PWD/lib/libgnome-maps.so.0 $out/lib/gnome-maps/libgnome-maps.so.0
'';
postCheck = ''
rm $out/lib/gnome-maps/libgnome-maps.so.0
'';
passthru = {
updateScript = gnome.updateScript { packageName = "gnome-maps"; };
};
meta = with lib; {
homepage = "https://apps.gnome.org/Maps/";
description = "Map application for GNOME 3";
mainProgram = "gnome-maps";
maintainers = teams.gnome.members;
license = licenses.gpl2Plus;
platforms = platforms.unix;
};
})