1// Copyright (C) 2022 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QTVERSIONCHECKS_H
5#define QTVERSIONCHECKS_H
6
7#if 0
8#pragma qt_class(QtVersionChecks)
9#pragma qt_sync_stop_processing
10#endif
11
12#include <QtCore/qtconfiginclude.h>
13
14/*
15 QT_VERSION is (major << 16) | (minor << 8) | patch.
16*/
17#define QT_VERSION QT_VERSION_CHECK(QT_VERSION_MAJOR, QT_VERSION_MINOR, QT_VERSION_PATCH)
18/*
19 can be used like #if (QT_VERSION >= QT_VERSION_CHECK(6, 4, 0))
20*/
21#define QT_VERSION_CHECK(major, minor, patch) ((major<<16)|(minor<<8)|(patch))
22
23/*
24 Helper macros to make some simple code active in Qt 6 or Qt 7 only,
25 like:
26 struct QT6_ONLY(Q_CORE_EXPORT) QTrivialClass
27 {
28 void QT7_ONLY(Q_CORE_EXPORT) void operate();
29 }
30*/
31#if QT_VERSION_MAJOR == 7 || defined(QT_BOOTSTRAPPED)
32# define QT7_ONLY(...) __VA_ARGS__
33# define QT6_ONLY(...)
34#elif QT_VERSION_MAJOR == 6
35# define QT7_ONLY(...)
36# define QT6_ONLY(...) __VA_ARGS__
37#else
38# error Qt major version not 6 or 7
39#endif
40
41/* Macro and tag type to help overload resolution on functions
42 that are, e.g., QT_REMOVED_SINCE'ed. Example use:
43
44 #if QT_CORE_REMOVED_SINCE(6, 4)
45 int size() const;
46 #endif
47 qsizetype size(QT6_DECL_NEW_OVERLOAD) const;
48
49 in the normal cpp file:
50
51 qsizetype size(QT6_IMPL_NEW_OVERLOAD) const {
52 ~~~
53 }
54
55 in removed_api.cpp:
56
57 int size() const { return int(size(QT6_CALL_NEW_OVERLOAD)); }
58*/
59#ifdef Q_QDOC
60# define QT6_DECL_NEW_OVERLOAD
61# define QT6_DECL_NEW_OVERLOAD_TAIL
62# define QT6_IMPL_NEW_OVERLOAD
63# define QT6_IMPL_NEW_OVERLOAD_TAIL
64# define QT6_CALL_NEW_OVERLOAD
65# define QT6_CALL_NEW_OVERLOAD_TAIL
66#else
67# define QT6_DECL_NEW_OVERLOAD QT6_ONLY(Qt::Disambiguated_t = Qt::Disambiguated)
68# define QT6_DECL_NEW_OVERLOAD_TAIL QT6_ONLY(, QT6_DECL_NEW_OVERLOAD)
69# define QT6_IMPL_NEW_OVERLOAD QT6_ONLY(Qt::Disambiguated_t)
70# define QT6_IMPL_NEW_OVERLOAD_TAIL QT6_ONLY(, QT6_IMPL_NEW_OVERLOAD)
71# define QT6_CALL_NEW_OVERLOAD QT6_ONLY(Qt::Disambiguated)
72# define QT6_CALL_NEW_OVERLOAD_TAIL QT6_ONLY(, QT6_CALL_NEW_OVERLOAD)
73#endif
74
75/*
76 Macro to tag Tech Preview APIs.
77 It expands to nothing, because we want to use it in places where
78 nothing is generally allowed (not even an attribute); for instance:
79 to tag other macros, Q_PROPERTY declarations, and so on.
80
81 Still: use it as if it were an C++ attribute.
82
83 To mark a class as TP:
84 class QT_TECH_PREVIEW_API Q_CORE_EXPORT QClass { ... };
85
86 To mark a function:
87 QT_TECH_PREVIEW_API void qFunction();
88
89 To mark an enumeration or enumerator:
90 enum class QT_TECH_PREVIEW_API QEnum {
91 Enum1,
92 Enum2 QT_TECH_PREVIEW_API,
93 };
94
95 To mark parts of a class:
96 class QClass : public QObject
97 {
98 // Q_OBJECT omitted d/t QTBUG-123229
99
100 QT_TECH_PREVIEW_API
101 Q_PROPERTY(int countNG ...) // this is TP
102
103 Q_PROPERTY(int count ...) // this is stable API
104
105 public:
106 QT_TECH_PREVIEW_API
107 void f(); // TP
108
109 void g(); // stable
110 };
111*/
112#define QT_TECH_PREVIEW_API
113
114#endif /* QTVERSIONCHECKS_H */
115