2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2010-08-27 12:11:55 +02:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2010-08-27 12:11:55 +02:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** This file is part of Qt Creator.
|
2010-08-27 12:11:55 +02:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** Commercial License Usage
|
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2016-01-15 14:57:40 +01:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2010-08-27 12:11:55 +02:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** GNU General Public License Usage
|
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2010-12-17 16:01:08 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
****************************************************************************/
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2016-03-18 07:55:01 +01:00
|
|
|
#pragma once
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2019-01-24 11:30:58 +01:00
|
|
|
#include "core_global.h"
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2019-01-25 15:48:24 +01:00
|
|
|
#include <utils/optional.h>
|
|
|
|
|
|
2012-02-15 10:42:41 +01:00
|
|
|
#include <QString>
|
2013-05-15 12:46:08 +02:00
|
|
|
#include <QUrl>
|
2019-01-29 11:43:43 +01:00
|
|
|
#include <QVariant>
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2019-02-01 15:52:43 +01:00
|
|
|
#include <vector>
|
|
|
|
|
|
2019-01-24 11:30:58 +01:00
|
|
|
namespace Core {
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2019-01-24 11:30:58 +01:00
|
|
|
class CORE_EXPORT HelpItem
|
2010-08-27 12:11:55 +02:00
|
|
|
{
|
|
|
|
|
public:
|
2019-02-01 15:52:43 +01:00
|
|
|
using Link = std::pair<QString, QUrl>;
|
|
|
|
|
using Links = std::vector<Link>;
|
|
|
|
|
|
2010-08-27 12:11:55 +02:00
|
|
|
enum Category {
|
|
|
|
|
ClassOrNamespace,
|
|
|
|
|
Enum,
|
|
|
|
|
Typedef,
|
|
|
|
|
Macro,
|
|
|
|
|
Brief,
|
|
|
|
|
Function,
|
2010-11-17 14:48:25 +01:00
|
|
|
QmlComponent,
|
|
|
|
|
QmlProperty,
|
2011-11-10 11:55:05 +01:00
|
|
|
QMakeVariableOfFunction,
|
2010-08-27 12:11:55 +02:00
|
|
|
Unknown
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
HelpItem();
|
2019-01-25 15:04:50 +01:00
|
|
|
HelpItem(const char *helpId);
|
|
|
|
|
HelpItem(const QString &helpId);
|
2010-08-27 12:11:55 +02:00
|
|
|
HelpItem(const QString &helpId, const QString &docMark, Category category);
|
2019-01-28 13:00:03 +01:00
|
|
|
HelpItem(const QStringList &helpIds, const QString &docMark, Category category);
|
|
|
|
|
explicit HelpItem(const QUrl &url);
|
2019-01-28 12:46:30 +01:00
|
|
|
HelpItem(const QUrl &url, const QString &docMark, Category category);
|
|
|
|
|
|
|
|
|
|
void setHelpUrl(const QUrl &url);
|
|
|
|
|
const QUrl &helpUrl() const;
|
2010-08-27 12:11:55 +02:00
|
|
|
|
2019-01-28 13:00:03 +01:00
|
|
|
void setHelpIds(const QStringList &ids);
|
|
|
|
|
const QStringList &helpIds() const;
|
2010-08-27 12:11:55 +02:00
|
|
|
|
|
|
|
|
void setDocMark(const QString &mark);
|
|
|
|
|
const QString &docMark() const;
|
|
|
|
|
|
|
|
|
|
void setCategory(Category cat);
|
|
|
|
|
Category category() const;
|
|
|
|
|
|
2019-02-01 12:11:57 +01:00
|
|
|
bool isEmpty() const;
|
2010-08-27 12:11:55 +02:00
|
|
|
bool isValid() const;
|
|
|
|
|
|
|
|
|
|
QString extractContent(bool extended) const;
|
|
|
|
|
|
2019-02-01 15:52:43 +01:00
|
|
|
const Links &links() const;
|
|
|
|
|
const Links bestLinks() const;
|
|
|
|
|
const QString keyword() const;
|
2013-05-15 12:46:08 +02:00
|
|
|
|
2010-08-27 12:11:55 +02:00
|
|
|
private:
|
2019-02-12 13:06:02 +01:00
|
|
|
bool isFuzzyMatch() const;
|
|
|
|
|
|
2019-01-28 12:46:30 +01:00
|
|
|
QUrl m_helpUrl;
|
2019-01-28 13:00:03 +01:00
|
|
|
QStringList m_helpIds;
|
2010-08-27 12:11:55 +02:00
|
|
|
QString m_docMark;
|
2017-07-18 23:15:52 +02:00
|
|
|
Category m_category = Unknown;
|
2019-02-01 15:52:43 +01:00
|
|
|
mutable Utils::optional<Links> m_helpLinks; // cached help links
|
|
|
|
|
mutable QString m_keyword;
|
|
|
|
|
mutable bool m_isFuzzyMatch = false;
|
2010-08-27 12:11:55 +02:00
|
|
|
};
|
|
|
|
|
|
2019-01-24 11:30:58 +01:00
|
|
|
} // namespace Core
|
2019-01-29 11:43:43 +01:00
|
|
|
|
|
|
|
|
Q_DECLARE_METATYPE(Core::HelpItem)
|