[Visual Studio 2017, .csproj- Eigenschaften]
Um Ihre PackageVersion / Version / AssemblyVersion-Eigenschaft (oder eine andere Eigenschaft) automatisch zu aktualisieren, erstellen Sie zunächst eine neue Microsoft.Build.Utilities.Task
Klasse, die Ihre aktuelle Build-Nummer erhält, und senden Sie die aktualisierte Nummer zurück (ich empfehle, nur für diese Klasse ein separates Projekt zu erstellen).
Ich aktualisiere die major.minor-Nummern manuell, lasse aber MSBuild die Build-Nummer automatisch aktualisieren (1.1. 1 , 1.1. 2 , 1.1. 3 usw. :)
using Microsoft.Build.Framework;
using System;
using System.Collections.Generic;
using System.Text;
public class RefreshVersion : Microsoft.Build.Utilities.Task
{
[Output]
public string NewVersionString { get; set; }
public string CurrentVersionString { get; set; }
public override bool Execute()
{
Version currentVersion = new Version(CurrentVersionString ?? "1.0.0");
DateTime d = DateTime.Now;
NewVersionString = new Version(currentVersion.Major,
currentVersion.Minor, currentVersion.Build+1).ToString();
return true;
}
}
Rufen Sie dann Ihren kürzlich erstellten Task on MSBuild-Prozess auf und fügen Sie den nächsten Code in Ihre .csproj-Datei ein:
<Project Sdk="Microsoft.NET.Sdk">
...
<UsingTask TaskName="RefreshVersion" AssemblyFile="$(MSBuildThisFileFullPath)\..\..\<dll path>\BuildTasks.dll" />
<Target Name="RefreshVersionBuildTask" BeforeTargets="Pack" Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">
<RefreshVersion CurrentVersionString="$(PackageVersion)">
<Output TaskParameter="NewVersionString" PropertyName="NewVersionString" />
</RefreshVersion>
<Message Text="Updating package version number to $(NewVersionString)..." Importance="high" />
<XmlPoke XmlInputPath="$(MSBuildProjectDirectory)\mustache.website.sdk.dotNET.csproj" Query="/Project/PropertyGroup/PackageVersion" Value="$(NewVersionString)" />
</Target>
...
<PropertyGroup>
..
<PackageVersion>1.1.4</PackageVersion>
..
Wenn Sie die Visual Studio Pack-Projektoption BeforeTargets="Build"
auswählen (wechseln Sie einfach zu, um die Aufgabe vor dem Erstellen auszuführen), wird der RefreshVersion-Code ausgelöst, um die neue Versionsnummer zu berechnen, und die XmlPoke
Aufgabe aktualisiert Ihre .csproj-Eigenschaft entsprechend (ja, die Datei wird geändert).
Bei der Arbeit mit NuGet-Bibliotheken sende ich das Paket auch an das NuGet-Repository, indem ich dem vorherigen Beispiel nur die nächste Build-Aufgabe hinzufüge.
<Message Text="Uploading package to NuGet..." Importance="high" />
<Exec WorkingDirectory="$(MSBuildProjectDirectory)\bin\release" Command="c:\nuget\nuget push *.nupkg -Source https://www.nuget.org/api/v2/package" IgnoreExitCode="true" />
c:\nuget\nuget
Hier habe ich den NuGet-Client (denken Sie daran, Ihren NuGet-API-Schlüssel durch Aufrufen zu speichern nuget SetApiKey <my-api-key>
oder den Schlüssel in den NuGet-Push-Aufruf aufzunehmen).
Nur für den Fall, dass es jemandem hilft ^ _ ^.