2

WiXとBurnのカスタムUIを作成しようとしています。私は見つけたガイドのいくつかに従いましたが、これまでのところ、BootstrapperApplicationから継承した次のプロジェクトがあります。

namespace MyBA
{
    public class TestBA : BootstrapperApplication
    {
        protected override void Run()
        {
            MessageBox.Show("My BA is running");
            this.Engine.Quit(0);
        }
    }
}

そしてAssemblyInfo.csで:

[assembly: BootstrapperApplication(typeof(TestBA))]

次に、私のBootstrapperプロジェクトには、次のものがあります。

<?xml version="1.0" encoding="UTF-8"?>
<Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"
     xmlns:util="http://schemas.microsoft.com/wix/UtilExtension">

    <Bundle Name="MyApplication"
            Version="1.0.0"
            Manufacturer="Acme Ltd"
            UpgradeCode="F84A4058-FDF6-4218-BCB5-12C811DA3C99"
            Condition="NOT ((VersionNT = 600 AND ServicePackLevel >=2) OR (VersionNT >= 601))"
            IconSourceFile="$(var.MyApplicationInstallerRequiredFiles.ProjectDir)logo.ico"
            SplashScreenSourceFile="$(var.MyApplicationInstallerRequiredFiles.ProjectDir)Splashscreen.bmp"
            DisableRepair="no"
            DisableRemove="no"
            DisableModify="no">

        <WixVariable Id="WixMbaPrereqPackageId"
                     Value="Netfx4Full" />
        <WixVariable Id="WixMbaPrereqLicenseUrl"
                     Value="NetfxLicense.rtf" />

        <WixVariable Id="WixStdbaLicenseRtf"
                     Value="$(var.MyApplicationInstallerRequiredFiles.ProjectDir)Licence.en-gb.rtf" />
        <WixVariable Id="WixStdbaLogo"
                     Value="$(var.MyApplicationInstallerRequiredFiles.ProjectDir)logoInstallSmall.bmp" />

        <BootstrapperApplicationRef Id='ManagedBootstrapperApplicationHost'>
            <Payload Name='BootstrapperCore.config'
                     SourceFile='$(var.MyApplicationInstallerRequiredFiles.ProjectDir)Bootstrapper\MyBA.BootstrapperCore.config' />
            <Payload SourceFile='$(var.MyApplicationInstallerRequiredFiles.ProjectDir)Bootstrapper\MyBA.dll' />
        </BootstrapperApplicationRef>

        <Chain>
            <PackageGroupRef Id="MyApplicationPackage" />
        </Chain>
    </Bundle>
</Wix>

MyBA.BootstrapperCore.configを追加しました

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <sectionGroup name="wix.bootstrapper"
                      type="Microsoft.Tools.WindowsInstallerXml.Bootstrapper.BootstrapperSectionGroup, BootstrapperCore">
            <section name="host"
                     type="Microsoft.Tools.WindowsInstallerXml.Bootstrapper.HostSection, BootstrapperCore" />
        </sectionGroup>
    </configSections>
    <startup useLegacyV2RuntimeActivationPolicy="true">
        <supportedRuntime version="v4.0" />
    </startup>
    <wix.bootstrapper>
        <host assemblyName="MyBA">
            <supportedFramework version="v4\Full" />
            <supportedFramework version="v4\Client" />
        </host>
    </wix.bootstrapper>
</configuration>

ただし、ブートストラッパーに対してSetup.exeを実行すると、スプラッシュスクリーンが短時間表示されますが、それ以外は表示されません。ログの%TEMP%を見ると、次のようになっています。

[0A00:0424][2011-11-02T15:52:08]: Burn v3.6.2221.0, path: C:\MyApplication\dev\source\Bootstrapper1\bin\Debug\Setup.exe, cmdline: ''
[0A00:0424][2011-11-02T15:52:08]: Setting string variable 'WixBundleName' to value 'MyApplication'
[0A00:0424][2011-11-02T15:52:08]: Setting string variable 'WixBundleLog' to value 'C:\Users\AppData\Local\Temp\MyApplication_20111102155208.log'
[0A00:0424][2011-11-02T15:52:08]: Condition 'NOT ((VersionNT = 600 AND ServicePackLevel >=2) OR (VersionNT >= 601))' evaluates to true.
[0A00:0424][2011-11-02T15:52:08]: Setting string variable 'WixBundleOriginalSource' to value 'C:\MyApplication\dev\source\Bootstrapper1\bin\Debug\Setup.exe'
[0A00:0424][2011-11-02T15:52:08]: Loading managed bootstrapper application.
[0A00:0424][2011-11-02T15:52:08]: Error 0x80131040: Failed to create the managed bootstrapper application.
[0A00:0424][2011-11-02T15:52:08]: Error 0x80131040: Failed to create UX.
[0A00:0424][2011-11-02T15:52:08]: Error 0x80131040: Failed to load UX.
[0A00:0424][2011-11-02T15:52:08]: Error 0x80131040: Failed while running
[0A00:0424][2011-11-02T15:52:08]: Error 0x80131040: Failed to run per-user mode.

なぜこれが発生し、上記のエラーが発生するのですか?

4

1 に答える 1