blob: 833a9d037288497e1e08d3b07834a90ddd221469 (
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "collectionnode.h"
#include <QtCore/qstringlist.h>
QT_BEGIN_NAMESPACE
/*!
\class CollectionNode
\brief A class for holding the members of a collection of doc pages.
*/
/*!
Appends \a node to the collection node's member list, if
and only if it isn't already in the member list.
*/
void CollectionNode::addMember(Node *node)
{
if (!m_members.contains(node))
m_members.append(node);
}
/*!
Returns \c true if this collection node contains at least
one namespace node.
*/
bool CollectionNode::hasNamespaces() const
{
return std::any_of(m_members.cbegin(), m_members.cend(), [](const Node *member) {
return member->isClassNode() && member->isInAPI();
});
}
/*!
Returns \c true if this collection node contains at least
one class node.
*/
bool CollectionNode::hasClasses() const
{
return std::any_of(m_members.cbegin(), m_members.cend(), [](const Node *member) {
return member->isClassNode() && member->isInAPI();
});
}
/*!
\fn template <typename F> NodeMap CollectionNode::getMembers(const F &&predicate) const
Returns a map containing this collection node's member nodes for which \c
predicate(node) returns \c true. The \a predicate is a function or a
lambda that takes a const Node pointer as an argument and returns a bool.
*/
/*!
\fn NodeMap CollectionNode::getMembers(Node::NodeType type) const
Returns a map containing this collection node's member nodes with
a specified node \a type.
*/
/*!
Returns the logical module version.
*/
QString CollectionNode::logicalModuleVersion() const
{
QStringList version;
version << m_logicalModuleVersionMajor << m_logicalModuleVersionMinor;
version.removeAll(QString());
return version.join(".");
}
/*!
This function accepts the logical module \a info as a string
list. If the logical module info contains the version number,
it splits the version number on the '.' character to get the
major and minor version numbers. Both major and minor version
numbers should be provided, but the minor version number is
not strictly necessary.
*/
void CollectionNode::setLogicalModuleInfo(const QStringList &info)
{
m_logicalModuleName = info[0];
if (info.size() > 1) {
QStringList dotSplit = info[1].split(QLatin1Char('.'));
m_logicalModuleVersionMajor = dotSplit[0];
if (dotSplit.size() > 1)
m_logicalModuleVersionMinor = dotSplit[1];
else
m_logicalModuleVersionMinor = "0";
}
}
/*!
\fn void CollectionNode::setState(const QString &state)
\fn QString CollectionNode::state()
Sets or gets a description of this module's state. For example,
\e {"Technical Preview"}. This string is used when generating the
module's documentation page and reference pages of the module's
members.
*/
QT_END_NAMESPACE
|