KsWare.BuildTools.IncrementVersion 0.3.0

dotnet tool install --global KsWare.BuildTools.IncrementVersion --version 0.3.0                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local KsWare.BuildTools.IncrementVersion --version 0.3.0                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=KsWare.BuildTools.IncrementVersion&version=0.3.0                
nuke :add-package KsWare.BuildTools.IncrementVersion --version 0.3.0                

KsWare.BuildTools.IncrementVersion

A tool which increments the build number before build.

The idea behind is to define the Major/Minor version on demand in a centralized location and increment the Build number on each (release) build without the need to change each version property in each project.

Because you (should) use always a change log file, we use this to define the version number.

Supports projects with the SDK format, including MAUI projects.
See also Identify the project format.

Currently it is provided to works with single project solutions, or more precisely, with one change log file per project. This means you cannot increment multiple projects with only one ChangeLog file.

And Yes, IncrementVersion uses IncrementVersion to increment the version. 😆

Usage

1. Adapt project file

After installing as a global tool you can add a build target

<Target Name="IncrementVersion" BeforeTargets="PrepareForBuild" Condition="$(Configuration)=='Release'">
    <Exec Command="KsWare.BuildTools.IncrementVersion.exe $(ProjectPath) -f $(SolutionDir)..\ChangeLog.md" />
</Target>

Exec Command: KsWare.BuildTools.IncrementVersion.exe <project> [-f <path>][-t]

Parameter Description
<project> path to the project file
-f <path> path to file which contains the version
-t or -test No changes will be writen. Use this for test purposes.

Don't forget to add/configure any of the version properties in your project file. I suggest to use VersionPrefix. Only properties that are present are changed! Properties containing macros will not be changed.

2. The ChangeLog file

  • Create a simple Changelog.md file.
  • Check if the -f path in the target points to this file!
  • Specify the major/minor version on top of file.
# 1.0
- first public version

As soon as you set the configuration to "Release", the version is incremented ONCE and also written into the ChangeLog.md.

For the next build number simple add your changes on top of the ChangeLog.md file.

- bugfixes
# 1.0.0

As soon as a new release version is created, the current version is added.

# 1.0.1
- bugfixes
# 1.0.0

To setup a new major/minor version, simple add the version on top, like in the first step.

# 2.0
- A new major version is born
# 1.0.1
...
Options

Installation

Installation from NuGet.org

dotnet tool install KsWare.BuildTools.IncrementVersion -g

Installation from local directory

dotnet tool install KsWare.BuildTools.IncrementVersion -g --add-source .

For more options see dotnet tool install

Global tools are installed in the following directories by default when you specify the -g or --global option:

Operating system Path
Linux/macOS $HOME/.dotnet/tools
Windows %USERPROFILE%.dotnet\tools

MAUI Projects

MAUI Properties are using other version properties.

  • ApplicationDisplayVersion contains the version number like '1.0.1' and is processed as usual like the VersionPrefix.

  • ApplicationVersion is an integer. This is also incremented with each release build.

Additional usage

You can use this tool per CLI also without a change log file.

KsWare.BuildTools.IncrementVersion.exe <project> [-v <version>][-t]

Parameter Description
<project> path to the project file
-v <version> the desired version (major/minor)
-t or -test No changes will be writen. Use this for test purposes.

Naming

For reasons of uniqueness and to avoid naming conflicts with other tools I finally decided to use the full name KsWare.BuildTools.IncrementVersion also for the tool name and for the binary file. As a short name I will remember KsIncVer but maybe I can think of a better one.

Limitations/Drawbacks

  • curently only one version format "Major.Minor.Build"
  • you need one changelog per project and not one per solution
  • semantic versioning not completey used

Planned features

  • reduce limitations/drawbacks of course 😉
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
0.3.0 283 6/16/2022

- log exceptions to IncrementVersion.log
- FIX for duplicate entries in project file
- add feature PackageReleaseNotes
- unify unique project/tool name "KsWare.BuildTools.IncrementVersion"
- first version on nuget.org