Skip to content
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

Deliver CoreFx façades next to MSBuild.exe #1542

Closed
rainersigwald opened this issue Jan 11, 2017 · 43 comments
Closed

Deliver CoreFx façades next to MSBuild.exe #1542

rainersigwald opened this issue Jan 11, 2017 · 43 comments
Assignees
Labels

Comments

@rainersigwald
Copy link
Member

We just encountered an intermittent failure fixed by dotnet/sdk#629 that occurred because façade assemblies are no longer available in the MSBuild.exe directory.

Prior to RC.3, the façade assemblies were available because Roslyn placed them next to its assemblies, which were in the MSBuild bin directory. After #1406 moved Roslyn to its own directory, the façades were no longer available to tasks that did not redistribute them (unless some other mechanism had loaded them already).

Since we expect it to be common to build a task assembly that depends on these façades, it would be nice if MSBuild itself distributed them so they're available to the loader for all tasks and the tasks don't have to each redistribute them.

@rainersigwald rainersigwald added this to the Visual Studio 15 RTM milestone Jan 11, 2017
@jaredpar
Copy link
Member

In addition to distributing the facades MSBuild should have some docs / be explicit about exactly which version of Desktop / Net Core it supports for a given version.

From an extensibility stand point I need to know what version of Net Standard I should target with my extension. For an extension targeting that version I should have no need to deploy facades as MSBuild should be providing them.

@rainersigwald
Copy link
Member Author

Talked about this with @jaredpar and @AndyGerlicher yesterday. The plan is:

  • MSBuild will ship with a set of .NET Standard 1.3 façades.
  • Document that MSBuild tasks should be compiled against .NET Standard 1.3 (and a specific set of façades).
  • Add binding redirects for lower versions of the façades that we ship to the version that we ship.

@MattGertz
Copy link

JoC would like you to talk to Eric St. John first.

@dsplaisted
Copy link
Member

I'd suggest getting @ericstj and @weshaggard's feedback on this. I think we made the statement yesterday that the facades are part of the platform and thus should be provided by MSBuild. I've realized that's not always true- we sometimes deliver facades in NuGet packages to make things work on versions of .NET that have already shipped. And if the facades really were part of the platform, then they should already be there and MSBuild shouldn't need to provide them.

I don't mean to imply that we shouldn't include the facades with MSBuild- it might be the right thing to do. But I think we should talk to the facade experts first.

@jaredpar
Copy link
Member

And if the facades really were part of the platform, then they should already be there and MSBuild shouldn't need to provide them.

It's very common when targeting Net Standard, even when running on desktop, for an EXE to be required to deploy facades in order to successfully run. Today MSBuild is deploying only a minimal subset of the facades. That leaves every extension guessing which of the remaining faceds it should / shouldn't be deploying in order to run.

The most consistent story here is for MSBuild, which is an extensibility platform, to ship the full set of facades. Consider other extensibility environments like Visual Studio which had the same problem and came to the same conclusion.

@ericstj
Copy link
Member

ericstj commented Jan 25, 2017

I think that MSBuild should include the largest set of desktop facades that is available at the time it ships in order to enable folks to limit their redist dependencies from tasks. It's not tied to a "netstandard" version, the facades were talking about here are used for desktop, not netstandard. So I'd expect you to include the latest facades for whichever version of desktop you are targeting. The set should be at least MSBuild and its closure, probably all of NETStandard.Library and its closure. As Jared suggests you can go as far as pulling in every package we ship from CoreFx that supports desktop, I'm leaning this way myself. While we're at it, how about throwing in a version of JSON.Net and some other popular nuget packages? I'm only half-kidding here, dealing with dependencies in desktop MSBuild tasks is a pain.

To restate, we're only talking about desktop here, for netcore you get what's in the shared framework. I suppose if you wanted to bundle some additional assemblies next to your netcoreapp version of MSBuild you could, but its less interesting because the binding model for netcore is less rigid (no binding redirects).

If you're recommending folks publish a netstandard project as a raw dll and expecting that to work generically, it won't. Consider that there are plenty of fat packages out there and a library published for netstandard will be missing its TFM-specific assets.

