-
Notifications
You must be signed in to change notification settings - Fork 123
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
WIP: Optionally remove dependency on MSBuild reference resolution #649
Conversation
Note this doesn't remove the use of MSBuild for project file cracking. But for deploying F# compilation that only uses scripts it should be adequate to allow the use of FCS with no MSBuild dependency An FSPROJ project cracker that has no MSBuild dependency would be another step towards our liberation. But that is very difficult (needs a whole MSBuild interpreter) and can depend on significant MSBuild internals. |
This looks great! I'll give this a test tomorrow. I just need to make sure that |
Do you think it would be possible to use the Msbuild parser from XS here in On 13 Oct 2016 12:24 a.m., "Jason Imison" [email protected] wrote:
|
@rneatherway Not easily - the XS parser uses msbuild anyway, so you wouldn't gain anything. |
What kind of scenario does msbuild resolver solve that the simplistic resolver won't ? |
@thinkbeforecoding When a versioned reference is being used like More problematic may be discrepancies, e.g. I assume the MSBuild reference resolver also checks process architecture, so if you're running FSI 32-bit it will find 32-bit DLLs should the DLLs be marked with process-specific architecture. I don't know if this is a problem in practice for F# scripts but I assume it could be. In other words I believe we can emulate the basic search that we ask the MSBuild reference resolver to perform, but there may be glitches in rarely-used corner cases. |
@thinkbeforecoding There is also a risk that simulated MSBuild reference resolution will be slower for the cases where it is used. I don't think this will be an issue though, since in most scenarios (Xamarin, Visual Studio) the client pre-resolves, and in other scenarios using FSharpChecker the resolution is not repeated unless the reference set changes |
open Microsoft.FSharp.Compiler.ReferenceResolver | ||
open Microsoft.FSharp.Compiler.AbstractIL.Internal.Library | ||
|
||
let internal SimulatedMSBuildResolver = |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this be exposed? I'm trying to remove the ProjectCracker dependency using Forge.ProjectSystem but I need a way to resolve dependencies. This would be very useful to resolve the core dependencies of .fsproj file.
@alfonsogarciacaro I suppose so, please submit a PR? |
I'm looking at removing the forced dependency on MSBuild for reference resolution (currenty MSBuild v12) and giving resasonable behaviour when MSBuild is not installed.
FCS only uses MSBuild reference resolution for referenced in scripts and direct calls to the F# compiler (it is not used when invoked via Visual Studio or Xamarin - except for scripts). Even then it is only for references like
#r "System.Xml
or#r "Sytem.Xml, Version=4.3.2.1,..." etc, which are not full assembly names but rather FullName specifications. (These
#rspecs can also be given on the
fsc.exe`` command line, though no one ever uses that).The idea in this PR is that if the flag
msbuildEnabled=false
is given toFSharpChecker
orFsiEvluationSession
then a more simplistic reference resolution mechanism (SimplisticResolver
) is used which simply searches paths and registry keys (and perhaps eventually the GAC) trying to emulate the behaviour of MS Build reference resolution.Implementation-wise, we factor the MSBuild reference resolution into a separate DLL (perhaps we will need one for each version of MSBuild we may want to interoperate with). This DLL is invoked by reflection by default. For the ones without versions like
#r "System.Xml"
, the resolution strategy in the PR should be adequate I think.The PR still uses MSBuild v12 by default if installed. But if Microsoft.Build.Framework 12.0.0.0 can't be loaded using Assembly.Load, then the component is not accessed and it defaults back to the SimplisticResolver resolver.
There are still sure to be glitches in SimplisticResolver - though if it passes FCS tests that's a pretty good indication that it's usable as a backoff strategy.