diff --git a/pkgs/development/compilers/fsharp41/default.nix b/pkgs/development/compilers/fsharp41/default.nix
new file mode 100644
index 000000000000..35e6749659e0
--- /dev/null
+++ b/pkgs/development/compilers/fsharp41/default.nix
@@ -0,0 +1,87 @@
+# Temporaririly avoid dependency on dotnetbuildhelpers to avoid rebuilding many times while working on it
+
+{ stdenv, fetchurl, pkgconfig, autoconf, automake, which, mono, dotnetbuildhelpers, dotnetPackages }:
+
+stdenv.mkDerivation rec {
+ name = "fsharp-${version}";
+ version = "4.1.7";
+
+ src = fetchurl {
+ url = "https://github.com/fsharp/fsharp/archive/${version}.tar.gz";
+ sha256 = "0rfkrk4mzi4w54mfqilvng9ar5swhmnwhsyjc54rx3fd0np3jiyl";
+ };
+
+ buildInputs = [
+ pkgconfig
+ autoconf
+ automake
+ which
+ mono
+ dotnetbuildhelpers
+ dotnetPackages.FsCheck262
+ dotnetPackages.FSharpCompilerTools
+ dotnetPackages.FSharpCore
+ dotnetPackages.FSharpData225
+ dotnetPackages.FsLexYacc704
+ dotnetPackages.MicrosoftDiaSymReader
+ dotnetPackages.MicrosoftDiaSymReaderPortablePdb
+ dotnetPackages.NUnit350
+ dotnetPackages.SystemCollectionsImmutable131
+ dotnetPackages.SystemReflectionMetadata
+ dotnetPackages.SystemValueTuple
+ ];
+
+ configurePhase = ''
+ substituteInPlace ./autogen.sh --replace "/usr/bin/env sh" "/bin/sh"
+ ./autogen.sh --prefix $out
+ '';
+
+ preBuild = ''
+ substituteInPlace Makefile --replace "MONO_ENV_OPTIONS=\$(monoopts) mono .nuget/NuGet.exe restore packages.config -PackagesDirectory packages -ConfigFile .nuget/NuGet.Config" "true"
+ substituteInPlace src/fsharp/Fsc-proto/Fsc-proto.fsproj --replace "" ""
+ substituteInPlace src/fsharp/Fsc-proto/Fsc-proto.fsproj --replace "" ""
+ substituteInPlace src/fsharp/Fsc-proto/Fsc-proto.fsproj --replace "" ""
+ substituteInPlace src/fsharp/Fsc-proto/Fsc-proto.fsproj --replace "" ""
+
+ rm -rf packages
+ mkdir packages
+
+ ln -s ${dotnetPackages.FsCheck262}/lib/dotnet/FsCheck packages/FsCheck.2.6.2
+ ln -s ${dotnetPackages.FSharpCompilerTools}/lib/dotnet/FSharp.Compiler.Tools packages/FSharp.Compiler.Tools.4.1.4
+ ln -s ${dotnetPackages.FSharpCore}/lib/dotnet/FSharp.Core/ packages/FSharp.Core.4.0.0.1
+ ln -s ${dotnetPackages.FSharpData225}/lib/dotnet/FSharp.Data/ packages/FSharp.Data.2.2.5
+ ln -s ${dotnetPackages.FsLexYacc704}/lib/dotnet/FsLexYacc/ packages/FsLexYacc.7.0.4
+ ln -s ${dotnetPackages.MicrosoftDiaSymReader}/lib/dotnet/Microsoft.DiaSymReader/ packages/Microsoft.DiaSymReader.1.1.0
+ ln -s ${dotnetPackages.MicrosoftDiaSymReaderPortablePdb}/lib/dotnet/Microsoft.DiaSymReader.PortablePdb/ packages/Microsoft.DiaSymReader.PortablePdb.1.2.0
+ ln -s ${dotnetPackages.NUnit350}/lib/dotnet/NUnit/ packages/NUnit.3.5.0
+ ln -s ${dotnetPackages.SystemCollectionsImmutable131}/lib/dotnet/System.Collections.Immutable/ packages/System.Collections.Immutable.1.3.1
+ ln -s ${dotnetPackages.SystemReflectionMetadata}/lib/dotnet/System.Reflection.Metadata/ packages/System.Reflection.Metadata.1.4.2
+ ln -s ${dotnetPackages.SystemValueTuple}/lib/dotnet/System.ValueTuple/ packages/System.ValueTuple.4.3.0
+ '';
+
+ # Make sure the executables use the right mono binary,
+ # and set up some symlinks for backwards compatibility.
+ postInstall = ''
+ substituteInPlace $out/bin/fsharpc --replace " mono " " ${mono}/bin/mono "
+ substituteInPlace $out/bin/fsharpi --replace " mono " " ${mono}/bin/mono "
+ substituteInPlace $out/bin/fsharpiAnyCpu --replace " mono " " ${mono}/bin/mono "
+ ln -s $out/bin/fsharpc $out/bin/fsc
+ ln -s $out/bin/fsharpi $out/bin/fsi
+ for dll in "$out/lib/mono/fsharp"/FSharp*.dll
+ do
+ create-pkg-config-for-dll.sh "$out/lib/pkgconfig" "$dll"
+ done
+ '';
+
+ # To fix this error when running:
+ # The file "/nix/store/path/whatever.exe" is an not a valid CIL image
+ dontStrip = true;
+
+ meta = {
+ description = "A functional CLI language";
+ homepage = "http://fsharp.org/";
+ license = stdenv.lib.licenses.asl20;
+ maintainers = with stdenv.lib.maintainers; [ thoughtpolice raskin ];
+ platforms = with stdenv.lib.platforms; unix;
+ };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 843678f57ae3..fef823a30b65 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -5261,6 +5261,10 @@ with pkgs;
fsharp = callPackage ../development/compilers/fsharp { };
+ fsharp41 = callPackage ../development/compilers/fsharp41 {
+ mono = mono46;
+ };
+
fstar = callPackage ../development/compilers/fstar {
ocamlPackages = ocaml-ng.ocamlPackages_4_02;
};
diff --git a/pkgs/top-level/dotnet-packages.nix b/pkgs/top-level/dotnet-packages.nix
index 71f2326b9379..ac4c5eaac64c 100644
--- a/pkgs/top-level/dotnet-packages.nix
+++ b/pkgs/top-level/dotnet-packages.nix
@@ -46,6 +46,20 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/net40/*" ];
};
+ FSharpCore = fetchNuGet {
+ baseName = "FSharp.Core";
+ version = "4.0.0.1";
+ sha256 = "01nhjcxdz8l1r5vvdzhmgy5x7z5fqppab3ki34qg14axgf8jjygn";
+ outputFiles = [ "*" ];
+ };
+
+ FSharpData225 = fetchNuGet {
+ baseName = "FSharp.Data";
+ version = "2.2.5";
+ sha256 = "1c9l6bk0d2srccash2980y9phq3kmfm0m76k4wghnysnq94vm724";
+ outputFiles = [ "*" ];
+ };
+
FSharpDataSQLProvider = fetchNuGet {
baseName = "SQLProvider";
version = "0.0.9-alpha";
@@ -60,6 +74,13 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/net45/*" ];
};
+ FsCheck262 = fetchNuGet {
+ baseName = "FsCheck";
+ version = "2.6.2";
+ sha256 = "0fh9yvsc4i61z31qf00d6gjv6xxd54pv1ykf5bpv95a5crc3qfvl";
+ outputFiles = [ "*" ];
+ };
+
FsCheckNunit = fetchNuGet {
baseName = "FsCheck.Nunit";
version = "1.0.4";
@@ -67,6 +88,13 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/net45/*" ];
};
+ FSharpCompilerTools = fetchNuGet {
+ baseName = "FSharp.Compiler.Tools";
+ version = "4.1.4";
+ sha256 = "0vsp0khlnwh15ibg8s161rw6a6i8rlriclpq53paga447jllf0m8";
+ outputFiles = [ "*" ];
+ };
+
FsLexYacc = fetchNuGet {
baseName = "FsLexYacc";
version = "6.1.0";
@@ -74,6 +102,13 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "build/*" ];
};
+ FsLexYacc704 = fetchNuGet {
+ baseName = "FsLexYacc";
+ version = "7.0.4";
+ sha256 = "01zpdb0pybdf0by02rwd7pb1g0cmnn8jxm2pibzxjxw6f4l43ywi";
+ outputFiles = [ "*" ];
+ };
+
FsPickler = fetchNuGet {
baseName = "FsPickler";
version = "1.2.9";
@@ -102,6 +137,13 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/*" ];
};
+ NUnit350 = fetchNuGet {
+ baseName = "NUnit";
+ version = "3.5.0";
+ sha256 = "19fxq9cf754ygda5c8rn1zqs71pfxi7mb96jwqhlichnqih6i16z";
+ outputFiles = [ "*" ];
+ };
+
NUnit2 = fetchNuGet {
baseName = "NUnit";
version = "2.6.4";
@@ -153,6 +195,13 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "tools/*" ];
};
+ SystemValueTuple = fetchNuGet {
+ baseName = "System.ValueTuple";
+ version = "4.3.0";
+ sha256 = "00p5s753xh5417arw3k6npf1pc1k3m1s9mrlkw5vmc7pg8lm6n88";
+ outputFiles = [ "*" ];
+ };
+
RestSharp = fetchNuGet {
baseName = "RestSharp";
version = "105.2.3";
@@ -195,6 +244,20 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/*" ];
};
+ MicrosoftDiaSymReader = fetchNuGet {
+ baseName = "Microsoft.DiaSymReader";
+ version = "1.1.0";
+ sha256 = "04dgwy6nyxksd1nb24k5c5vz8naggg7hryadvwqnm2v3alkh6g88";
+ outputFiles = [ "*" ];
+ };
+
+ MicrosoftDiaSymReaderPortablePdb = fetchNuGet {
+ baseName = "Microsoft.DiaSymReader.PortablePdb";
+ version = "1.2.0";
+ sha256 = "0qa8sqg0lzz9galkkfyi8rkbkali0nxm3qd5y4dlxp96ngrq5ldz";
+ outputFiles = [ "*" ];
+ };
+
NUnitRunners = fetchNuGet {
baseName = "NUnit.Runners";
version = "2.6.4";
@@ -210,6 +273,20 @@ let self = dotnetPackages // overrides; dotnetPackages = with self; {
outputFiles = [ "lib/portable-net45+win8+wp8+wpa81/*" ];
};
+ SystemCollectionsImmutable131 = fetchNuGet {
+ baseName = "System.Collections.Immutable";
+ version = "1.3.1";
+ sha256 = "149fcp7k7r9iw24dv5hbaij0c38kcv28dyhzbkggilfh4x2hy8c2";
+ outputFiles = [ "*" ];
+ };
+
+ SystemReflectionMetadata = fetchNuGet {
+ baseName = "System.Reflection.Metadata";
+ version = "1.4.2";
+ sha256 = "19fhdgd35yg52gyckhgwrphq07nv7v7r73hcg69ns94xfg1i6r7i";
+ outputFiles = [ "*" ];
+ };
+
Suave = fetchNuGet {
baseName = "Suave";
version = "0.29.0";