Я пытаюсь создать пакет WiX, который устанавливает .NET Framework 4.0 перед установщиком MSI. Я проверил файл журнала для моего загрузочного файла с использованием аргумента командной строки \l log.txt
и обнаружил, что ExePackage::DetectCondition
всегда оценивает значение false.WiX 'Bundle' 'ExePackage' 'DetectCondition' всегда false
Я включаю WixNetFxExtension.dll
в качестве ссылки в моем проекте Visual Studio 2010 Windows Installer XML Bootstrapper.
Я в том числе NetFxExtension
имен:
<?xml version="1.0" encoding="UTF-8"?>
<Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"
xmlns:util="http://schemas.microsoft.com/wix/UtilExtension"
xmlns:bal="http://schemas.microsoft.com/wix/BalExtension"
xmlns:netfx="http://schemas.microsoft.com/wix/NetFxExtension">
Обеспечение основной структуры расслоения:
<Bundle Name="RSA Bootstrapper"
...
<BootstrapperApplicationRef Id="WixStandardBootstrapperApplication.RtfLicense" />
...
<Chain>
<PackageGroupRef Id="NET40" />
<PackageGroupRef Id="RSA_Application" />
</Chain>
</Bundle>
...
Я в том числе <PropertyRef Id="NETFRAMEWORK40FULL" />
во фрагменте, а затем происходит определить ExePackage для .NET Рамка 4.0 (NET40
):
<Fragment>
<PropertyRef Id="NETFRAMEWORK40FULL" />
<PackageGroup Id="NET40">
<ExePackage SourceFile="dotNetFx40_Full_x86_x64.exe"
Compressed="yes"
Cache="yes"
DetectCondition="NETFRAMEWORK40FULL"
InstallCommand="/norestart /passive /showrmui /ACTION=Install"
Permanent="yes"
InstallCondition="NOT NETFRAMEWORK40FULL"
Vital="yes" >
<ExitCode Value="0" Behavior="success" />
<ExitCode Value="1641" Behavior="scheduleReboot" />
<ExitCode Value="3010" Behavior="scheduleReboot" />
<ExitCode Behavior="error" /> <!-- Everything else is an error -->
</ExePackage>
...
Я также проверил вывод сборки Visual Studio, чтобы подтвердить правильность ссылки на WixNetFxExtension.dll
:
C: \ Program Files (x86) \ WiX Toolset v3.7 \ bin \ Light.exe ... -ext "C : \ Program Files (x86) \ WiX Toolset v3.7 \ bin \ WixNetFxExtension.dll "
Проблема с DetectCondition
. Независимо от того, что я установил, он оценивает false
.
Думая, что, может быть, NETFRAMEWORK40FULL
ссылки нельзя доверять, я пытался использовать это вместо того, чтобы:
<Fragment>
<Variable Name="isInstalled"
Type="numeric"
Value="0"
Persisted="yes"
bal:Overridable="yes"/>
<util:RegistrySearch Id="FindInstallKey"
Root="HKLM" Key="SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full"
Value="Install"
Result="exists"
Variable="InstallKeyExists" />
<util:RegistrySearch
Root="HKLM" Key="SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full"
Value="Install"
Variable="isInstalled"
After="FindInstallKey"
Condition="InstallKeyExists = true"
Format="raw" />
</Fragment>
Установка DetectCondition="isInstalled"
или DetectCondition="isInstalled = true"
всегда имеет значение ложь. Даже установка DetectCondition="true"
всегда оценивается как false!
Вот лог фрагмент того, что я имею в виду, с DetectCondition="true"
[16A0:17B4][2013-02-13T13:01:43]i001: Burn v3.7.1224.0, Windows v6.1 (Build 7601: Service Pack 1), path: C:\Users\lalic\Documents\Visual Studio 2010\Projects\RSA Preset\Bootstrapper\bin\Release\Bootstrapper.exe, cmdline: '/l log.txt -burn.unelevated BurnPipe.{33090847-CC78-445B-BAAA-564B840B7E8E} {38F95C6A-EC0F-4402-951B-FABFC5827CB6} 6296'
[16A0:17B4][2013-02-13T13:01:43]i000: Setting string variable 'WixBundleLog' to value 'C:\Users\lalic\Documents\Visual Studio 2010\Projects\RSA Preset\Bootstrapper\bin\Release\log.txt'
[16A0:17B4][2013-02-13T13:01:43]i000: Setting string variable 'WixBundleOriginalSource' to value 'C:\Users\lalic\Documents\Visual Studio 2010\Projects\RSA Preset\Bootstrapper\bin\Release\Bootstrapper.exe'
[16A0:17B4][2013-02-13T13:01:43]i052: Condition '((VersionNT = v5.1) AND (ServicePackLevel >= 3)) OR ((VersionNT = v5.2) AND (ServicePackLevel >= 2)) OR ((VersionNT = v6.0) AND (ServicePackLevel >= 1)) OR (VersionNT >= v6.1)' evaluates to true.
[16A0:17B4][2013-02-13T13:01:43]i000: Setting string variable 'WixBundleName' to value 'RSA Bootstrapper'
[16A0:17B4][2013-02-13T13:01:43]i100: Detect begin, 2 packages
[16A0:17B4][2013-02-13T13:01:43]i052: Condition 'true' evaluates to false.
[16A0:17B4][2013-02-13T13:01:43]i103: Detected related package: {D431417D-F0AC-4CFB-8E25-E27F5B8101D9}, scope: PerMachine, version: 2.1.15.0, language: 0 operation: MajorUpgrade
[16A0:17B4][2013-02-13T13:01:43]i101: Detected package: dotNetFx40_Full_x86_x64.exe, state: Absent, cached: None
[16A0:17B4][2013-02-13T13:01:43]i101: Detected package: RSA_Preset.msi, state: Absent, cached: None
[16A0:17B4][2013-02-13T13:01:43]i199: Detect complete, result: 0x0
[16A0:17B4][2013-02-13T13:02:04]i200: Plan begin, 2 packages, action: Install
[16A0:17B4][2013-02-13T13:02:04]i052: Condition 'NOT NETFRAMEWORK40FULL' evaluates to true.
В частности, i052: Condition 'true' evaluates to false.
и фактически Condition 'NOT NETFRAMEWORK40FULL' evaluates to true.
, даже если у меня есть .NET 4.0 Full установлен и может вручную найти .NET 4.0 запись в моем реестре, как в обычном месте, так и под HKLM\SOFTWARE\Wow6432Node
(я на 64-битной системе).
Я что-то упустил? Почему DetectCondition не работает для меня? Проект компилирует, запускает, развертывает полезную нагрузку (-ы) и в противном случае работает нормально.
Извините за длинный пост. Попытка быть тщательной! И на этой ноте я использую WiX v3.7 – Terrabits