ProjectsAreNugetPackages 1.0.15

dotnet add package ProjectsAreNugetPackages --version 1.0.15                
NuGet\Install-Package ProjectsAreNugetPackages -Version 1.0.15                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ProjectsAreNugetPackages" Version="1.0.15">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ProjectsAreNugetPackages --version 1.0.15                
#r "nuget: ProjectsAreNugetPackages, 1.0.15"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ProjectsAreNugetPackages as a Cake Addin
#addin nuget:?package=ProjectsAreNugetPackages&version=1.0.15

// Install ProjectsAreNugetPackages as a Cake Tool
#tool nuget:?package=ProjectsAreNugetPackages&version=1.0.15                

ProjectsAreNugetPackages

  • Build a nuget package after having built the project.
  • Consume project dependencies as nuget packages after a one-time migration

Custom Properties

  • BuildNugetPackage: true/false. Whether or not to build a Nuget package after build
  • OfficialBuild: true/false. Helper property to resolve default values for other properties.
  • NugetToolPath: Folder path of Nuget.exe
  • NugetConfig: Path to Nuget.config
  • NuSpecPath: Path to project's nuspec file. If empty, defaults to built-in nuspec file.
  • NugetManufacturer: Package author field.
  • NuspecVersion: Package version (without suffix).
  • NuspecVersionSuffix: Package version suffix. Default to:
    • 'local' on non-official release builds
    • 'localdebug' on non-official debug builds
    • nothing on release official builds
  • NugetId: Package Id. Defaults to project file name.
  • NugetIdPrefix: Package prefix. Used to distinguish project dependencies from available packages on nuget.org
  • NugetBuildFolder: Tagret folder for Nuget packages. Expected to exist in nuget.config file.
  • NugetSource: URL to nuget source to add packages to on UploadNugetPackage target
  • NugetUpdatePreRelease: Whether or not to update/install pre-release nuget packages. Used on NugetInstallUpdate target.

Custom Items

  • NugetPackProperty: key=value pairs to pass as properties to Nuget pack command.
  • NugetUpdateSource: List of nuget URLs to update from. Defaults to NugetBuildFolder and NugetSource.

Custom Imports

Customization properties can be placed in solution folder and/or project folder in file 'ProjectsAreNugetPackages.custom.props'

Tasks

  • ConvertProjectRefToNugetPackage: One-time task to convert project refrences and library inputs to Nuget dependencies
    • Inputs:
      • Projects [Required]: Item list with all projects to convert. May contain 'Properties' and 'AdditionalProperties' metadata with Key=Value pairs to set on project when loading it to resolve refernces
      • AllProjects [Required]: Item list with all projects. May contain 'Alias' metadata if project file name does not equal the library refernce name.
      • PackageIdPrefix: Prefix to project names as Nuget dependencies. See property NugetIdPrefix.
      • PackageVersion: Version of projects' NuGet dependencies.
  • ResolveDependants: Resolve build order according to Nuget dependants
    • Inputs:
      • DependecyProject [Required]: The target project to build.
      • AllProjects [Required]: Item list with all projects.
      • PackageIdPrefix: Prefix to project names as Nuget dependencies. See property NugetIdPrefix.
      • ProcessorCount: Maximal projects to build in parallel. Defaults to Environment.ParallelBuildLevel value. See output parameter DependantProjectsBuildOrdered.
    • Outputs:
      • DependantProjectsBuildOrdered: Item list- projects to build in order. Projects that do not depend on DependecyProject are not on the list. Contains metadata ParallelBuildLevel with numeric level order of projects that can be built in parallel.

Targets

  • ConvertProjectRefToNugetPackage: See ConvertProjectRefToNugetPackage task
  • ResolveDependants: See ResolveDependants task
  • NugetInstallUpdate: Install and update nuget packages
  • UploadNugetPackage: Nuget add built package to 'NugetSource' repository
  • CreateNugetPackage: Pack a project.

How to use

First time init

  1. Install the package to all projects
  2. Create a local nuget.config file
  • Add source with relative path to local nuget build folder.
  • [Optional] Add source to organization's nuget repository.
  1. Create a file 'TidyBuild.custom.props' with these properties:
  • NugetConfig
  • NugetIdPrefix
  • NuspecVersion
  • FullVersion (for TidyBuild)
  • [Optional] NugetSource
  1. MSBuild all projects with target 'ConvertProjectRefToNugetPackage'
  2. Build all projects normally
  3. Create build.xml file. Sample code:
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <Import Project="$(MSBuildThisFileDirectory)\packages\ProjectsAreNugetPackages.1.0.9\build\ProjectsAreNugetPackages.tasks"/>

  <ItemGroup>
    <AllProjects Include=".\**\*.*proj"/>
  </ItemGroup>
  <ItemDefinitionGroup>
    <AllProjects>
      <Properties>Configuration=Release;Platform=Win32</Properties>
    </AllProjects>
  </ItemDefinitionGroup>

  <PropertyGroup>
    <TargetProject>NativeDll1\NativeDll1.vcxproj</TargetProject>
  </PropertyGroup>

  
  <Target Name="Build" DependsOnTargets="_ResolveBuildOrder" Inputs="@(ProjectBuildOrder)" Outputs="%(ParallelBuildLevel)\NeverExists">
    <Exec Command='"$(MSBuildBinPath)\MSBuild.exe" "%(ProjectBuildOrder.FullPath)" "/Property:%(ProjectBuildOrder.Properties)" /Target:NugetInstallUpdate' />
    <MSBuild Projects="@(ProjectBuildOrder)" Targets="Rebuild" BuildInParallel="true"/>
  </Target>

  <Target Name="_ResolveBuildOrder">
    <ResolveDependants DependecyProjects="$(TargetProject)" AllProjects="@(AllProjects)" PackageIdPrefix="Local.">
      <Output TaskParameter="DependantProjectsBuildOrdered" ItemName="ProjectBuildOrder" />
    </ResolveDependants>
    <Message Text="Projects: @(AllProjects)" Importance="low"/>
    <Message Text="Project parallel build in step %(ProjectBuildOrder.ParallelBuildLevel): @(ProjectBuildOrder)"/>
  </Target>
</Project>

Routine builds

  1. MSBuild build.xml target 'Build'. Make sure to set 'TargetProject' property from command line.
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.15 1,234 1/12/2018
1.0.14 1,005 1/10/2018
1.0.13 1,002 1/9/2018
1.0.11 897 1/9/2018
1.0.10 1,040 1/8/2018
1.0.9 1,184 1/3/2018
1.0.8 967 12/28/2017
1.0.6 996 12/26/2017
1.0.5 1,184 12/25/2017
1.0.4 992 12/24/2017
1.0.3 967 12/24/2017
1.0.0 1,015 12/20/2017