Another initial MinGW environment, having some more basic tools. This will allow us to compile some packages for the stdenv from source.

svn path=/nixpkgs/trunk/; revision=6134
This commit is contained in:
Martin Bravenboer 2006-08-16 15:43:34 +00:00
parent 4957325c31
commit 38de63873c
3 changed files with 115 additions and 71 deletions

View File

@ -8,29 +8,98 @@
{system} : {system} :
let { let {
body =
stdenvFinal;
/** /**
* Initial standard environment based on native cygwin tools. * Initial standard environment based on native Cygwin tools.
*/ */
stdenvInit1 = stdenvInit1 =
import ./simple-stdenv { import ./simple-stdenv {
inherit system; inherit system;
name = "stdenv-initial-cygwin"; name = "stdenv-init1-mingw";
shell = "/bin/bash.exe"; shell = "/bin/bash.exe";
path = ["/usr/bin" "/bin"]; path = ["/usr/bin" "/bin"];
}; };
/** /**
* Initial standard environment based on MSYS tools. * Initial standard environment based on MSYS tools.
* From this point, Cygwin should no longer by involved.
*/ */
stdenvInit2 = stdenvInit2 =
import ./simple-stdenv { import ./simple-stdenv {
inherit system; inherit system;
name = "stdenv-initial-msys"; name = "stdenv-init2-mingw";
shell = msys + /bin/sh.exe; shell = msysShell;
path = [(msys + /bin)]; path = [(msys + /bin)];
}; };
/**
* Initial standard environment with the most basic MinGW packages.
*/
stdenvInit3 =
(import ./simple-stdenv) {
inherit system;
name = "stdenv-init3-mingw";
shell = msysShell;
path = [ (make + /bin) (msys + /bin) (binutils /bin) (gccCore + /bin) ];
};
/**
* Final standard environment, based on generic stdenv.
* It would be better to make the generic stdenv usable on
* MINGW (i.e. make all environment variables CAPS).
*/
stdenvFinal =
let {
body =
stdenv // mkDerivationFun;
shell =
msys + /bin/sh + ".exe";
gccWrapper = (import ../../build-support/gcc-wrapper) {
name = "mingw-gcc-wrapper";
nativeTools = false;
nativeGlibc = true;
shell = msysShell;
binutils = binutils;
gcc = gccCore // { langC = true; langCC = false; langF77 = false; };
/**
* Tricky: gcc-wrapper cannot be constructed using the MSYS shell
* so we use the Cygwin shell.
*/
stdenv = stdenvInit1;
};
stdenv =
stdenvInit2.mkDerivation {
name = "stdenv-mingw";
builder = ./builder.sh;
substitute = ../../build-support/substitute/substitute.sh;
setup = ./setup.sh;
initialPath = [make msys];
gcc = gccWrapper;
shell = msysShell;
};
mkDerivationFun = {
mkDerivation = attrs:
(derivation (
(removeAttrs attrs ["meta"])
//
{
builder = if attrs ? realBuilder then attrs.realBuilder else shell;
args = if attrs ? args then attrs.args else
["-e" (if attrs ? builder then attrs.builder else ../generic/default-builder.sh)];
inherit stdenv system;
})
)
// { meta = if attrs ? meta then attrs.meta else {}; };
};
};
/** /**
* Fetchurl, based on Cygwin curl in stdenvInit1 * Fetchurl, based on Cygwin curl in stdenvInit1
*/ */
@ -61,63 +130,25 @@ let {
}; };
}; };
/** msysShell =
* Complete standard environment, based on generic stdenv. msys + /bin/sh + ".exe";
* It would be better to make the generic stdenv usable on
* MINGW (i.e. make all environment variables CAPS).
*/
body =
let {
body =
stdenv // mkDerivationFun;
shell = msys + /bin/sh + ".exe"; gccCore =
(import ./pkgs).gccCore {
binpkgs =
(import ./pkgs) {
stdenv = stdenvInit2; stdenv = stdenvInit2;
inherit fetchurl; inherit fetchurl;
}; };
gcc = (import ../../build-support/gcc-wrapper) { make =
name = "mingw-gcc-wrapper"; (import ./pkgs).make {
nativeTools = false; stdenv = stdenvInit2;
nativeGlibc = true; inherit fetchurl;
inherit shell; # Note: this is the MSYS shell.
binutils = binpkgs.binutils;
gcc = binpkgs.gccCore // { langC = true; langCC = false; langF77 = false; };
/**
* Tricky: gcc-wrapper cannot be constructed using the MSYS shell
* so we use the Cygwin shell.
*/
stdenv = stdenvInit1;
}; };
stdenv = binutils =
stdenvInit2.mkDerivation { (import ./pkgs).binutils {
name = "stdenv-mingw"; stdenv = stdenvInit2;
builder = ./builder.sh; inherit fetchurl;
substitute = ../../build-support/substitute/substitute.sh;
setup = ./setup.sh;
initialPath = [binpkgs.make msys];
inherit shell gcc;
};
mkDerivationFun = {
mkDerivation = attrs:
(derivation (
(removeAttrs attrs ["meta"])
//
{
builder = if attrs ? realBuilder then attrs.realBuilder else shell;
args = if attrs ? args then attrs.args else
["-e" (if attrs ? builder then attrs.builder else ../generic/default-builder.sh)];
inherit stdenv system;
})
)
// { meta = if attrs ? meta then attrs.meta else {}; };
};
}; };
} }

View File

@ -1,17 +1,7 @@
/** /**
* MinGW packages. * MinGW packages.
*/ */
let { rec {
/**
* stdenv and fetchurl are parameters of every function to make this more flexible:
* after some packages, we might be able to use a better stdenv/fetchurl.
*/
body = {stdenv, fetchurl} : {
make = make { inherit stdenv fetchurl; };
gccCore = gccCore { inherit stdenv fetchurl; };
binutils = binutils { inherit stdenv fetchurl; };
};
/** /**
* Make. Binary. * Make. Binary.
@ -55,6 +45,19 @@ let {
}; };
}; };
/**
* MinGW Runtime. Source.
*/
mingwRuntime = {stdenv, fetchurl} :
stdenv.mkDerivation {
name = "mingw-runtime-3.10";
src =
fetchurl {
url = http://surfnet.dl.sourceforge.net/sourceforge/mingw/mingw-runtime-3.10-src.tar.gz;
md5 = "9225684e663eafa900b4075731c25f4c";
};
};
/* /*
pkgs.coreutils pkgs.coreutils
pkgs.findutils pkgs.findutils

View File

@ -2,6 +2,16 @@ set -e
test -z $NIX_GCC && NIX_GCC=@GCC@ test -z $NIX_GCC && NIX_GCC=@GCC@
# Workaround MSYS shell problem
if test -z "$out"; then
out="$OUT"
src="$SRC"
srcs="$SRCS"
buildInputs="$BUILDINPUTS"
propagatedBuildInputs="$PROPAGATEDBUILDINPUTS"
succeedOnFailure="$SUCCEEDONFAILURE"
fi
# Set up the initial path. # Set up the initial path.
PATH= PATH=
for i in $NIX_GCC @INITIALPATH@; do for i in $NIX_GCC @INITIALPATH@; do