mirror of https://github.com/nodejs/node.git
win,msi: correct installation path registry keys
This is a port of 14db629497
.
Original commit message:
Since install is per machine only, installation path should be stored
in local machine instead of current user. The registry stores HKLM in
different places for 32 and 64 bit applications, so the installer
will not suggest the old path when upgrading from 32 to 64 bit
version.
Fixes joyent/node#5592
Fixes joyent/node#25087
PR-URL: https://github.com/joyent/node/pull/25640
Reviewed-By: Alexis Campailla <alexis@janeasystems.com>
Reviewed-By: Bert Belder <bertbelder@gmail.com>
PR-URL: https://github.com/nodejs/node/pull/2565
Reviewed-By: Alexis Campailla <alexis@janeasystems.com>
This commit is contained in:
parent
4cfe5eb9af
commit
c6a54d0964
|
@ -44,6 +44,14 @@
|
|||
|
||||
<Property Id="INSTALLDIR">
|
||||
<RegistrySearch Id="InstallPathRegistry"
|
||||
Type="raw"
|
||||
Root="HKLM"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
Name="InstallPath"/>
|
||||
<!-- Also need to search under HKCU to support upgrading from old
|
||||
versions. If we wanted to disable backward compatibility, this
|
||||
second search could be deleted. -->
|
||||
<RegistrySearch Id="InstallPathRegistryCU"
|
||||
Type="raw"
|
||||
Root="HKCU"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
|
@ -56,8 +64,9 @@
|
|||
Description="!(loc.NodeRuntime_Description)"
|
||||
Absent="disallow">
|
||||
<ComponentRef Id="NodeExecutable"/>
|
||||
<ComponentRef Id="NodeRegistryEntries"/>
|
||||
<ComponentRef Id="NodeVarsScript"/>
|
||||
<ComponentRef Id="NodeStartMenuAndRegistryEntries"/>
|
||||
<ComponentRef Id="NodeStartMenu"/>
|
||||
<ComponentRef Id="AppData" />
|
||||
<ComponentGroupRef Id="Product.Generated"/>
|
||||
|
||||
|
@ -129,6 +138,20 @@
|
|||
<File Id="node.exe" KeyPath="yes" Source="$(var.SourceDir)\node.exe"/>
|
||||
</Component>
|
||||
|
||||
<Component Id="NodeRegistryEntries">
|
||||
<RegistryValue Root="HKLM"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
Name="InstallPath"
|
||||
Type="string"
|
||||
Value="[INSTALLDIR]"
|
||||
KeyPath="yes"/>
|
||||
<RegistryValue Root="HKLM"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
Name="Version"
|
||||
Type="string"
|
||||
Value="$(var.ProductVersion)"/>
|
||||
</Component>
|
||||
|
||||
<Component Id="NodeVarsScript">
|
||||
<File Id="nodevars.bat" KeyPath="yes" Source="$(var.RepoDir)\tools\msvs\nodevars.bat"/>
|
||||
</Component>
|
||||
|
@ -151,18 +174,15 @@
|
|||
</DirectoryRef>
|
||||
|
||||
<DirectoryRef Id="ApplicationProgramsFolder">
|
||||
<Component Id="NodeStartMenuAndRegistryEntries">
|
||||
<Component Id="NodeStartMenu">
|
||||
<!-- RegistryValue needed because every Component must have a KeyPath.
|
||||
Because of ICE43, the Root must be HKCU. -->
|
||||
<RegistryValue Root="HKCU"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
Name="InstallPath"
|
||||
Type="string"
|
||||
Value="[INSTALLDIR]"
|
||||
Key="$(var.RegistryKeyPath)\Components"
|
||||
Name="NodeStartMenuShortcuts"
|
||||
Type="integer"
|
||||
Value="1"
|
||||
KeyPath="yes"/>
|
||||
<RegistryValue Root="HKCU"
|
||||
Key="$(var.RegistryKeyPath)"
|
||||
Name="Version"
|
||||
Type="string"
|
||||
Value="$(var.ProductVersion)"/>
|
||||
<Shortcut Id="NodeVarsScriptShortcut"
|
||||
Name="Node.js command prompt"
|
||||
Target="[%ComSpec]"
|
||||
|
|
Loading…
Reference in New Issue