Finally in all these cases folks need to know what not to put in their packages because build/publish isn't going to do the right thing. Perhaps in v.Next you can make use of the trimming / conflict resolution we're putting in to model what's in your MSBuild "platform".

@jaredpar
Copy link
Member

@ericstj

It's not tied to a "netstandard" version, the facades were talking about here are used for desktop, not netstandard.

MSBuild is both a desktop and CoreClr application. It now supports hosting task DLLs which are portable and target Net Standard. Why should they target desktop here?

To restate, we're only talking about desktop here, for netcore you get what's in the shared framework.

Look at this from the other angle. I'm an MSBuild task author and I want to build a portable task. How can MSBuild communicate the set of facades that will be available to my task when run on either runtime? Anything not guaranteed to be available is a facade my task needs to bundle.

@ericstj
Copy link
Member

ericstj commented Jan 25, 2017

MSBuild is both a desktop and CoreClr application. It now supports hosting task DLLs which are portable and target Net Standard. Why should they target desktop here?

That's a requirement and something they should already doing for their EXE. There is no such thing as a portable layout for an exe. Consider that the System.Runtime.dll, etc for desktop are very different from the .NET core: you cannot have one application layout that works in both places. They need not target desktop, but they should already be publishing for it.

Look at this from the other angle. I'm an MSBuild task author and I want to build a portable task.

Yeah I understand that. MSBuild is free to go off and define their own set of assemblies they consider their platform: not just facades, but actual contracts (even 3rd party libraries as I previously suggested). That's a different pivot than desktop facades and its a discussion that looks more like "what's the set of API that MSBuild provides as a platform". I was trying to scope this thread because, presumably, NETCoreApp has already done a decent analysis here with shared framework and thats a superset of what MSBuild would want. Sure, MSBuild is free to be different, but then they cannot piggy-back on the shared-framework trimming that already exists.

Also, as I mentioned I don't think "portable" task is a thing, unless it has caveats. There is no runtime resolution of TFM specific assets. This is why apps must be TFM-specific as I mentioned above. So if you want to have a portable plugin model, you need to make sure the host app can provide any TFM-specific assets that your plugins might want to use. MSBuild sould consider this when determining what things to bundle.

How can MSBuild communicate the set of facades that will be available to my task when run on either runtime? Anything not guaranteed to be available is a facade my task needs to bundle.

It looks to me like @rainersigwald was suggesting that they merely document it. I think you might be able to use the features in https://github.com/dotnet/sdk/blob/master/src/Tasks/Microsoft.NET.Build.Tasks/ResolvePublishAssemblies.cs to either list an MSBuild (meta-)package a platform package, or mark all the packages you want to be platform as private assets, but I haven't tried it. In v2 we'll have conflict resolution that supports a platform manifest, like I mentioned previously.

@jaredpar
Copy link
Member

@ericstj

There is no such thing as a portable layout for an exe.

Yes. But they can define the minimum set of facades / contracts that their EXE will bring with it on all platforms.

Also, as I mentioned I don't think "portable" task is a thing, unless it has caveats.

The future of .Net is portability but your saying we can't have a portable way to build applications?

Tasks are just DLLs. There is no reason I shouldn't be able to build a portable DLL and have MSBuild host it. Forcing me to build a different DLL for every platform that MSBuild supports doesn't make sense.

@ericstj
Copy link
Member

ericstj commented Jan 25, 2017

Yes. But they can define the minimum set of facades / contracts that their EXE will bring with it on all platforms.

Sure, and they'll need different files for each platform if the component has a different implementation on that platform. Those different versions of the files can't live in the same path...

The future of .Net is portability but your saying we can't have a portable way to build applications?

Like I said before, you can build a portable application today, but you need to publish a layout for each platform(TFM). This is because the apps dependencies have platform(TFM) specific implementations. Now fast-forward to NETStandard2.0 where we've asserted that a larger set of the platform is available and inbox in the platform and you can see how it will likely eliminate the need for any dependencies with platform(TFM) specific implementations. You'd still hit the same issue if took a dependency that needed a platform specific implementation app-local, but NETStandard2.0 aims to reduce the likelihood of that.

