* Moved more stuff from the release tree.
svn path=/nixpkgs/trunk/; revision=13395
This commit is contained in:
parent
044c4dfe9f
commit
da8bcbd9a5
|
@ -0,0 +1,53 @@
|
||||||
|
# This function compiles a source tarball in a virtual machine image
|
||||||
|
# that contains a Debian-like (i.e. dpkg-based) OS. Currently this is
|
||||||
|
# just for portability testing: it doesn't produce any Debian
|
||||||
|
# packages.
|
||||||
|
|
||||||
|
vmTools: args: with args;
|
||||||
|
|
||||||
|
vmTools.runInLinuxImage (stdenv.mkDerivation (
|
||||||
|
|
||||||
|
{
|
||||||
|
name = "debian-build";
|
||||||
|
|
||||||
|
doCheck = true;
|
||||||
|
|
||||||
|
# Don't install the result in the Nix store.
|
||||||
|
useTempPrefix = true;
|
||||||
|
|
||||||
|
phases = "sysInfoPhase unpackPhase patchPhase configurePhase buildPhase checkPhase installPhase distPhase";
|
||||||
|
}
|
||||||
|
|
||||||
|
// args //
|
||||||
|
|
||||||
|
{
|
||||||
|
src = src.path;
|
||||||
|
|
||||||
|
# !!! cut&paste from rpm-build.nix
|
||||||
|
postHook = ''
|
||||||
|
ensureDir $out/nix-support
|
||||||
|
cat "$diskImage"/nix-support/full-name > $out/nix-support/full-name
|
||||||
|
|
||||||
|
# If `src' is the result of a call to `makeSourceTarball', then it
|
||||||
|
# has a subdirectory containing the actual tarball(s). If there are
|
||||||
|
# multiple tarballs, just pick the first one.
|
||||||
|
echo $src
|
||||||
|
if test -d $src/tarballs; then
|
||||||
|
src=$(ls $src/tarballs/*.tar.bz2 $src/tarballs/*.tar.gz | sort | head -1)
|
||||||
|
fi
|
||||||
|
''; # */
|
||||||
|
|
||||||
|
sysInfoPhase = ''
|
||||||
|
echo "System/kernel: $(uname -a)"
|
||||||
|
if test -e /etc/debian_version; then echo "Debian release: $(cat /etc/debian_version)"; fi
|
||||||
|
header "installed Debian packages"
|
||||||
|
dpkg-query --list
|
||||||
|
stopNest
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Test build on ${args.diskImage.fullName} (${args.diskImage.name})";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
))
|
|
@ -17,4 +17,10 @@ rec {
|
||||||
doCoverageAnalysis = true;
|
doCoverageAnalysis = true;
|
||||||
} // args);
|
} // args);
|
||||||
|
|
||||||
|
rpmBuild = args: import ./rpm-build.nix vmTools args;
|
||||||
|
|
||||||
|
debBuild = args: import ./debian-build.nix vmTools (
|
||||||
|
{ inherit stdenv;
|
||||||
|
} // args);
|
||||||
|
|
||||||
}
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
# This function builds an RPM from a source tarball that contains a
|
||||||
|
# RPM spec file (i.e., one that can be built using `rpmbuild -ta').
|
||||||
|
|
||||||
|
vmTools: args: with args;
|
||||||
|
|
||||||
|
vmTools.buildRPM (
|
||||||
|
|
||||||
|
{
|
||||||
|
name = "rpm-build";
|
||||||
|
}
|
||||||
|
|
||||||
|
// args //
|
||||||
|
|
||||||
|
{
|
||||||
|
src = src.path;
|
||||||
|
|
||||||
|
preBuild = ''
|
||||||
|
ensureDir $out/nix-support
|
||||||
|
cat "$diskImage"/nix-support/full-name > $out/nix-support/full-name
|
||||||
|
|
||||||
|
# If `src' is the result of a call to `makeSourceTarball', then it
|
||||||
|
# has a subdirectory containing the actual tarball(s). If there are
|
||||||
|
# multiple tarballs, just pick the first one.
|
||||||
|
if test -d $src/tarballs; then
|
||||||
|
src=$(ls $src/tarballs/*.tar.bz2 $src/tarballs/*.tar.gz | sort | head -1)
|
||||||
|
fi
|
||||||
|
''; # */
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
shopt -s nullglob
|
||||||
|
for i in $out/rpms/*/*.rpm; do
|
||||||
|
echo "file rpm $i" >> $out/nix-support/hydra-build-products
|
||||||
|
done
|
||||||
|
''; # */
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Build of an RPM package on ${args.diskImage.fullName} (${args.diskImage.name})";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
)
|
|
@ -233,6 +233,15 @@ rec {
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
|
||||||
|
modifyDerivation = f: attrs:
|
||||||
|
let attrsCleaned = removeAttrs attrs ["meta" "passthru" "outPath" "drvPath"];
|
||||||
|
newDrv = derivation (attrsCleaned // (f attrs));
|
||||||
|
in newDrv //
|
||||||
|
{ meta = if attrs ? meta then attrs.meta else {};
|
||||||
|
passthru = if attrs ? passthru then attrs.passthru else {};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/* Run a derivation in a Linux virtual machine (using Qemu/KVM). By
|
/* Run a derivation in a Linux virtual machine (using Qemu/KVM). By
|
||||||
default, there is no disk image; the root filesystem is a tmpfs,
|
default, there is no disk image; the root filesystem is a tmpfs,
|
||||||
and /nix/store is shared with the host (via the CIFS protocol to
|
and /nix/store is shared with the host (via the CIFS protocol to
|
||||||
|
@ -254,7 +263,7 @@ rec {
|
||||||
`run-vm' will be left behind in the temporary build directory
|
`run-vm' will be left behind in the temporary build directory
|
||||||
that allows you to boot into the VM and debug it interactively. */
|
that allows you to boot into the VM and debug it interactively. */
|
||||||
|
|
||||||
runInLinuxVM = attrs: derivation (removeAttrs attrs ["meta" "passthru" "outPath" "drvPath"] // {
|
runInLinuxVM = modifyDerivation (attrs: {
|
||||||
builder = "${bash}/bin/sh";
|
builder = "${bash}/bin/sh";
|
||||||
args = ["-e" (vmRunCommand qemuCommandLinux)];
|
args = ["-e" (vmRunCommand qemuCommandLinux)];
|
||||||
origArgs = attrs.args;
|
origArgs = attrs.args;
|
||||||
|
@ -289,7 +298,7 @@ rec {
|
||||||
- Reboot to shutdown the machine (because Qemu doesn't seem
|
- Reboot to shutdown the machine (because Qemu doesn't seem
|
||||||
capable of a APM/ACPI VM shutdown).
|
capable of a APM/ACPI VM shutdown).
|
||||||
*/
|
*/
|
||||||
runInGenericVM = attrs: derivation (removeAttrs attrs ["meta" "passthru" "outPath" "drvPath"] // {
|
runInGenericVM = modifyDerivation (attrs: {
|
||||||
system = "i686-linux";
|
system = "i686-linux";
|
||||||
builder = "${bash}/bin/sh";
|
builder = "${bash}/bin/sh";
|
||||||
args = ["-e" (vmRunCommand qemuCommandGeneric)];
|
args = ["-e" (vmRunCommand qemuCommandGeneric)];
|
||||||
|
|
Loading…
Reference in New Issue