The F# compiler, FSharp.Core library, and tools for F#
Перейти к файлу
John Wostenberg a4927e182d Update DEVGUIDE.md (#4501)
* Add documentation about XLF localization and updating resx

* Clean up doc a little bit, and make some changes suggested by markdownlint

* Grammar

* Change wording

* Fix formatting mistake

* Fix another typo
2018-03-13 11:55:56 +00:00
.nuget move NuGet.Config to the root 2018-02-22 18:46:40 -08:00
.vscode Port build.cmd to build.sh (#2497) 2017-02-28 10:26:58 -08:00
artifacts Implement Proposal B: https://github.com/fsharp/fslang-design/blob/master/RFCs/FS-1034-fsharp-core-package.md (#3101) 2017-05-25 16:16:40 -07:00
build consolidate Newtonsoft.Json version to match what's shipped in VS 2018-03-09 14:46:48 -08:00
fcs upgrade System.ValueTuple to 4.4.0 (asm ver 4.0.2.0) 2018-03-05 13:22:43 -08:00
mono get latest mono in CI (#4394) 2018-02-24 00:39:30 +00:00
scripts Fix the Mono and OSX builds (#4273) 2018-01-29 19:30:42 +00:00
setup consolidate VS package version generation 2018-03-12 13:22:00 -07:00
src Equality is 0 (#4493) 2018-03-12 17:50:05 +00:00
tests Equality is 0 (#4493) 2018-03-12 17:50:05 +00:00
vsintegration don't try to include VSSDK targets if they haven't been restored yet 2018-03-12 16:16:37 -07:00
.gitattributes [WIP] simplify mono build (#4358) 2018-02-17 19:30:19 +01:00
.gitignore [WIP] simplify mono build (#4358) 2018-02-17 19:30:19 +01:00
BuildToolsVersion.txt Enable Build/CI with Mono (#1703) 2016-11-06 18:49:18 +00:00
CHANGELOG.md Test CI after https://github.com/Microsoft/visualfsharp/pull/4392 2018-02-24 00:08:39 +00:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2017-09-15 23:35:29 -07:00
CONTRIBUTING.md rename src/fsharp/vs --> src/fsharp/service (#4119) 2017-12-15 16:56:14 +00:00
DEVGUIDE.md Update DEVGUIDE.md (#4501) 2018-03-13 11:55:56 +00:00
DotnetCLIToolsVersion.txt Update Dependencies (#3884) 2017-11-06 20:19:45 -08:00
DotnetCLIVersion.txt Update build tools to latest (#1651) 2016-10-24 22:57:24 -07:00
FSharp.Directory.Build.props honor the environment variable $NUGET_PACKAGES for package restore 2018-03-12 15:46:20 -07:00
FSharp.Directory.Build.targets ensure build outputs always go to `$(Configuration)\$(TargetDotnetProfile)\bin` 2018-03-07 12:42:08 -08:00
FSharp.sln [WIP] simplify mono build (#4358) 2018-02-17 19:30:19 +01:00
ISSUE_TEMPLATE.md Suggest to attach a zip in issue template (#3478) 2017-08-21 13:36:59 +01:00
License.txt Adopt the MIT License (#3517) 2017-08-31 16:02:26 -07:00
Makefile move NuGet.Config to the root 2018-02-22 18:46:40 -08:00
NuGet.Config Merge remote-tracking branch 'upstream/dev15.6' into merges/dev15.6-to-master 2018-03-05 11:25:55 -08:00
PublishToBlob.proj Update feed tasks version 2018-02-28 08:49:41 -08:00
README.md fixes typos (#4459) 2018-03-07 16:05:59 +00:00
RoslynPackageVersion.txt Merge remote-tracking branch 'upstream/dev15.6' into merges/dev15.6-to-master 2018-03-05 11:25:55 -08:00
TESTGUIDE.md Minor fix (#4195) 2018-01-18 11:22:52 -08:00
VisualFSharp.sln remove the `Proto` configuration from VisualFSharp.sln 2018-03-07 14:21:45 -08:00
attributions.md Update attributions.md (#3490) 2017-08-23 10:36:26 -07:00
build-everything.proj Merge remote-tracking branch 'upstream/dev15.6' into merges/dev15.6-to-master 2018-03-05 11:25:55 -08:00
build-nuget-packages.proj build nuget packages after signing (#4269) 2018-01-26 17:16:52 -08:00
build.cmd Merge pull request #4453 from brettfo/restore-order 2018-03-06 16:04:56 -08:00
build.sh Merge remote-tracking branch 'upstream/dev15.6' into merges/dev15.6-to-master 2018-03-05 11:25:55 -08:00
code Create code 2017-09-15 23:33:41 -07:00
init-tools.cmd ensure the expected dotnet CLI is actually present 2017-11-20 11:09:49 -08:00
init-tools.sh Build proto using dotnet cli (#3232) 2017-06-21 10:40:06 -07:00
netci.groovy update CI to allow sudo on Ubuntu (#4392) 2018-02-24 00:08:11 +00:00
packages.config consolidate Newtonsoft.Json version to match what's shipped in VS 2018-03-09 14:46:48 -08:00
verify-translations.cmd add manual helper script to verify all translations 2018-02-08 13:31:11 -08:00

README.md

The F# Language, Library, and Visual F# Tools Repository

You are invited to help produce future releases of the F# language compiler, library, and tools. This repository enables development on Linux, macOS and Windows, along with some automated CI testing for these.

The F# Compiler and Tools are also mirrored in the corresponding repository of the F# Software Foundation.

Changes contributed here are eventually propagated to this repository and are included in all packagings of F# and open source F# editing tools. The process for doing this is explained in this guide by the F# Core Engineering Group. Currently, the F# community coordinates packaging other editions of F# for use on Linux, macOS, Android, iOS, and other platforms, and Microsoft coordinates packaging this repository as part of the Visual F# Tools.

For historical reasons this repository is called "visualfsharp" and currently also contains the Visual F# IDE Tools. The eventual plan is to split these repositories into "fsharp" and "visualfsharp".

Build Status

Ubuntu (Build) Windows (Debug Build) Windows (Release Tests 1) Windows (Release Tests 2) Windows (Release Tests 3)
master Build Status Build Status Build Status Build Status Build Status
dev15.5 Build Status Build Status Build Status Build Status Build Status
dev15.6 Build Status Build Status Build Status Build Status Build Status
dev15.7 Build Status Build Status Build Status Build Status Build Status

Help improve the Quality of the Tools by Using the Nightly Releases of Visual F# Tools

To setup Visual Studio to use the latest nightly releases of the Visual F# Tools: https://blogs.msdn.microsoft.com/dotnet/2017/03/14/announcing-nightly-releases-for-the-visual-f-tools/

Contributing

See DEVGUIDE.md and TESTGUIDE.md for details on build, development, and testing.

See CONTRIBUTING.md for general guidelines on the contribution process, also how we label issues and PRs

To contribute to the F# ecosystem more generally see the F# Software Foundation's Community Projects pages.

Branches

These are the branches in use:

  • master = Latest branch for OSS developers and nightly users.

    • Most contributions go here.
    • Able to be built, installed and used in the latest public Visual Studio release.
    • May contain updated F# features and logic.
    • Used to build nightly VSIX (see above).
    • Gets integrated into https://github.com/fsharp/fsharp to form the basis of Mono releases
    • Gets integrated into https://github.com/fsharp/FSharp.Compiler.Service to form the basis of FSharp.Compiler.Service releases
  • dev15.x

    • Latest release branch for the particular point release of Visual Studio.
    • Incorporates features and fixes from master up to a particular branch point, then selective cherry-picks.
    • May contain new features that depend on new things or fixes in the corresponding Visual Studio release.
    • Gets integrated back into master once the corresponding Visual Studio release is made.
    • Used to build Visual F# Tool updates

Technical Documentation

License

This project is subject to the MIT License. A copy of this license can be found in License.txt at the root of this repo.

Using

For typical installs of F#, see http://fsharp.org.

Using Nightly Releases of Visual F# Tools

To setup Visual Studio to use the latest nightly releases of the Visual F# Tools:

https://blogs.msdn.microsoft.com/dotnet/2017/03/14/announcing-nightly-releases-for-the-visual-f-tools/

If you wish to set up a Preview nightly atop Visual Studio preview builds, you can either download a VSIX Manually from here or set up a VSIX feed in visual studio from here.

Using CI Builds

To install F#, see http://fsharp.org.

To download the bits for the latest CI builds see these instructions. This includes and ZIPs containing the F# compiler and VSIX installers for the Visual F# IDE Tools.

Using F# on a build server or computer without an F# installation

If you wish to use the latest F# compiler on a computer without Visual Studio 2017 installed, you can add the nuget package FSharp.Compiler.Tools to your projects. This will replace the in-box compiler with the version contained in the package. The actual package is built in https://github.com/fsharp/fsharp.

You will need to adjust the targets reference on your project file to use the targets file from the installed FSharp.Compiler.Tools package. See https://github.com/fsharp/fsharp/issues/676 for how to modify your project file.

Code of Conduct

This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behavior in our community. This code of conduct has been adopted by many other projects. For more information see the Code of conduct.

Get In Touch

Follow @VisualFSharp and @fsharporg on twitter and subscribe to the .NET Blog.

Members of the F# Software Foundation can be invited to the "F# Software Foundation" discussion rooms on slack. More details at http://fsharp.org/guides/slack/.