/**************************************************************************** ** ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of Qt Creator. ** ** 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 ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #include "cpphoverhandler.h" #include "cppeditorconstants.h" #include "cppelementevaluator.h" #include #include #include #include #include using namespace Core; using namespace TextEditor; namespace CppEditor { namespace Internal { CppHoverHandler::CppHoverHandler() {} CppHoverHandler::~CppHoverHandler() {} bool CppHoverHandler::acceptEditor(IEditor *editor) { return editor->document()->id() == CppEditor::Constants::CPPEDITOR_ID; } void CppHoverHandler::identifyMatch(TextEditorWidget *editorWidget, int pos) { if (!editorWidget->extraSelectionTooltip(pos).isEmpty()) { setToolTip(editorWidget->extraSelectionTooltip(pos)); } else { QTextCursor tc(editorWidget->document()); tc.setPosition(pos); CppElementEvaluator evaluator(editorWidget); evaluator.setTextCursor(tc); evaluator.execute(); if (evaluator.hasDiagnosis()) { setToolTip(evaluator.diagnosis()); setIsDiagnosticTooltip(true); } if (evaluator.identifiedCppElement()) { const QSharedPointer &cppElement = evaluator.cppElement(); if (!isDiagnosticTooltip()) setToolTip(cppElement->tooltip); QStringList candidates = cppElement->helpIdCandidates; candidates.removeDuplicates(); foreach (const QString &helpId, candidates) { if (helpId.isEmpty()) continue; const QMap helpLinks = HelpManager::linksForIdentifier(helpId); if (!helpLinks.isEmpty()) { setLastHelpItemIdentified(HelpItem(helpId, cppElement->helpMark, cppElement->helpCategory, helpLinks)); break; } } } } } void CppHoverHandler::decorateToolTip() { if (Qt::mightBeRichText(toolTip())) setToolTip(toolTip().toHtmlEscaped()); if (isDiagnosticTooltip()) return; const HelpItem &help = lastHelpItemIdentified(); if (help.isValid()) { // If Qt is built with a namespace, we still show the tip without it, as // it is in the docs and for consistency with the doc extraction mechanism. const HelpItem::Category category = help.category(); const QString &contents = help.extractContent(false); if (!contents.isEmpty()) { if (category == HelpItem::ClassOrNamespace) setToolTip(help.helpId() + contents); else setToolTip(contents); } else if (category == HelpItem::Typedef || category == HelpItem::Enum || category == HelpItem::ClassOrNamespace) { // This approach is a bit limited since it cannot be used for functions // because the help id doesn't really help in that case. QString prefix; if (category == HelpItem::Typedef) prefix = QLatin1String("typedef "); else if (category == HelpItem::Enum) prefix = QLatin1String("enum "); setToolTip(prefix + help.helpId()); } addF1ToToolTip(); } } } // namespace Internal } // namespace CppEditor