3

我正在维护一个旧应用程序,其中用户配置存储在注册表中。卸载时留下我现在正在用 WiX 重写安装程序。

如果注册表中没有默认值,安装程序应在注册表中添加一个默认值,否则应保留现有值。

我正在考虑如何在 WiX 中做到这一点。而我想出的解决方案有些繁琐:

 <Property Id="MY_PROPERTY">
      <RegistrySearch Root="HKLM" Key="SOFTWARE\MyProduct" Name="MyProperty" Type="raw" />
  </Property>

  <CustomAction Id="ca.SetDefaultValue" Property="MY_PROPERTY" Value="DefaultValue" />

  <InstallExecuteSequence>
      <Custom After="RegistrySearch" Action="ca.SetDefaultValue">Not MY_PROPERTY</Custom>
  </InstallExecuteSequence>

  <Component Id="c.Registry">
      <RegistryValue Root="HKLM" Key="SOFTWARE\MyProduct" Name="MyProperty" Type="string" Value="[MY_PROPERTY]" />
  </Component>

因此,请进行注册表搜索以查找旧值。如果未设置,则使用计划的自定义操作设置为默认值。然后“像往常一样”创建值。

谁能想出一个更顺畅的方法来做到这一点?

请注意,我不能使用方便的变量,Installed因为值可能在那里,被以前的、现在已卸载的版本留下。

4

2 回答 2

8

从Wix 记住属性模式开始,但更进一步。AppSearch运行后,如果REMEMBERME属性获得或未获得值,请使用SetProperty自定义操作分配默认值 if REMEMBERME=""

不过,我更进一步。我有一个我称之为“财产优先”的概念。基本上,它是一个属性应该如何获得其价值的优先级列表。

从最高到最低:

  1. 在 UI 期间输入的属性
  2. 在命令行传入的公共属性
  3. 期间发现的属性AppSearch
  4. Property表中定义的默认值

换句话说,在第一次静默安装期间,在命令行中没有传递任何属性,应该使用属性表中的默认值。

在没有在命令行传递任何属性的第二次静默安装期间,记住的值应优先于默认值。(如果不同)

在第一次或第二次静默安装期间,在命令行传递的属性应被视为覆盖值,并优先于默认值和记忆值。

在交互式安装期间,会发生上述规则,并且 UI 应显示该值。如果用户更改该值,则这是最终值。

我将由您决定如何实现各种自定义操作来执行此操作。它通常涉及一个 temp prop 和一个 real prop 以及一系列具有正确执行调度和条件的 Set Property CA,以执行您希望它执行的操作。

于 2012-07-08T16:53:50.077 回答
1

您没有明确设置keypath=yes组件中的注册表值。但是,在这种情况下,wix 将选择第一个可以用作键路径的子项。来自wix 组件元素文档

如果组件或子注册表值或文件的 KeyPath 未设置为“是”,WiX 将按顺序查看组件下的子元素并尝试自动选择其中一个作为键路径。

因此,您的注册表值是安装它的组件的密钥路径。这意味着如果注册表值已经存在,则不会安装该组件。据我所知,这就是你想要的行为。

于 2012-07-08T21:59:04.860 回答