-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
ChakraCore NuGet package #85
Comments
Thanks for the suggestion. We will look into the possibility of creating a ChakraCore Nuget package. |
If there was a 'vote' button, I would pressed it for sure. Nuget package is a 'must have' for such project. Please, ensure that this package could be used in dnx project. Seems like https://github.com/robpaveza/jsrt-dotnet from @robpaveza could be a starting point. |
Thanks for reminding me @EdMaurer. I'll look into this asap. |
this would be great for allowing asp.net core apps to use isomorphic javascript |
Just wanted to let everyone know that we're setting up our infrastructure to produce NuGet packages. Stay tuned. |
@dilijev great news! Waiting ChakraCore package for dnx projects. |
Our infrastructure is set up to make NuGet packages and we are now hosting ChakraCore preview builds on MyGet.org: https://www.myget.org/gallery/chakracore-preview These builds will be signed and can be used to trial development with ChakraCore and embedding ChakraCore into applications. Some thoughts/questions:
|
You could make a separate debug nuget package that included either the pdb and dll or just the pdb. While it makes sense to me to include the headers, I haven't used c/c++ with nuget or needed header files for anything recently so I might be wrong. Someone with more recent c/c++ experience might have a different thought. |
It looks like there might be a supported pattern for native (C++) NuGet packages: That also suggests a pattern for making it easier to use NuGet to take a dependency on ChakraCore in a VS project. Also I noticed that the MyGet website has integration with SymbolSource. This might be the best way to distribute debugging symbols, instead of in the binary distribution packages. I'll add some tasks to the initial description that still need to be done to make consuming our NuGet packages a great experience. It seems the thing to do is to create different packages that can be used in different scenarios (development, debugging, etc.) For example, TypeScript has two different packages that contain different tools depending on the development scenario. |
are you planning to move to the main nuget index after you come out of preview? what it the reason for using myget.com for a public package? |
Yes, once we are out of preview we will move to the NuGet.org index (at least for the stable, official releases). We were following the example of TypeScript using MyGet for preview builds, since we want to make sure nobody accidentally takes a dependency on the preview builds which will expire quickly and generally not be available for any significant length of time. |
Has anyone tried the packages? Any general asks? |
I have tried to build a simple HelloWorld console app, but adding the Nuget package fails: Could not install package 'Microsoft.ChakraCore 1.2.4.53527-preview'. You are trying to install this package into a project that targets '.NETFramework,Version=v4.5.2', but the package does not contain any assembly references or content files that are compatible with that framework. For more information, contact the package author. Also tried for v4.5 and v4.6, no success. |
@jimmcslim Are you trying to build a .NET app? The contents of the NuGet package are intended for Native targets. It is also possible that in the current configuration, the NuGet package is simply a method for distributing the binaries and that NuGet will not automatically do the right thing. (You may have to manually add the references to the binaries.) Contents of the package at the moment:
|
Yes was trying to build a .NET app. Is the intention for this Nuget package to ultimately work for .Net apps, e.g. also include the JSRT bindings for .Net and I'm off to the races adding JavaScript interop capabilities to my applications? Or should I be using packages like JavaScript Engine Switcher for .Net - Core and JavaScript Engine Switcher for .Net - Chakra? |
@dilijev I thought NuGet package of ChakraCore will be for .net apps or even for .net core apps. Otherwise it looks a bit useless. |
@resnyanskiy Thanks for the feedback. We will have to look more deeply into supporting .NET targets in the NuGet package (/cc @liminzhu). Since we're a native project it's more straightforward to support a Native target for the moment. (NuGet has semantics for Native targets [reference linked above], but we are not yet implementing that semantic package layout.) Since NuGet is still a good platform for distributing dependencies and we expect that native code projects will want to embed ChakraCore, we think that a NuGet package targeting native projects is a good idea. We acknowledge, however, that this is not the only (and not even necessarily the most-wanted) scenario we should plan to support. For now, Native is a stepping stone. Side note: in it's current state, it's still not entirely useless, as we get to use the .nupkg (which is a .zip) as a way to distribute our official preview binaries. :P |
@digitalinfinity - @liminzhu mentioned this to me and I wanted to get your thoughts on it / get it on your radar:
Also (very much future work): after we have something release-ready, getting the package added to Edit 2016-07-15: I forgot that we can create our own apt-get package feed and host our binaries there. That's probably the approach we want to take. |
+1 This is already mentioned in the roadmap, but would be great if xplat builds were also included with the nuspec -- similar to how netcore distributes libuv, having the package be the combination of platform specific builds, which can be taken independently if desired. https://github.com/aspnet/libuv-package (Note that this doesn't reference distributing xplat libs on other package managers e.g. apt-get or brew for instance, only allowing xplat libs to be distributed on nuget to be consumed from things like netcore) |
Thanks for the reference to libuv, @Oceanswave -- it's good to know which layouts by other packages are preferred by our users. We'll look into this! |
Merge pull request #2266 from pre10der89:chakra_nuget Adding implementation for several nuget packages that allow the ChakraCore DLLs to be referenced in .NET projects... This main tasks in git issue #85... A nuspec has been provided for the following flavors: ARM, x86, x64 (combined) ARM (only) x86 (only) x64 (only) Symbols [PDBs] (only) v140 (CPP only)
…mentation Merge pull request #2266 from pre10der89:chakra_nuget Adding implementation for several nuget packages that allow the ChakraCore DLLs to be referenced in .NET projects... This main tasks in git issue #85... A nuspec has been provided for the following flavors: ARM, x86, x64 (combined) ARM (only) x86 (only) x64 (only) Symbols [PDBs] (only) v140 (CPP only)
We've created preview packages using the new dfefinitions from #2266 and published them to the MyGet feed: .NET: https://www.myget.org/feed/chakracore-preview/package/nuget/Microsoft.ChakraCore We welcome your feedback! Thanks @matthargett and @pre10der89 for all your help in making this a reality! |
Our pleasure! Thanks to @bluejeans for encouraging us to collaborate on upstream projects in the process of making an awesome next-generation experience for our customers 😃 |
Closing this issue as all of the main functionality work items have been completed. I created a an issue for any follow-up items: #2578 |
I didn't see this already so I hope it isn't a duplicate.
I also didn't see it in the roadmap.
I read the quick-start guide on embedding ChakraCore, but following this guidance will make it hard to keep an embedded version up to date.
https://github.com/Microsoft/ChakraCore/wiki/Embedding-ChakraCore
A better solution would be if MS created a NuGet package for ChakraCore and auto-published it from its build server.
Maintainers' Update
@dilijev (added 2016-04-26 / last updated 2016-01-31):
Wiki: https://github.com/Microsoft/ChakraCore/wiki/NuGet-Packages
NuGet feed: https://www.nuget.org/packages/Microsoft.ChakraCore
MyGet feed: https://www.myget.org/feed/chakracore-preview/package/nuget/Microsoft.ChakraCore
Work Items
Microsoft.ChakraCore.<major>.<minor>.<patch>-preview-<build1>-<build2>
(e.g.Microsoft.ChakraCore.1.3.0-preview-00008-12345
). Commit hash is, as always, encoded in binary metadata.Preview builds of multiple branches: e.g.(Infrastructure now exists but there's no compelling reason to publish preview builds of multiple release branches -- patch updates to already-released minor versions like 1.2 and 1.3 will be extremely minor so there's nothing meaningful to preview.)release/*
andmaster
Follow-up Items
Moved follow-up work items to #2578
/cc @digitalinfinity @boingoing
The text was updated successfully, but these errors were encountered: