summary refs log tree commit diff
path: root/pkgs
diff options
context:
space:
mode:
authorJörg Thalheim <Mic92@users.noreply.github.com>2018-10-25 10:38:29 +0100
committerGitHub <noreply@github.com>2018-10-25 10:38:29 +0100
commit926d6c0bad41a094aefe0a9d3bbd14ccec83b30e (patch)
treefdd0209198c9ac1e5da9198d38bba375e22dddcb /pkgs
parent26974e962ebc5c1e3dfd8f6a84402ad72dc43d24 (diff)
parent325a5699cb0002b135f778497486366c92e3f8e7 (diff)
downloadnixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar.gz
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar.bz2
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar.lz
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar.xz
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.tar.zst
nixpkgs-926d6c0bad41a094aefe0a9d3bbd14ccec83b30e.zip
Merge pull request #42371 from Mic92/nix-breakpoints
breakpointHook: add for debugging failing builds
Diffstat (limited to 'pkgs')
-rw-r--r--pkgs/applications/virtualization/cntr/default.nix24
-rw-r--r--pkgs/build-support/setup-hooks/breakpoint-hook.sh9
-rw-r--r--pkgs/top-level/all-packages.nix5
3 files changed, 38 insertions, 0 deletions
diff --git a/pkgs/applications/virtualization/cntr/default.nix b/pkgs/applications/virtualization/cntr/default.nix
new file mode 100644
index 00000000000..79dbddfab55
--- /dev/null
+++ b/pkgs/applications/virtualization/cntr/default.nix
@@ -0,0 +1,24 @@
+{ stdenv, rustPlatform, fetchFromGitHub }:
+
+rustPlatform.buildRustPackage rec {
+  name = "cntr-${version}";
+  version = "1.2.0";
+
+  src = fetchFromGitHub {
+    owner = "Mic92";
+    repo = "cntr";
+    rev = version;
+    sha256 = "0lmbsnjia44h4rskqkv9yc7xb6f3qjgbg8kcr9zqnr7ivr5fjcxg";
+  };
+
+  cargoSha256 = "0gainr5gfy0bbhr6078zvgx0kzp53slxjp37d3da091ikgzgfn51";
+
+  meta = with stdenv.lib; {
+    description = "A container debugging tool based on FUSE";
+    homepage = https://github.com/Mic92/cntr;
+    license = licenses.mit;
+    # aarch64 support will be fixed soon
+    platforms = [ "x86_64-linux" ];
+    maintainers = [ maintainers.mic92 ];
+  };
+}
diff --git a/pkgs/build-support/setup-hooks/breakpoint-hook.sh b/pkgs/build-support/setup-hooks/breakpoint-hook.sh
new file mode 100644
index 00000000000..6bef786ac3a
--- /dev/null
+++ b/pkgs/build-support/setup-hooks/breakpoint-hook.sh
@@ -0,0 +1,9 @@
+breakpointHook() {
+    local red='\033[0;31m'
+    local no_color='\033[0m'
+
+    echo -e "${red}build failed in ${curPhase} with exit code ${exitCode}${no_color}"
+    printf "To attach install cntr and run the following command as root:\n\n"
+    sh -c "echo '   cntr attach -t command cntr-${out}'; while true; do sleep 99999999; done"
+}
+failureHooks+=(breakpointHook)
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index dea13be70d0..dc12e6b0c7e 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -977,6 +977,9 @@ with pkgs;
 
   bruteforce-luks = callPackage ../tools/security/bruteforce-luks { };
 
+  breakpointHook = assert stdenv.isLinux;
+    makeSetupHook { } ../build-support/setup-hooks/breakpoint-hook.sh;
+
   bsod = callPackage ../misc/emulators/bsod { };
 
   btrfs-progs = callPackage ../tools/filesystems/btrfs-progs { };
@@ -16010,6 +16013,8 @@ with pkgs;
   cni = callPackage ../applications/networking/cluster/cni {};
   cni-plugins = callPackage ../applications/networking/cluster/cni/plugins.nix {};
 
+  cntr = callPackage ../applications/virtualization/cntr { };
+
   communi = libsForQt5.callPackage ../applications/networking/irc/communi { };
 
   confclerk = callPackage ../applications/misc/confclerk { };