Merge topic 'wix-cmake-package-registry'

92c4d40 CPackWiX: added new CPACK_WIX_CMAKE_PACKAGE_REGISTRY variable
This commit is contained in:
Brad King 2014-01-08 09:58:45 -05:00 committed by CMake Topic Stage
commit 1857660984
3 changed files with 56 additions and 1 deletions

View File

@ -205,6 +205,17 @@
# #
# ``<TOOL>`` can be either LIGHT or CANDLE. # ``<TOOL>`` can be either LIGHT or CANDLE.
# #
# .. variable:: CPACK_WIX_CMAKE_PACKAGE_REGISTRY
#
# If this variable is set the generated installer will create
# an entry in the windows registry key
# ``HKEY_LOCAL_MACHINE\Software\Kitware\CMake\Packages\<package>``
# The value for ``<package>`` is provided by this variable.
#
# Assuming you also install a CMake configuration file this will
# allow other CMake projects to find your package with
# the :command:`find_package` command.
#
#============================================================================= #=============================================================================
# Copyright 2013 Kitware, Inc. # Copyright 2013 Kitware, Inc.

View File

@ -437,7 +437,15 @@ bool cmCPackWIXGenerator::CreateWiXSourceFiles()
featureDefinitions.AddAttribute("Level", "1"); featureDefinitions.AddAttribute("Level", "1");
CreateFeatureHierarchy(featureDefinitions); if(!CreateCMakePackageRegistryEntry(featureDefinitions))
{
return false;
}
if(!CreateFeatureHierarchy(featureDefinitions))
{
return false;
}
featureDefinitions.EndElement("Feature"); featureDefinitions.EndElement("Feature");
@ -564,6 +572,39 @@ bool cmCPackWIXGenerator::CreateWiXSourceFiles()
return true; return true;
} }
bool cmCPackWIXGenerator::CreateCMakePackageRegistryEntry(
cmWIXSourceWriter& featureDefinitions)
{
const char* package = GetOption("CPACK_WIX_CMAKE_PACKAGE_REGISTRY");
if(!package)
{
return true;
}
featureDefinitions.BeginElement("Component");
featureDefinitions.AddAttribute("Id", "CM_PACKAGE_REGISTRY");
featureDefinitions.AddAttribute("Directory", "TARGETDIR");
featureDefinitions.AddAttribute("Guid", "*");
std::string registryKey =
std::string("Software\\Kitware\\CMake\\Packages\\") + package;
std::string upgradeGuid = GetOption("CPACK_WIX_UPGRADE_GUID");
featureDefinitions.BeginElement("RegistryValue");
featureDefinitions.AddAttribute("Root", "HKLM");
featureDefinitions.AddAttribute("Key", registryKey);
featureDefinitions.AddAttribute("Name", upgradeGuid);
featureDefinitions.AddAttribute("Type", "string");
featureDefinitions.AddAttribute("Value", "[INSTALL_ROOT]");
featureDefinitions.AddAttribute("KeyPath", "yes");
featureDefinitions.EndElement("RegistryValue");
featureDefinitions.EndElement("Component");
return true;
}
bool cmCPackWIXGenerator::CreateFeatureHierarchy( bool cmCPackWIXGenerator::CreateFeatureHierarchy(
cmWIXSourceWriter& featureDefinitions) cmWIXSourceWriter& featureDefinitions)
{ {

View File

@ -81,6 +81,9 @@ private:
bool CreateWiXSourceFiles(); bool CreateWiXSourceFiles();
bool CreateCMakePackageRegistryEntry(
cmWIXSourceWriter& featureDefinitions);
bool CreateFeatureHierarchy( bool CreateFeatureHierarchy(
cmWIXSourceWriter& featureDefinitions); cmWIXSourceWriter& featureDefinitions);