mirror of https://github.com/containers/podman.git
				
				
				
			
		
			
				
	
	
		
			89 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Nix
		
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Nix
		
	
	
	
| { system ? builtins.currentSystem }:
 | |
| let
 | |
|   pkgs = (import ./nixpkgs.nix {
 | |
|     config = {
 | |
|       packageOverrides = pkg: {
 | |
|         gpgme = (static pkg.gpgme);
 | |
|         libassuan = (static pkg.libassuan);
 | |
|         libgpgerror = (static pkg.libgpgerror);
 | |
|         libseccomp = (static pkg.libseccomp);
 | |
|         glib = (static pkg.glib).overrideAttrs (x: {
 | |
|           outputs = [ "bin" "out" "dev" ];
 | |
|           mesonFlags = [
 | |
|             "-Ddefault_library=static"
 | |
|             "-Ddevbindir=${placeholder ''dev''}/bin"
 | |
|             "-Dgtk_doc=false"
 | |
|             "-Dnls=disabled"
 | |
|           ];
 | |
|           postInstall = ''
 | |
|             moveToOutput "share/glib-2.0" "$dev"
 | |
|             substituteInPlace "$dev/bin/gdbus-codegen" --replace "$out" "$dev"
 | |
|             sed -i "$dev/bin/glib-gettextize" -e "s|^gettext_dir=.*|gettext_dir=$dev/share/glib-2.0/gettext|"
 | |
|             sed '1i#line 1 "${x.pname}-${x.version}/include/glib-2.0/gobject/gobjectnotifyqueue.c"' \
 | |
|               -i "$dev"/include/glib-2.0/gobject/gobjectnotifyqueue.c
 | |
|           '';
 | |
|         });
 | |
|         pcsclite = (static pkg.pcsclite).overrideAttrs (x: {
 | |
|           configureFlags = [
 | |
|             "--enable-confdir=/etc"
 | |
|             "--enable-usbdropdir=/var/lib/pcsc/drivers"
 | |
|             "--disable-libsystemd"
 | |
|             "--disable-libudev"
 | |
|             "--disable-libusb"
 | |
|           ];
 | |
|           buildInputs = [ pkgs.python3 pkgs.dbus ];
 | |
|         });
 | |
|         systemd = (static pkg.systemd).overrideAttrs (x: {
 | |
|           outputs = [ "out" "dev" ];
 | |
|           mesonFlags = x.mesonFlags ++ [
 | |
|             "-Dglib=false"
 | |
|             "-Dstatic-libsystemd=true"
 | |
|           ];
 | |
|         });
 | |
|       };
 | |
|     };
 | |
|   });
 | |
| 
 | |
|   static = pkg: pkg.overrideAttrs (x: {
 | |
|     doCheck = false;
 | |
|     configureFlags = (x.configureFlags or [ ]) ++ [
 | |
|       "--without-shared"
 | |
|       "--disable-shared"
 | |
|     ];
 | |
|     dontDisableStatic = true;
 | |
|     enableSharedExecutables = false;
 | |
|     enableStatic = true;
 | |
|   });
 | |
| 
 | |
|   self = with pkgs; buildGoModule rec {
 | |
|     name = "podman";
 | |
|     src = builtins.filterSource
 | |
|       (path: type: !(type == "directory" && baseNameOf path == "bin")) ./..;
 | |
|     vendorSha256 = null;
 | |
|     doCheck = false;
 | |
|     enableParallelBuilding = true;
 | |
|     outputs = [ "out" ];
 | |
|     nativeBuildInputs = [ bash gitMinimal go-md2man pkg-config which ];
 | |
|     buildInputs = [ glibc glibc.static glib gpgme libassuan libgpgerror libseccomp libapparmor libselinux ];
 | |
|     prePatch = ''
 | |
|       export CFLAGS='-static -pthread'
 | |
|       export LDFLAGS='-s -w -static-libgcc -static'
 | |
|       export EXTRA_LDFLAGS='-s -w -linkmode external -extldflags "-static -lm"'
 | |
|       export BUILDTAGS='static netgo osusergo exclude_graphdriver_btrfs exclude_graphdriver_devicemapper seccomp apparmor selinux'
 | |
|       export CGO_ENABLED=1
 | |
|     '';
 | |
|     buildPhase = ''
 | |
|       patchShebangs .
 | |
|       make bin/podman
 | |
|       make bin/podman-remote
 | |
|       make bin/rootlessport
 | |
|     '';
 | |
|     installPhase = ''
 | |
|       install -Dm755 bin/podman $out/bin/podman
 | |
|       install -Dm755 bin/podman-remote $out/bin/podman-remote
 | |
|       install -Dm755 bin/rootlessport $out/libexec/podman/rootlessport
 | |
|     '';
 | |
|   };
 | |
| in
 | |
| self
 |