blob: 47ab6d287e6adcc99e233bab9daacb82aba9745a (
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
|
// Copyright (C) 2008-2012 NVIDIA Corporation.
// Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#ifndef QSSG_RENDERER_UTIL_H
#define QSSG_RENDERER_UTIL_H
//
// W A R N I N G
// -------------
//
// This file is not part of the Qt API. It exists purely as an
// implementation detail. This header file may change from version to
// version without notice, or even be removed.
//
// We mean it.
//
#include <QtQuick3DUtils/private/qssgrenderbasetypes_p.h>
QT_BEGIN_NAMESPACE
namespace QSSGRendererUtil
{
inline constexpr quint32 nextMultipleOf4(quint32 value) {
return (value + 3) & ~3;
}
}
class QSSGRenderPath
{
public:
QSSGRenderPath() = default;
explicit inline QSSGRenderPath(const QString &p) noexcept
: m_path(p), m_key(qHash(p, QHashSeed::globalSeed())) {}
inline bool isNull() const { return m_path.isNull(); }
inline bool isEmpty() const { return m_path.isEmpty(); }
QString path() const { return m_path; }
private:
friend bool operator==(const QSSGRenderPath &, const QSSGRenderPath &);
friend size_t qHash(const QSSGRenderPath &, size_t) Q_DECL_NOTHROW;
QString m_path;
size_t m_key = 0;
};
inline bool operator==(const QSSGRenderPath &p1, const QSSGRenderPath &p2)
{
return (p1.m_key == p2.m_key) && (p1.m_path == p2.m_path);
}
inline size_t qHash(const QSSGRenderPath &path, size_t seed) Q_DECL_NOTHROW
{
return (path.m_key) ? path.m_key : qHash(path.m_path, seed);
}
QT_END_NAMESPACE
#endif
|