mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-02-19 02:24:30 +00:00
![Artturin](/assets/img/avatar_default.png)
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" ```
66 lines
1.7 KiB
Nix
66 lines
1.7 KiB
Nix
{ lib, stdenv, cmake, fetchFromGitLab
|
|
, json_c, libsodium, libxml2, ncurses }:
|
|
|
|
let
|
|
rev = "22796663dcad81684ab24308d9db570f6781ba2c";
|
|
|
|
in stdenv.mkDerivation rec {
|
|
name = "mpw-${version}-${builtins.substring 0 8 rev}";
|
|
version = "2.6";
|
|
|
|
src = fetchFromGitLab {
|
|
owner = "MasterPassword";
|
|
repo = "MasterPassword";
|
|
sha256 = "1f2vqacgbyam1mazawrfim8zwp38gnwf5v3xkkficsfnv789g6fw";
|
|
inherit rev;
|
|
};
|
|
|
|
sourceRoot = "${src.name}/platform-independent/c/cli";
|
|
|
|
postPatch = ''
|
|
rm build
|
|
substituteInPlace mpw-cli-tests \
|
|
--replace '/usr/bin/env bash' ${stdenv.shell} \
|
|
--replace ./mpw ./build/mpw
|
|
'';
|
|
|
|
cmakeFlags = [
|
|
"-Dmpw_version=${version}"
|
|
"-DBUILD_MPW_TESTS=ON"
|
|
];
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
buildInputs = [ json_c libxml2 libsodium ncurses ];
|
|
|
|
installPhase = ''
|
|
runHook preInstall
|
|
|
|
install -Dm755 mpw $out/bin/mpw
|
|
install -Dm644 ../mpw.completion.bash $out/share/bash-completion/completions/_mpw
|
|
install -Dm644 ../../../../README.md $out/share/doc/mpw/README.md
|
|
|
|
runHook postInstall
|
|
'';
|
|
|
|
# Some tests are expected to fail on ARM64
|
|
# See: https://gitlab.com/spectre.app/cli/-/issues/27#note_962950844 (mpw is a predecessor to spectre-cli and this issue is relevant to mpw as well)
|
|
doCheck = !(stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64);
|
|
|
|
checkPhase = ''
|
|
runHook preCheck
|
|
|
|
../mpw-cli-tests
|
|
|
|
runHook postCheck
|
|
'';
|
|
|
|
meta = with lib; {
|
|
description = "Stateless password management solution";
|
|
mainProgram = "mpw";
|
|
homepage = "https://masterpasswordapp.com/";
|
|
license = licenses.gpl3;
|
|
platforms = platforms.unix;
|
|
};
|
|
}
|