Visual Studio.NET Add-In for Incrementing Project Build Numbers

Environment: Visual Studio.NET 2002, Visual Studio.NET 2003


The most convenient method I find for automatically incrementing project build numbers for Visual C++ projects is through an add-in that modifies the build number on each successful release build. I found an add-in for doing that at CodeGuru, but it only works for Visual Studio 6.0. I searched a long time for a similar add-in written for Visual Studio.NET but haven't found any. So I wrote one myself, after I did a few days of research about the Visual Studio Automation Model.

Advantages of Using an Add-In over Using Macros or Separate Executables

The first advantage is seamless integration with Visual Studio.NET, thus is not necessary to make custom build steps, pre-link steps, or otherwise trigger the build number incrementation. The main advantage of using an add-in is it uses the Visual Studio.NET automation code model to make modifications to files, thus the development environment is "aware" of the changes and manages them better than an external solution.

So, What Does the Add-In Do?

On each successful build of a project on a release configuration, the add-in searches for a file included in the project called "version.h". Then it searches for one or all of the following macros and modifies their contents in a way described below.

The macros that should be present in version.h are (at least one of them is required):


The macros can be placed anywhere in the file. The file can contain other things besides these macros. Here is an example of a version.h file:

#define FILE_VERSION         1,0,0,1
#define PRODUCT_VERSION      1,0,0,9
#define FILE_VERSION_STR     "1, 0, 0, 1\n"
#define PRODUCT_VERSION_STR  "1, 0, 0, 9\n"

After a successful project build on a release configuration, version.h will become:

#define FILE_VERSION         1,0,0,2
#define PRODUCT_VERSION      1,0,0,10
#define FILE_VERSION_STR     "1, 0, 0, 2\n"
#define PRODUCT_VERSION_STR  "1, 0, 0, 10\n"
Tip: All of these macros can contain any type of string containing at least a decimal number. Only the last number on that string will be incremented. For example, if FILE_VERSION is 1.2, after the build it will become 1.3.

Okay, So How Do You Use the add-In to Increase the Build Number Contained in the Version Resource?

There is an article on Microsoft Support found here that explains how to do that in a safe way. Basically, you have to cut the version resource from your .rc file and paste it to your .rc2 file. Then, replace the values of the FILEVERSION and PRODUCTVERSION statements with FILE_VERSION and PRODUCT_VERSION. Then, you have to include the "version.h" file at the top of the version resource.

Add-In Installation

  1. Save the file "autobuildnumber.dll" in a directory.
  2. Run the "regsvr32 autobuildnumber.dll" command from the add-in's directory.
  3. Double click the autobuildnumber.reg file.
  4. Go to the Visual Studio.NET IDE, and from the Tools->Add-in Manager menu, check the "AutoBuildNumber" box. You also can check the boxes "Startup" and "Command line".
  5. Include a "version.h" file (containing the above macros) in your project.
  6. That's all.


After successfully incrementing build numbers, the add-in displays an output message in the build output window, indicating success. If the version.h file is under source control and is not checked out, the add-in displays an error message in the build output window describing the error. In that case, the build number is not incremented.

The source files are not included. The add-in was built with Visual Studio.NET 2003 and tested on Visual Studio.NET 2002 and 2003. Please e-mail me for support information and source files information.


Download add-in - 68 Kb


  • VS2005 No Go

    Posted by Wiccaan on 12/14/2006 07:29am

    I know this article is pretty old, just informing the author, if they are still around and haven't noticed yet, that this does not work VS2005 =/

  • Can you email me the source

    Posted by Legacy on 02/12/2004 12:00am

    Originally posted by: FilbertFox

    I like your add-in, can you email me the source code or release it on this site? I need to add a few features of my own, so the source will save me alot of time.

  • Please provide source code for your addin

    Posted by Legacy on 05/20/2003 12:00am

    Originally posted by: logan dugenoux

    The interesting thing is mainty how to build addins for Visual Studio, not the build number...

  • Source code is more welcome

    Posted by Legacy on 05/16/2003 12:00am

    Originally posted by: typetype

    Do you notice that almost all projects in codeguru are coming as both binary and source code?

Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • This white paper examines the economics of deploying Red Hat's Storage Server. Based on GlusterFS, a distributed file system that Red Hat acquired as part of Gluster, Red Hat Storage Server is ushering in a new era of software-based storage (also known as software-defined storage by many suppliers) solutions. Such solutions leverage commodity x86-based hardware from server vendors and a distributed shared nothing architecture that allows businesses to build out a service-based storage infrastructure in an …

  • Data integrity and ultra-high performance dictate the success and growth of many companies. One of these companies is BridgePay Network Solutions, a recently launched and rapidly growing financial services organization that allows merchants around the world to process millions of daily credit card transactions. Due to the nature of their business, their IT team needed to strike the perfect balance between meeting regulatory-mandated data security measures with the lowest possible levels of latency and …

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date