Forcing me to build a different DLL for every platform that MSBuild supports doesn't make sense.

Again, I didn't say you needed to build a different dll. I said there's a caveat here that dependencies may be TFM specific and both need to be published. I agree with you that MSBuild should try to realize a portable plugin model by providing those TFM specific files. I'm saying that MSBuild can't present it as completely portable, since any dependency that's TFM specific and not in their provided set would require the plugin to publish that dependency separately. Now we could ask for MSbuild to define a convention for "fat" layouts that have TFM-specific assets side-by-side, but that feels like feature creep.

@jeffkl
Copy link
Contributor

jeffkl commented Jan 25, 2017

@ericstj I'll need some more info on how to gather the facade assemblies so we can package them up. If I made a build project that targets net46 and depends on NETStandard.Library, does that give me the facades when I publish? Or is it more complex?

@ericstj
Copy link
Member

ericstj commented Jan 25, 2017

@jeffkl that'll give you the set that's in NETStandard.Library and its closure. MSBuild may be depending on packages above NETStandard.Library and you'd want to include those as well.

If you have an entry point package, a package that represents MSBuild.Exe and its dependencies, just publish that for net46 and it'll give you all the facades needed for MSBuild to run. That's the first option I suggested. Now if you added a NETStandard.Library ref to that project (if you don't already have one) and publish it for net46 that'll give you all the facades needed to satisfy NETStandard.Library.

If you want to provide additional packages as a convenience for developers, as we've suggested, just add more references and publish for net46. I'm putting together a few samples to demonstrate, will share in a moment.

@ericstj
Copy link
Member

ericstj commented Jan 25, 2017

@jeffkl
Copy link
Contributor

jeffkl commented Jan 26, 2017

Thanks @ericstj I'll try and make progress on this today

@ericstj
Copy link
Member

ericstj commented Jan 26, 2017

Thanks @jeffkl.

All the talk above about fat packages and what not is relevant if MSBuild recommends that folks build a task as netstandard and publish as netstandard in the package. Since any package can have a netstandard assembly and also have netcoreapp and net4x implementations with significant differences, folks have to be careful when taking a dependency on such a package. Bundling the corefx bits with MSBuild as you are doing here solves this for the common packages that folks will use, but there are many others. It's worth documenting that. I'd include something like:
"If your MSBuild task depends on a nuget package that has a different implementation for .NET Desktop and .NETCore then you should cross publish your task, and add a condition for the version of the task you use based on the value of the MSBuildRuntimeType property."

Here's an example of what that looks like:
https://github.com/dotnet/standard/blob/master/netstandard/tools/targets/NETStandard.Library.targets

@jeffkl
Copy link
Contributor

jeffkl commented Jan 26, 2017

Alright, just to verify. We have to use project.json because we can't use the new SDK stuff just yet. So this is my project.json:

{
    "dependencies": {
        "NETStandard.Library": "1.6.0",
        "Microsoft.CSharp": "4.0.1",
        "Microsoft.NETCore.Platforms": "1.0.1",
        "Microsoft.NETCore.Targets": "1.0.1",
        "Microsoft.VisualBasic": "10.0.1",
        "Microsoft.Win32.Registry": "4.0.0",
        "Microsoft.Win32.Registry.AccessControl": "4.0.0",
        "System.Buffers": "4.0.0",
        "System.Collections": "4.0.11",
        "System.Collections.Concurrent": "4.0.12",
        "System.Collections.Immutable": "1.2.0",
        "System.Collections.NonGeneric": "4.0.1",
        "System.Collections.Specialized": "4.0.1",
        "System.ComponentModel": "4.0.1",
        "System.ComponentModel.Annotations": "4.1.0",
        "System.ComponentModel.EventBasedAsync": "4.0.11",
        "System.ComponentModel.Primitives": "4.1.0",
        "System.ComponentModel.TypeConverter": "4.1.0",
        "System.Data.Common": "4.1.0",
        "System.Data.SqlClient": "4.1.0",
        "System.Diagnostics.Contracts": "4.0.1",
        "System.Diagnostics.DiagnosticSource": "4.0.0",
        "System.Diagnostics.FileVersionInfo": "4.0.0",
        "System.Diagnostics.Process": "4.1.0",
        "System.Diagnostics.StackTrace": "4.0.1",
        "System.Diagnostics.TextWriterTraceListener": "4.0.0",
        "System.Diagnostics.TraceSource": "4.0.0",
        "System.Drawing.Primitives": "4.0.0",
        "System.Dynamic.Runtime": "4.0.11",
        "System.Globalization.Extensions": "4.0.1",
        "System.IO.FileSystem.AccessControl": "4.0.0",
        "System.IO.FileSystem.DriveInfo": "4.0.0",
        "System.IO.FileSystem.Watcher": "4.0.0",
        "System.IO.MemoryMappedFiles": "4.0.0",
        "System.IO.Packaging": "4.0.0",
        "System.IO.Pipes": "4.0.0",
        "System.IO.UnmanagedMemoryStream": "4.0.1",
        "System.Linq.Parallel": "4.0.1",
        "System.Linq.Queryable": "4.0.1",
        "System.Net.Http.Rtc": "4.0.1",
        "System.Net.Http.WinHttpHandler": "4.0.0",
        "System.Net.NameResolution": "4.0.0",
        "System.Net.NetworkInformation": "4.1.0",
        "System.Net.Ping": "4.0.0",
        "System.Net.Primitives": "4.0.11",
        "System.Net.Requests": "4.0.11",
        "System.Net.Security": "4.0.0",
        "System.Net.WebHeaderCollection": "4.0.1",
        "System.Net.WebSockets": "4.0.0",
        "System.Net.WebSockets.Client": "4.0.0",
        "System.Numerics.Vectors": "4.1.1",
        "System.Reflection.Context": "4.0.1",
        "System.Reflection.DispatchProxy": "4.0.1",
        "System.Reflection.Emit": "4.0.1",
        "System.Reflection.Emit.ILGeneration": "4.0.1",
        "System.Reflection.Emit.Lightweight": "4.0.1",
        "System.Reflection.Metadata": "1.3.0",
        "System.Reflection.TypeExtensions": "4.1.0",
        "System.Resources.Reader": "4.0.0",
        "System.Resources.Writer": "4.0.0",
        "System.Runtime.CompilerServices.Unsafe": "4.0.0",
        "System.Runtime.CompilerServices.VisualC": "4.0.0",
        "System.Runtime.InteropServices.WindowsRuntime": "4.0.1",
        "System.Runtime.Serialization.Json": "4.0.2",
        "System.Runtime.Serialization.Primitives": "4.1.1",
        "System.Runtime.Serialization.Xml": "4.1.1",
        "System.Runtime.WindowsRuntime": "4.0.11",
        "System.Runtime.WindowsRuntime.UI.Xaml": "4.0.1",
        "System.Security.AccessControl": "4.0.0",
        "System.Security.Claims": "4.0.1",
        "System.Security.Cryptography.Cng": "4.2.0",
        "System.Security.Cryptography.Csp": "4.0.0",
        "System.Security.Cryptography.Pkcs": "4.0.0",
        "System.Security.Cryptography.ProtectedData": "4.0.0",
        "System.Security.Principal": "4.0.1",
        "System.Security.Principal.Windows": "4.0.0",
        "System.Security.SecureString": "4.0.0"
    },
    "frameworks": {
        "net46": { }
    }
}

I ran the following:

D:\msbuild\setup\Facades>dotnet restore && dotnet publish
log  : Restoring packages for D:\msbuild\setup\Facades\project.json...
log  : Lock file has not changed. Skipping lock file write. Path: D:\msbuild\setup\Facades\project.lock.json
log  : D:\msbuild\setup\Facades\project.json
log  : Restore completed in 11679ms.
Publishing Facades for .NETFramework,Version=v4.6/win7-x64
publish: Published to D:\msbuild\setup\Facades\bin\Debug\net46\win7-x64\publish
Published 1/1 projects successfully

Which places the following assemblies in the publish folder:

    Microsoft.Win32.Primitives.dll
    Microsoft.Win32.Registry.AccessControl.dll
    Microsoft.Win32.Registry.dll
    System.AppContext.dll
    System.Buffers.dll
    System.Collections.Immutable.dll
    System.Collections.NonGeneric.dll
    System.Collections.Specialized.dll
    System.ComponentModel.Primitives.dll
    System.ComponentModel.TypeConverter.dll
    System.Console.dll
    System.Data.Common.dll
    System.Data.SqlClient.dll
    System.Diagnostics.DiagnosticSource.dll
    System.Diagnostics.FileVersionInfo.dll
    System.Diagnostics.Process.dll
    System.Diagnostics.StackTrace.dll
    System.Diagnostics.TextWriterTraceListener.dll
    System.Diagnostics.TraceSource.dll
    System.Drawing.Primitives.dll
    System.Globalization.Calendars.dll
    System.Globalization.Extensions.dll
    System.IO.Compression.dll
    System.IO.Compression.ZipFile.dll
    System.IO.FileSystem.AccessControl.dll
    System.IO.FileSystem.dll
    System.IO.FileSystem.DriveInfo.dll
    System.IO.FileSystem.Primitives.dll
    System.IO.FileSystem.Watcher.dll
    System.IO.MemoryMappedFiles.dll
    System.IO.Packaging.dll
    System.IO.Pipes.dll
    System.IO.UnmanagedMemoryStream.dll
    System.Net.Http.Rtc.dll
    System.Net.Http.WinHttpHandler.dll
    System.Net.NameResolution.dll
    System.Net.NetworkInformation.dll
    System.Net.Ping.dll
    System.Net.Security.dll
    System.Net.Sockets.dll
    System.Net.WebSockets.Client.dll
    System.Net.WebSockets.dll
    System.Numerics.Vectors.dll
    System.Reflection.DispatchProxy.dll
    System.Reflection.Metadata.dll
    System.Reflection.TypeExtensions.dll
    System.Resources.Reader.dll
    System.Resources.Writer.dll
    System.Runtime.CompilerServices.Unsafe.dll
    System.Runtime.CompilerServices.VisualC.dll
    System.Runtime.InteropServices.RuntimeInformation.dll
    System.Runtime.Serialization.Primitives.dll
    System.Runtime.Serialization.Xml.dll
    System.Security.AccessControl.dll
    System.Security.Claims.dll
    System.Security.Cryptography.Algorithms.dll
    System.Security.Cryptography.Cng.dll
    System.Security.Cryptography.Csp.dll
    System.Security.Cryptography.Encoding.dll
    System.Security.Cryptography.Pkcs.dll
    System.Security.Cryptography.Primitives.dll
    System.Security.Cryptography.ProtectedData.dll
    System.Security.Cryptography.X509Certificates.dll
    System.Security.Principal.Windows.dll
    System.Security.SecureString.dll

So if we ship these with MSBuild in Visual Studio, this will make it so task authors who target netstandard1.3 will not have to ship their own dependencies?

@ericstj
Copy link
Member

ericstj commented Jan 26, 2017

Don't import netcore50. I've created a project.json based sample:https://gist.github.com/ericstj/af57217e1972f78408d66b4eed042093#file-all-project-json

I've shared the list I get when publishing here: https://gist.github.com/ericstj/af57217e1972f78408d66b4eed042093#file-net46-dlls-txt

Your file list was missing the following, possibly truncated?

System.Text.Encoding.CodePages.dll
System.Text.Encodings.Web.dll
System.Threading.AccessControl.dll
System.Threading.Overlapped.dll
System.Threading.Tasks.Dataflow.dll
System.Threading.Tasks.Extensions.dll
System.Threading.Thread.dll
System.Threading.ThreadPool.dll
System.Xml.XmlDocument.dll
System.Xml.XPath.dll
System.Xml.XPath.XDocument.dll
System.Xml.XPath.XmlDocument.dll

Your file list included System.Net.Http.Rtc.dll incorrectly due to your import of netcore50 and direct-reference to this UWP-specific package.

So if we ship these with MSBuild in Visual Studio, this will make it so task authors who target netstandard1.3 will not have to ship their own dependencies?

They will not have to bundle these dependencies, correct.

If you do include all of these in your desktop layout you should make sure to include the same in the NETCoreApp layout for parity since some of these aren't in the shared framework. That should happen automatically if you reference the packages in the project used to publish your MSBuild.exe for NETCoreApp.

@jeffkl
Copy link
Contributor

jeffkl commented Jan 26, 2017

Don't import netcore50

My mistake, for some reason I thought I needed to include a runtime which caused restore errors. Removing the runtime let me remove the import.

Your file list was missing the following, possibly truncated?

I was under the impression that we needed to stick with whatever version of .NET Framework that VS supports which is .NET 4.6. So I didn't add the ones that you said were .NET 4.6.1. Is this incorrect?

If you do include all of these in your desktop layout you should make sure to include the same in the NETCoreApp layout for parity since some of these aren't in the shared framework.

Won't the .deps.json of the task library allow .NET Core to find the dependencies? I guess that only works if they happen to be restored on the machine?

Also, we think we'll need to add binding redirects for the facades to upgrade 0.0.0.0-[our version] to our version, do you agree? Assembly redirects aren't possible in .NET Core though I suppose.

@ericstj
Copy link
Member

ericstj commented Jan 26, 2017

So I didn't add the ones that you said were .NET 4.6.1. Is this incorrect?

There is only one package that was net461 specific, it was commented out: System.ServiceProcess.ServiceController

Won't the .deps.json of the task library allow .NET Core to find the dependencies?

The .NET Core host is the one responsible for parsing a .deps.json. This is the component that starts up the CoreCLR for your app, using your app's .deps.json. When you load a task no-one looks at the .deps.json unless you do in your own loader: https://github.com/Microsoft/msbuild/blob/cb8c727a898e4439a3cd18f329504e436b0b7c00/src/Shared/CoreCLRAssemblyLoader.cs. It doesn't look to me like you do. /cc @gkhanna79 It is an interesting suggestion, and I bet you could build that feature.

Also, we think we'll need to add binding redirects for the facades to upgrade 0.0.0.0-[our version] to our version, do you agree? Assembly redirects aren't possible in .NET Core though I suppose.

Yes, you should do this in MSBuild.exe.config. You don't need redirects on .NET Core, it automatically allows a higher version than the ref.

@gkhanna79
Copy link
Member

Does DependencyModel allow you to process Deps.json?

VM (and related support) should be agnostic of appmodel activation support artifacts. But if someone wishes to build one, I agree, they can absolutely build it.

@ericstj
Copy link
Member

ericstj commented Jan 26, 2017

Even if it did, the deps.json wouldn't have the right info in it unless the task restored and published for NETCoreApp. /cc @eerhardt

@jaredpar
Copy link
Member

Question here: does this set of facades map to Net Core App 1.0 or 1.1?

@jeffkl
Copy link
Contributor

jeffkl commented Jan 26, 2017

Here's my prototype: https://github.com/jeffkl/msbuild/commits/facades

I'm trying it in VS right now...

@eerhardt
Copy link
Member

We had to do this in the dotnet/sdk as well. See https://github.com/dotnet/sdk/blob/master/build/Nuget/Microsoft.NET.Sdk.Nuget.targets, where we are copying a bunch of assemblies from our nuget cache and deploying them next to our task.dll.

For .netcoreapp1.0, the only "System" assembly we needed was System.Runtime.Serialization.Primitives. The rest were all for desktop only.

Even if it did, the deps.json wouldn't have the right info in it unless the task restored and published for NETCoreApp.

If you target netstandardx.y, we build a deps.json file for the library during build. And the deps.json file lists the dependencies to the assemblies you referenced during your build. And if those assemblies didn't have "runtime" assets for "netstandardx.y" or lower, then yes you wouldn't get which runtime assemblies you should be loading at runtime.

@ericstj
Copy link
Member

ericstj commented Jan 26, 2017

Net Core App 1.0 or 1.1?

Good point, right now it's 1.0 which was an assumption because everyone is focusing on LTS. Using 1.1 would bring in those higher versions without much risk since most of these are facades. @jeffkl see the updated project.json here: https://gist.github.com/ericstj/af57217e1972f78408d66b4eed042093#file-all-1-1-project-json

@weshaggard this includes some standalone OOB assemblies (like System.Net.Http and System.Collections.Immutable) we might want to exclude those, yes?

have "runtime" assets for "netstandardx.y" or lower, then yes you wouldn't get which runtime assemblies you should be loading at runtime.

@eerhardt that's not the point. Those are the easy ones: they'll get published next to the task. Suppose a package has NETCoreApp-specific assemblies. Those won't be next to the task or present in the deps.

@jaredpar
Copy link
Member

@ericstj terminology question.

What do you call the Net Standard 1.3 facades for the version specific to Net Core App 1.1?

@jeffkl
Copy link
Contributor

jeffkl commented Jan 27, 2017

@ericstj okay that means I have to remove System.Runtime.WindowsRuntime and System.Runtime.WindowsRuntime.UI.Xaml right?

System.Runtime.WindowsRuntime 4.0.11 provides a compile-time reference assembly for System.Runtime.WindowsRuntime on .NETFramework,Version=v4.6, but there is no run-time assembly compatible with win.
System.Runtime.WindowsRuntime.UI.Xaml 4.0.1 provides a compile-time reference assembly for System.Runtime.WindowsRuntime.UI.Xaml on .NETFramework,Version=v4.6, but there is no run-time assembly compatible with win.

@AndyGerlicher
Copy link
Contributor

Moved this out from RTM. I don't think we can take this change at this point given there's a workaround for task authors. If anyone strongly objects let me know.

@MattGertz for awareness as well.

@MattGertz
Copy link

Reluctantly agree, given the new bar JoC set last night. @jaredpar, where does this leave us?

@ericstj
Copy link
Member

ericstj commented Jan 27, 2017

@jeffkl yeah, you can remove those.

@jaredpar
Copy link
Member

@MattGertz just means that extensions will need to bring along facades with them for 15.0.

At this point though we should probably just skip the 1.3 facades altogether and focus on 2.0. Post RTW obviously.

@ericstj
Copy link
Member

ericstj commented Jan 27, 2017

2.0 will definitely be a better deployment model for tasks, but I do think MSBuild needs to better consider the implications of task dependencies, something similar to what the old CLI did with "tools". /cc @eerhardt

@AndyGerlicher
Copy link
Contributor

I agree with what you're saying, but it seems like the runtime should have the ability to do this? I wouldn't want msbuild to be aware of a runtime.deps.json to load a task. Or did you mean something else?

@ericstj
Copy link
Member

ericstj commented Jan 28, 2017

I wouldn't go so far as to prescribe runtime.deps.json as the only solution. Its a solution but it isn't even complete (who restores the packages?).

I think you just need to draw out what e2e looks like for an msbuild task with dependencies, including if those dependencies differ by framework. NS2.0 makes a lot of this moot for the framework dependencies but doesn't do so for things higher in the stack like 3rd party dependencies.

It might be reasonable to say that the answer is something in the tooling that warns a user if they try to publish something for netstandard* and a package has fx specific assets for TFMs supporting netstandard. You could then say that the solution for that warning is to publish the task for specific TFMs then switch at runtime with MSBuildRuntimeType.

@johnbucayan
Copy link

Hi everyone. I think this trail is already closed but my solution when I encounter this error is uninstall and re-install the typescript.exe and it works.

@jeffkl
Copy link
Contributor

jeffkl commented May 11, 2018

I'm closing this since we've moved to .NETStandard2.0 and all facades are in later versions of the .NET Framework.

@jeffkl jeffkl closed this as completed May 11, 2018
@AR-May AR-May added the triaged label Feb 21, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests