diff options
Diffstat (limited to 'setup_native/source/win32/customactions/shellextensions/upgrade.cxx')
-rw-r--r-- | setup_native/source/win32/customactions/shellextensions/upgrade.cxx | 92 |
1 files changed, 46 insertions, 46 deletions
diff --git a/setup_native/source/win32/customactions/shellextensions/upgrade.cxx b/setup_native/source/win32/customactions/shellextensions/upgrade.cxx index 6280bfb5b2e5..2efd60ad868a 100644 --- a/setup_native/source/win32/customactions/shellextensions/upgrade.cxx +++ b/setup_native/source/win32/customactions/shellextensions/upgrade.cxx @@ -2,7 +2,7 @@ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * + * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite @@ -49,82 +49,82 @@ using namespace std; -namespace +namespace { // The provided GUID must be without surounding '{}' string GetGuidPart(const string& guid, int index) { - assert((guid.length() == 36) && "No GUID or wrong format!"); + assert((guid.length() == 36) && "No GUID or wrong format!"); assert(((index > -1) && (index < 5)) && "Out of range!"); - + if (index == 0) return string(guid.c_str(), 8); if (index == 1) return string(guid.c_str() + 9, 4); if (index == 2) return string(guid.c_str() + 14, 4); if (index == 3) return string(guid.c_str() + 19, 4); if (index == 4) return string(guid.c_str() + 24, 12); - + return string(); } - + void Swap(char* p1, char* p2) { char tmp = *p1; *p1 = *p2; *p2 = tmp; } - + string Invert(const string& str) { char* buff = reinterpret_cast<char*>(_alloca(str.length())); strncpy(buff, str.c_str(), str.length()); - + char* front = buff; char* back = buff + str.length() - 1; - - while (front < back) - Swap(front++, back--); - - return string(buff, str.length()); + + while (front < back) + Swap(front++, back--); + + return string(buff, str.length()); } - + // Convert the upgrade code (which is a GUID) according // to the way the windows installer does when writing it // to the registry - // The first 8 bytes will be inverted, from the the last + // The first 8 bytes will be inverted, from the the last // 8 bytes always the nibbles will be inverted for further - // details look in the MSDN under compressed registry keys + // details look in the MSDN under compressed registry keys string ConvertGuid(const string& guid) { string convertedGuid; - + string part = GetGuidPart(guid, 0); convertedGuid = Invert(part); - + part = GetGuidPart(guid, 1); convertedGuid += Invert(part); - + part = GetGuidPart(guid, 2); convertedGuid += Invert(part); - + part = GetGuidPart(guid, 3); convertedGuid += Invert(string(part.c_str(), 2)); convertedGuid += Invert(string(part.c_str() + 2, 2)); - - part = GetGuidPart(guid, 4); + + part = GetGuidPart(guid, 4); int pos = 0; for (int i = 0; i < 6; i++) { convertedGuid += Invert(string(part.c_str() + pos, 2)); - pos += 2; + pos += 2; } return convertedGuid; } - + string GetMsiProperty(MSIHANDLE handle, const string& sProperty) { - string result; - TCHAR szDummy[1] = TEXT(""); - DWORD nChars = 0; + string result; + TCHAR szDummy[1] = TEXT(""); + DWORD nChars = 0; if (MsiGetProperty(handle, sProperty.c_str(), szDummy, &nChars) == ERROR_MORE_DATA) { @@ -132,13 +132,13 @@ namespace LPTSTR buffer = reinterpret_cast<LPTSTR>(_alloca(nBytes)); ZeroMemory( buffer, nBytes ); MsiGetProperty(handle, sProperty.c_str(), buffer, &nChars); - result = buffer; + result = buffer; } - return result; + return result; } inline bool IsSetMsiProperty(MSIHANDLE handle, const string& sProperty) - { + { return (GetMsiProperty(handle, sProperty).length() > 0); } @@ -157,51 +157,51 @@ namespace { HKEY hKey; if (RegOpenKey(hRootKey, regKey.c_str(), &hKey) == ERROR_SUCCESS) - { + { DWORD nSubKeys; DWORD lLongestSubKey; - + if (RegQueryInfoKey( hKey, NULL, NULL, NULL, &nSubKeys, &lLongestSubKey, NULL, NULL, NULL, NULL, NULL, NULL) == ERROR_SUCCESS) { LPTSTR buffer = reinterpret_cast<LPTSTR>(_alloca(lLongestSubKey + 1)); - + for (DWORD i = 0; i < nSubKeys; i++) - { - LONG ret = RegEnumKey(hKey, i, buffer, lLongestSubKey + 1); - if ((ret == ERROR_SUCCESS) && (buffer == upgradeKey)) + { + LONG ret = RegEnumKey(hKey, i, buffer, lLongestSubKey + 1); + if ((ret == ERROR_SUCCESS) && (buffer == upgradeKey)) return true; } } } return false; } -} // namespace +} // namespace extern "C" UINT __stdcall SetProductInstallMode(MSIHANDLE handle) { - string upgradeCode = GetMsiProperty(handle, TEXT("UpgradeCode")); + string upgradeCode = GetMsiProperty(handle, TEXT("UpgradeCode")); upgradeCode = ConvertGuid(string(upgradeCode.c_str() + 1, upgradeCode.length() - 2)); - - //MessageBox(NULL, upgradeCode.c_str(), TEXT("Debug"), MB_OK); - + + //MessageBox(NULL, upgradeCode.c_str(), TEXT("Debug"), MB_OK); + if (RegistryKeyHasUpgradeSubKey( - HKEY_CURRENT_USER, + HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\Installer\\UpgradeCodes"), upgradeCode) && IsSetMsiProperty(handle, TEXT("ALLUSERS"))) - { + { UnsetMsiProperty(handle, TEXT("ALLUSERS")); //MessageBox(NULL, "ALLUSERS removed", "DEBUG", MB_OK); } else if (RegistryKeyHasUpgradeSubKey( - HKEY_LOCAL_MACHINE, + HKEY_LOCAL_MACHINE, TEXT("Software\\Classes\\Installer\\UpgradeCodes"), upgradeCode) && !IsSetMsiProperty(handle, TEXT("ALLUSERS"))) { SetMsiProperty(handle, TEXT("ALLUSERS")); //MessageBox(NULL, "ALLUSERS set", "DEBUG", MB_OK); - } - return ERROR_SUCCESS; + } + return ERROR_SUCCESS; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |