Enhanced F# Language Features for Visual Studio Code
Part of the Ionide plugin suite.
F# 4.0 needs to be installed on your system in order to use Ionide
For more detailed instructions on installing F# :
FSC (F# Compiler) and FSI/fsharpi on Mono (F# Interactive) need to be added to your system PATH. The default location on Windows is
64-bit - C:\Program Files (x86)\Microsoft SDKs\F#\4.0\Framework\v4.0\
32-bit - C:\Program Files\Microsoft SDKs\F#\4.0\Framework\v4.0
Add MSBUILD_PATH environment variable which points to the home of Microsoft Build Tools, e.g., MSBUILD_PATH = D:\Program Files (x86)\MSBuild\14.0\Bin
.
You can download F# 4.0 here for Windows
Install the Microsoft Build Tools 2015
If you use chocolatey, you can install all the pre-requisites easily:
choco install windows-sdk-8.0 -y
choco install visualfsharptools -y
choco install microsoft-build-tools --version 14.0.25420.1 -y
choco install visualstudiocode -y
- Required: Mono >= 3.10
- Recommended: Mono >= 4.0.2
- Better syntax highlighting
- Auto completions
- Error highlighting and error list
- Tooltips
- Go to Declaration
- Show symbols in file
- Highlighting usages
- Install nodejs. (On Windows via chocolaty this is
C:\> choco install nodejs
) - Run
npm install -g vsce
to install vsce globally. - Fork the repo to your GitHub account, then clone locally.
- Run
build.cmd Build
(orbuild.sh Build
). If you have not done so already you may need to configure a GitHub SSH key. - Open folder in VSCode
code .
- Make changes
- Press
F5
to build plugin and start experimental instance of VSCode - Make PR ;)
- Enable Logging in User settings with
// FSharp configuration
// Set the verbosity for F# Language Service Output Channel
"FSharp.logLanguageServiceRequestsOutputWindowLevel": "DEBUG",
// Enable logging language service requests (FSAC) to an output channel, the developer tools console, or both
"FSharp.logLanguageServiceRequests": "both"
- Open the Output Panel and switch to the
F# Language Service
Channel - Or Toggle Developer Tools (
Help |> Toggle Developer Tools
) and open the console tab
The project is hosted on GitHub where you can report issues, fork the project and submit pull requests.
The library is available under MIT license, which allows modification and redistribution for both commercial and non-commercial purposes.