1 | /**************************************************************************** |
2 | ** |
3 | ** Copyright (C) 2016 The Qt Company Ltd. |
4 | ** Contact: https://www.qt.io/licensing/ |
5 | ** |
6 | ** This file is part of the qmake application of the Qt Toolkit. |
7 | ** |
8 | ** $QT_BEGIN_LICENSE:GPL-EXCEPT$ |
9 | ** Commercial License Usage |
10 | ** Licensees holding valid commercial Qt licenses may use this file in |
11 | ** accordance with the commercial license agreement provided with the |
12 | ** Software or, alternatively, in accordance with the terms contained in |
13 | ** a written agreement between you and The Qt Company. For licensing terms |
14 | ** and conditions see https://www.qt.io/terms-conditions. For further |
15 | ** information use the contact form at https://www.qt.io/contact-us. |
16 | ** |
17 | ** GNU General Public License Usage |
18 | ** Alternatively, this file may be used under the terms of the GNU |
19 | ** General Public License version 3 as published by the Free Software |
20 | ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT |
21 | ** included in the packaging of this file. Please review the following |
22 | ** information to ensure the GNU General Public License requirements will |
23 | ** be met: https://www.gnu.org/licenses/gpl-3.0.html. |
24 | ** |
25 | ** $QT_END_LICENSE$ |
26 | ** |
27 | ****************************************************************************/ |
28 | |
29 | #ifndef QT_WINDOWS_REGISTRY_H |
30 | #define QT_WINDOWS_REGISTRY_H |
31 | |
32 | // |
33 | // W A R N I N G |
34 | // ------------- |
35 | // |
36 | // This file is not part of the Qt API. It exists purely as an |
37 | // implementation detail. This header file may change from version to |
38 | // version without notice, or even be removed. |
39 | // |
40 | // We mean it. |
41 | // |
42 | |
43 | #include <QtCore/qglobal.h> |
44 | |
45 | #ifdef Q_OS_WIN32 |
46 | #include <QtCore/qt_windows.h> |
47 | #else |
48 | typedef void* HKEY; |
49 | #endif |
50 | |
51 | #include <QtCore/qstring.h> |
52 | |
53 | QT_BEGIN_NAMESPACE |
54 | |
55 | /** |
56 | * Read a value from the Windows registry. |
57 | * |
58 | * If the key is not found, or the registry cannot be accessed (for example |
59 | * if this code is compiled for a platform other than Windows), a null |
60 | * string is returned. |
61 | * |
62 | * 32-bit code reads from the registry's 32 bit view (Wow6432Node), |
63 | * 64 bit code reads from the 64 bit view. |
64 | * Pass KEY_WOW64_32KEY to access the 32 bit view regardless of the |
65 | * application's architecture, KEY_WOW64_64KEY respectively. |
66 | */ |
67 | QString qt_readRegistryKey(HKEY parentHandle, const QString &rSubkey, |
68 | unsigned long options = 0); |
69 | |
70 | QT_END_NAMESPACE |
71 | |
72 | #endif // QT_WINDOWS_REGISTRY_H |
73 | |
74 | |