[Visual Studio 2017, propriedades .csproj ]
Para atualizar automaticamente sua propriedade PackageVersion / Version / AssemblyVersion (ou qualquer outra propriedade), primeiro, crie uma nova Microsoft.Build.Utilities.Task
classe que obterá seu número de compilação atual e enviará de volta o número atualizado (recomendo criar um projeto separado apenas para essa classe).
Eu atualizo manualmente os números major.minor, mas deixo o MSBuild atualizar automaticamente o número da compilação (1.1. 1 , 1.1. 2 , 1.1. 3 , etc. :)
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;
}
}
Em seguida, chame sua tarefa recém-criada no processo MSBuild, adicionando o próximo código em seu arquivo .csproj:
<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>
..
Ao escolher a opção de projeto do Visual Studio Pack (apenas altere para BeforeTargets="Build"
para executar a tarefa antes de Build), o código RefreshVersion será acionado para calcular o novo número de versão e a XmlPoke
tarefa atualizará sua propriedade .csproj de acordo (sim, ela modificará o arquivo).
Ao trabalhar com bibliotecas NuGet, também envio o pacote para o repositório NuGet apenas adicionando a próxima tarefa de compilação ao exemplo anterior.
<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
é onde eu tenho o cliente NuGet (lembre-se de salvar sua chave de API NuGet chamando nuget SetApiKey <my-api-key>
ou para incluir a chave na chamada push do NuGet).
Apenas no caso de ajudar alguém ^ _ ^.