Итак, я пришел к тому же выводу, что и Боб. Это было неприемлемо, поскольку внесло слишком много вариаций в сборки, поэтому я решил это по-другому. Я знал, что исполняемый файл в командной строке может ссылаться на переменную среды Windows во время выполнения. Поэтому все, что мне нужно было сделать, - это установить переменную окружения, сослаться на нее и вуаля:
light.exe ... -out Installer.%BLAH_VERSION%.msi
Чтобы это произошло, нужно было сделать совсем немного. Для начала мой номер версии взят из информации о сборке проекта Visual Studio. Первое, что мне нужно было сделать, это сделать его динамичным, чтобы он создавал новый для каждой сборки. Изменение последних 2 чисел на * сделало это:
[assembly: AssemblyVersion("6.4.*")]
Следующее, что нужно сделать, - это экстернализовать это число, чтобы его можно было использовать в другом месте. Добавление этого раздела в конец csproj сделало следующее:
<Target Name="PostBuildMacros">
<GetAssemblyIdentity AssemblyFiles="$(TargetPath)">
<Output TaskParameter="Assemblies" ItemName="Targets" />
</GetAssemblyIdentity>
<ItemGroup>
<VersionNumber Include="@(Targets->'%(Version)')"/>
</ItemGroup>
</Target>
<PropertyGroup>
<PostBuildEventDependsOn>
$(PostBuildEventDependsOn);
PostBuildMacros;
</PostBuildEventDependsOn>
<PostBuildEvent>setx BLAH_VERSION @(VersionNumber)</PostBuildEvent>
</PropertyGroup>
Благодаря этому сообщению stackoverflow за помощь.
Конечно, чтобы ссылаться на него, мне понадобитсячтобы найти способ получить уже открытую командную строку, чтобы обновить ее ссылки на переменную среды. Это оказалось самым сложным, но эта статья о переполнении стека пришла на помощь.
Так что теперь я связал все это вместе с помощью пакетного сценария Windows. По сути, я собираю EXE, проверяю его, проверяю, что он работает хорошо, запускаю свой пакетный скрипт и у меня есть файл MSI, названный в честь созданной для меня версии информации о сборке.