Skip to main content

NuPack – Ruby Gems for .NET

If you know Ruby, one of the great tools around is Ruby Gems. Ruby Gems is a package management system that makes the process of incorporating third party libraries into your solutions as simple as possible. If you compare this to the .NET experience where you had to search for the correct assemblies and reference them yourself, the Ruby world looked a lot nicer. Until last week when Microsoft released NuPack, a package manager for .NET.

NuPack is a free open source package manager that makes it easy for you to find, install, and use .NET libraries in your projects. It works with all .NET project types. NuPack enables developers who maintain open source projects (for example, projects like Moq, NHibernate, Ninject, StructureMap, NUnit, Windsor, RhinoMocks, Elmah, etc) to package up their libraries and register them with an online gallery/catalog that is searchable.  The client-side NuPack tools – which include full Visual Studio integration – make it trivial for any .NET developer who wants to use one of these libraries to easily find and install it within the project they are working on.

NuPack handles dependency management between libraries (for example: library1 depends on library2). It also makes it easy to update (and optionally remove) libraries from your projects later. It supports updating web.config files (if a package needs configuration settings). It also allows packages to add PowerShell scripts to a project (for example: scaffold commands). Importantly, NuPack is transparent and clean – and does not install anything at the system level. Instead it is focused on making it easy to manage libraries you use with your projects.

Remark: The NuPack extensions only work with Visual Studio 2010

How to get started?

Download the latest build. Once you download it double click on the NuPack.Tools.vsix file and click Install to add the extension to Visual Studio 2010. Afterwards restart any Visual Studio instances you have running.

NuPackInstall

After installation, you’ll find a new Package Manager window under View –> Other windows –> Package Manager Console. This console uses PowerShell cmdlets to access the same features that the GUI does. The specific commands can be found here. The package manager console is the quickest way to update your solution with third-party packages.

PackageManagerConsole

Of course, you also have some nice Visual Studio integration. Right click on the References folder in a project and you’ll see this:

AddPackageReference

Adding a complex package

Let’s test the power of the NuPack engine by adding a complex package like NHibernate. From the Package Manager Console start typing add-package nh<tab> and you’ll see a list of all the available packages. Select NHibernate.Core and press <enter>.

addnhibernatepackage

The console reports us:

PM> add-package NHibernate.Core
'log4net (= 1.2.1)' not referenced. Retrieving dependency...
Done
'Iesi.Collections (= 1.0)' not referenced. Retrieving dependency...
Done
'Antlr (>= 3.0)' not referenced. Retrieving dependency...
Done
Successfully added 'log4net 1.2.1' to WpfApplication1
Successfully added 'Iesi.Collections 1.0' to WpfApplication1
Successfully added 'Antlr 3.1.1' to WpfApplication1
Successfully added 'NHibernate.Core 2.1.2' to WpfApplication1

What happened? The package manager checked for all the required dependencies, validated for each dependency if it’s already included in the project and adds a reference when it’s missing. If we look at the references for our project, we see that the required references are added.

NHibernateReferences 

On the file system a new packages folder is created which contains all the files and a  nupkg file for each depencency. This nupkg file contains all the metadata and the binary file itself.

packagefoldercontent

For more information, have a look at the Get started page.

Popular posts from this blog

DevToys–A swiss army knife for developers

As a developer there are a lot of small tasks you need to do as part of your coding, debugging and testing activities.  DevToys is an offline windows app that tries to help you with these tasks. Instead of using different websites you get a fully offline experience offering help for a large list of tasks. Many tools are available. Here is the current list: Converters JSON <> YAML Timestamp Number Base Cron Parser Encoders / Decoders HTML URL Base64 Text & Image GZip JWT Decoder Formatters JSON SQL XML Generators Hash (MD5, SHA1, SHA256, SHA512) UUID 1 and 4 Lorem Ipsum Checksum Text Escape / Unescape Inspector & Case Converter Regex Tester Text Comparer XML Validator Markdown Preview Graphic Color B

Help! I accidently enabled HSTS–on localhost

I ran into an issue after accidently enabling HSTS for a website on localhost. This was not an issue for the original website that was running in IIS and had a certificate configured. But when I tried to run an Angular app a little bit later on http://localhost:4200 the browser redirected me immediately to https://localhost . Whoops! That was not what I wanted in this case. To fix it, you need to go the network settings of your browser, there are available at: chrome://net-internals/#hsts edge://net-internals/#hsts brave://net-internals/#hsts Enter ‘localhost’ in the domain textbox under the Delete domain security policies section and hit Delete . That should do the trick…

Azure DevOps/ GitHub emoji

I’m really bad at remembering emoji’s. So here is cheat sheet with all emoji’s that can be used in tools that support the github emoji markdown markup: All credits go to rcaviers who created this list.