Author: raskin
Date: Wed May  2 03:14:05 2012
New Revision: 33968
URL: https://nixos.org/websvn/nix/?rev=33968&sc=1

Log:
Update Julia; a few fixes get included; changes to build system

Modified:
   nixpkgs/trunk/pkgs/development/compilers/julia/default.nix

Modified: nixpkgs/trunk/pkgs/development/compilers/julia/default.nix
==============================================================================
--- nixpkgs/trunk/pkgs/development/compilers/julia/default.nix  Tue May  1 
21:00:30 2012        (r33967)
+++ nixpkgs/trunk/pkgs/development/compilers/julia/default.nix  Wed May  2 
03:14:05 2012        (r33968)
@@ -1,6 +1,6 @@
 { stdenv, fetchgit, gfortran, perl, m4, llvm, gmp, pcre, blas, liblapack
  , readline, fftwSinglePrec, fftw, libunwind, suitesparse, glpk, fetchurl
- , ncurses, libunistring, lighttpd
+ , ncurses, libunistring, lighttpd, patchelf
  } :
 let
   liblapackShared = liblapack.override{shared=true;};
@@ -8,12 +8,12 @@
 in
 stdenv.mkDerivation rec {
   pname = "julia";
-  date = "20120410";
+  date = "20120501";
   name = "${pname}-git-${date}";
 
   grisu_ver = "1.1";
   dsfmt_ver = "2.1";
-  arpack_ver = "3.0.2";
+  arpack_ver = "3.1.0";
   clp_ver = "1.14.5";
   lighttpd_ver = "1.4.29";
 
@@ -27,9 +27,9 @@
     sha256 = 
"e9d3e04bc984ec3b14033342f5ebdcd5202d8d8e40128dd737f566945612378f";
   };
   arpack_src = fetchurl {
-    url = "http://forge.scilab.org/index.php/p/arpack-ng/downloads/353/get/";;
-    name = "arpack-ng-${arpack_ver}.tar.gz";
-    sha256 = 
"4add769386e0f6b0484491bcff129c6f5234190dbf58e07cc068fbd5dc7278bf";
+    url = "http://forge.scilab.org/index.php/p/arpack-ng/downloads/376/get/";;
+    name = "arpack-ng_${arpack_ver}.tar.gz";
+    sha256 = 
"65b7856126f06ecbf9ec450d50df92ca9260d4b0d21baf02497554ac230d6feb";
   };
   clp_src = fetchurl {
     url = "http://www.coin-or.org/download/source/Clp/Clp-${clp_ver}.tgz";;
@@ -43,12 +43,12 @@
 
   src = fetchgit {
     url = "git://github.com/JuliaLang/julia.git";
-    rev = "73776ba8ed510862b81eb1dd5c70e2055deb5895";
-    sha256 = 
"e833caeeecedc5603ee71405a8cb3813bf7ace10df8f7b4a43c7beccf0ccaf0d";
+    rev = "990ffabb00f0e51d326911888facdbc473fb634d";
+    sha256 = 
"dfcf41b2d7b62dd490bfd6f6fb962713c920de3f00afaee47423bd26eba7e3b2";
   };
 
   buildInputs = [ gfortran perl m4 gmp pcre llvm blas liblapackShared readline 
-    fftw fftwSinglePrec libunwind suitesparse glpk ncurses libunistring
+    fftw fftwSinglePrec libunwind suitesparse glpk ncurses libunistring 
patchelf
     ];
 
   configurePhase = ''
@@ -63,38 +63,51 @@
     }
 
     for i in "${grisu_src}" "${dsfmt_src}" "${arpack_src}" "${clp_src}" 
"${lighttpd_src}" ; do
-      copy_kill_hash "$i" external
+      copy_kill_hash "$i" deps
     done
-    copy_kill_hash "${dsfmt_src}" external/random
+    copy_kill_hash "${dsfmt_src}" deps/random
 
-    sed -e '/cd SuiteSparse-SYSTEM/,+1s@find /lib /usr/lib /usr/local/lib@find 
${suitesparse}/lib@' -i external/Makefile
+    sed -e '/cd SuiteSparse-SYSTEM/,+1s@find /lib /usr/lib /usr/local/lib@find 
${suitesparse}/lib@' -i deps/Makefile
 
     ${if realGcc ==null then "" else 
     ''export NIX_LDFLAGS="$NIX_LDFLAGS -L${realGcc}/lib -L${realGcc}/lib64 
-lpcre -llapack -lm -lfftw3f -lfftw3 -lglpk -lunistring "''}
 
     sed -e 's@ cpp @ gcc -E @g' -i base/Makefile
-  '';
 
-  preInstall = ''
-    export makeFlags="$makeFlags PREFIX=\"$out\""
+    sed -e '1s@#! */bin/bash@#!${stdenv.shell}@' -i deps/*.sh
+
+    export LDFLAGS="-L${suitesparse}/lib"
+
+    mkdir -p "$out/lib"
+    sed -e "s@/usr/local/lib@$out/lib@g" -i deps/Makefile
+    sed -e "s@/usr/lib@$out/lib@g" -i deps/Makefile
+    
+    sed -e '/libumfpack.a/s@find @find ${suitesparse}/lib @' -i deps/Makefile
+
+    export makeFlags="$makeFlags PREFIX=\"$out\" USR=\"$out\""
+
+    sed -e 's@openblas@blas@' -i base/*.jl
+
+    sed -e '/install -v julia-release-webserver/d' -i Makefile
+
+    export dontPatchELF=1
   '';
 
   postInstall = ''
-    mkdir -p "$out/bin"
-    ln -s "$out/share/julia/julia" "$out/bin"
+   ln -s "$out/share/julia/julia" "$out/bin"
 
-    mkdir -p "$out/share/julia/ui/"
-    cp -r ui/website "$out/share/julia/ui/"
-    cp external/lighttpd.conf "$out/share/julia/ui/"
-
-    mkdir -p "$out/share/julia/ui/webserver/"
-    cp -r ui/webserver/{*.jl,*.h} "$out/share/julia/ui/webserver/"
-
-    echo -e '#!/bin/sh' >> "$out/bin/julia-webserver"
-    echo -e "cd \"$out/share/julia\"" >> "$out/bin/julia-webserver"
-    echo -e '${lighttpd}/sbin/lighttpd -D -f ./ui/lighttpd.conf &' >> 
"$out/bin/julia-webserver"
-    echo -e './julia-release-webserver -p 2001' >> "$out/bin/julia-webserver"
-    chmod a+x "$out/bin/julia-webserver"
+   mkdir -p "$out/share/julia/ui/"
+   cp -r ui/website "$out/share/julia/ui/"
+   cp deps/lighttpd.conf "$out/share/julia/ui/"
+
+   mkdir -p "$out/share/julia/ui/webserver/"
+   cp -r ui/webserver/{*.jl,*.h} "$out/share/julia/ui/webserver/"
+
+   echo -e '#!/bin/sh' >> "$out/bin/julia-webserver"
+   echo -e "cd \"$out/share/julia\"" >> "$out/bin/julia-webserver"
+   echo -e '${lighttpd}/sbin/lighttpd -D -f ./ui/lighttpd.conf &' >> 
"$out/bin/julia-webserver"
+   echo -e '../../bin/julia-release-webserver -p 2001' >> 
"$out/bin/julia-webserver"
+   chmod a+x "$out/bin/julia-webserver"
   '';
 
   meta = {
_______________________________________________
nix-commits mailing list
nix-comm...@lists.science.uu.nl
http://lists.science.uu.nl/mailman/listinfo/nix-commits

Reply via email to