KsWare.BuildTools.IncrementVersion
0.3.0
dotnet tool install --global KsWare.BuildTools.IncrementVersion --version 0.3.0
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local KsWare.BuildTools.IncrementVersion --version 0.3.0
#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 theVersionPrefix
.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 | Versions 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. |
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