blob: 1e64d9b2d32e4edd9755e0456434fc0f0c96f44b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
// Copyright (C) 2016 Jochen Becher
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0 WITH Qt-GPL-exception-1.0
#pragma once
#include "uid.h"
#include "qmtassert.h"
namespace qmt {
template<class T>
class Handle
{
public:
Handle() = default;
explicit Handle(const Uid &uid) : m_uid(uid) { }
explicit Handle(T *t) : m_uid(t ? t->uid() : Uid()), m_target(t) { }
Handle(const Handle &rhs) : m_uid(rhs.m_uid), m_target(rhs.m_target) { }
template<class U>
Handle(const Handle<U> &rhs) : m_uid(rhs.uid()), m_target(rhs.target()) { }
Handle &operator=(const Handle &) = default;
bool isNull() const { return !m_uid.isValid(); }
bool hasTarget() const { return m_target != nullptr; }
Uid uid() const { return m_uid; }
T *target() const { return m_target; }
void setUid(const Uid &uid)
{
QMT_CHECK(m_target ? (m_target->uid() == uid) : true);
m_uid = uid;
}
void setTarget(T *t)
{
m_uid = t ? t->uid() : Uid();
m_target = t;
}
void clear()
{
m_uid = Uid();
m_target = nullptr;
}
void clearTarget() { m_target = nullptr; }
friend auto qHash(const Handle<T> &handle) { return qHash(handle.uid()); }
private:
Uid m_uid;
T *m_target = nullptr;
};
template<class T, class U>
bool operator==(const Handle<T> &lhs, const Handle<U> &rhs)
{
return lhs.uid() == rhs.uid();
}
template<class T>
Handle<T> makeHandle(T *t)
{
return Handle<T>(t);
}
template<class T, class U>
Handle<T> handle_dynamic_cast(const Handle<U> &handle)
{
if (!handle.hasTarget())
return Handle<T>(handle.uid());
return Handle<T>(dynamic_cast<T *>(handle.target()));
}
} // namespace qmt
|