This repo is where you can contribute to the F# compiler, core library and the Visual F# Tools.
To learn what F# is and why it's interesting, go to fsharp.org.
To get a free F# environment, go to fsharp.org.
License
Contributions made to this repo are subject to terms and conditions of the Apache License, Version 2.0. A copy of the license can be found in the License.txt file at the root of this distribution. By using this source code in any fashion, you are agreeing to be bound by the terms of the Apache License, Version 2.0. You must not remove this notice, or any other, from this software.
Questions? If you have questions about the source code, please ask in the issues and discussion forums.
The compiler is compiled as a set of .NET 4.0 components using a bootstrap process. This uses the Last Known Good (LKG) compiler to build.
Note that you need the .NET framework 3.5 installed on your machine in order to complete this step.
gacutil /i lkg\FSharp-2.0.50726.900\bin\FSharp.Core.dll
msbuild src\fsharp-proto-build.proj
This uses the proto compiler to build FSharp.Core.dll
, FSharp.Compiler.dll
, fsc.exe
, and fsi.exe
.
msbuild src/fsharp-library-build.proj
msbuild src/fsharp-compiler-build.proj
You can now use the updated F# compiler in debug\net40\bin\fsc.exe
and F# Interactive in debug\net40\bin\fsi.exe
to develop and test basic language and tool features.
Note: The updated library is not used until you run update.cmd
, see below. The updated compiler is not run 'pre-compiled' until you run update.cmd -ngen
, see below.
See TESTGUIDE.md for full details on how to run tests.
Prior to a Debug test run, you need to complete all of these steps:
msbuild src/fsharp-library-build.proj
msbuild src/fsharp-compiler-build.proj
msbuild src/fsharp-typeproviders-build.proj
msbuild src/fsharp-compiler-unittests-build.proj
msbuild src/fsharp-library-build.proj /p:TargetFramework=net20
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable47
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable7
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable78
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable259
msbuild src/fsharp-library-unittests-build.proj
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable47
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable7
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable78
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable259
src\update.cmd debug -ngen
tests\BuildTestTools.cmd debug
[Optional] If testing the Visual Studio bits (see below) you will also need:
msbuild vsintegration\fsharp-vsintegration-build.proj
msbuild vsintegration\fsharp-vsintegration-unittests-build.proj
Prior to a Release test run, you need to do all of these:
msbuild src/fsharp-library-build.proj /p:Configuration=Release
msbuild src/fsharp-compiler-build.proj /p:Configuration=Release
msbuild src/fsharp-typeproviders-build.proj /p:Configuration=Release
msbuild src/fsharp-compiler-unittests-build.proj /p:Configuration=Release
msbuild src/fsharp-library-build.proj /p:TargetFramework=net20 /p:Configuration=Release
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable47 /p:Configuration=Release
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable7 /p:Configuration=Release
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable78 /p:Configuration=Release
msbuild src/fsharp-library-build.proj /p:TargetFramework=portable259 /p:Configuration=Release
msbuild src/fsharp-library-unittests-build.proj /p:Configuration=Release
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable47 /p:Configuration=Release
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable7 /p:Configuration=Release
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable78 /p:Configuration=Release
msbuild src/fsharp-library-unittests-build.proj /p:TargetFramework=portable259 /p:Configuration=Release
src\update.cmd release -ngen
tests\BuildTestTools.cmd release
[Optional] If testing the Visual F# IDE Tools (see below) you will also need:
msbuild vsintegration\fsharp-vsintegration-build.proj /p:Configuration=Release
msbuild vsintegration\fsharp-vsintegration-unittests-build.proj /p:Configuration=Release
To build the VS components:
msbuild vsintegration\fsharp-vsintegration-build.proj
To install the VS components:
- Ensure that the VSIX package is uninstalled.
- In VS, select Tools/Extensions and Updates
- If the package
VisualStudio.FSharp.EnableOpenSource
is installed, select Uninstall
- Run
debug\net40\bin\EnableOpenSource.vsix
- Restart Visual Studio, it should now be running your freshly-built Visual F# IDE Tools.
- The
update.cmd
script adds the builtFSharp.Core
to the GAC, adds required strong name validation skips, and NGens the compiler and libraries. This requires admin privileges. - The compiler binaries produced are "private" and strong-named signed with a test key.
- Some additional tools are required to build the compiler, notably
fslex.exe
,fsyacc.exe
,FSharp.PowerPack.Build.Tasks.dll
,FsSrGen.exe
,FSharp.SRGen.Build.Tasks.dll
, and the other tools found in thelkg
directory. - The overall bootstrapping process executes as follows
- We first need an existing F# compiler. We use the one in the
lkg
directory. Let's assume this compiler has anFSharp.Core.dll
with version X. - We use this compiler to compile the source in this distribution, to produce a "proto" compiler, dropped to the
proto
directory. When run, this compiler still relies onFSharp.Core.dll
with version X. - We use the proto compiler to compile the source for
FSharp.Core.dll
in this distribution. - We use the proto compiler to compile the source for
FSharp.Compiler.dll
,fsc.exe
,fsi.exe
, and other binaries found in this distribution.