mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-18 10:53:52 +00:00
e0464e4788
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" ```
65 lines
2.1 KiB
Nix
65 lines
2.1 KiB
Nix
{ lib, stdenv
|
|
, fetchFromGitHub
|
|
, autoPatchelfHook
|
|
, libusb-compat-0_1
|
|
, readline ? null
|
|
, enableReadline ? true
|
|
, hidapi ? null
|
|
, pkg-config ? null
|
|
, mspds ? null
|
|
, enableMspds ? false
|
|
}:
|
|
|
|
assert stdenv.hostPlatform.isDarwin -> hidapi != null && pkg-config != null;
|
|
assert enableReadline -> readline != null;
|
|
assert enableMspds -> mspds != null;
|
|
|
|
stdenv.mkDerivation rec {
|
|
version = "0.25";
|
|
pname = "mspdebug";
|
|
src = fetchFromGitHub {
|
|
owner = "dlbeer";
|
|
repo = "mspdebug";
|
|
rev = "v${version}";
|
|
sha256 = "0prgwb5vx6fd4bj12ss1bbb6axj2kjyriyjxqrzd58s5jyyy8d3c";
|
|
};
|
|
|
|
enableParallelBuilding = true;
|
|
nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin pkg-config
|
|
++ lib.optional (enableMspds && stdenv.hostPlatform.isLinux) autoPatchelfHook;
|
|
buildInputs = [ libusb-compat-0_1 ]
|
|
++ lib.optional stdenv.hostPlatform.isDarwin hidapi
|
|
++ lib.optional enableReadline readline;
|
|
|
|
postPatch = lib.optionalString stdenv.hostPlatform.isDarwin ''
|
|
# TODO: remove once a new 0.26+ release is made
|
|
substituteInPlace drivers/tilib_api.c --replace .so ${stdenv.hostPlatform.extensions.sharedLibrary}
|
|
|
|
# Makefile only uses pkg-config if it detects homebrew
|
|
substituteInPlace Makefile --replace brew true
|
|
'';
|
|
|
|
# TODO: wrap with MSPDEBUG_TILIB_PATH env var instead of these rpath fixups in 0.26+
|
|
runtimeDependencies = lib.optional enableMspds mspds;
|
|
postFixup = lib.optionalString (enableMspds && stdenv.hostPlatform.isDarwin) ''
|
|
# autoPatchelfHook only works on linux so...
|
|
for dep in $runtimeDependencies; do
|
|
install_name_tool -add_rpath $dep/lib $out/bin/$pname
|
|
done
|
|
'';
|
|
|
|
installFlags = [ "PREFIX=$(out)" "INSTALL=install" ];
|
|
makeFlags = [ "UNAME_S=$(unameS)" ] ++
|
|
lib.optional (!enableReadline) "WITHOUT_READLINE=1";
|
|
unameS = lib.optionalString stdenv.hostPlatform.isDarwin "Darwin";
|
|
|
|
meta = with lib; {
|
|
description = "Free programmer, debugger, and gdb proxy for MSP430 MCUs";
|
|
mainProgram = "mspdebug";
|
|
homepage = "https://dlbeer.co.nz/mspdebug/";
|
|
license = licenses.gpl2;
|
|
platforms = platforms.all;
|
|
maintainers = with maintainers; [ aerialx ];
|
|
};
|
|
}
|