/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://www.qt.io/licensing/ ** ** This file is part of the tools applications of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL21$ ** 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 The Qt Company. For licensing terms ** and conditions see http://www.qt.io/terms-conditions. For further ** information use the contact form at http://www.qt.io/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 or version 3 as published by the Free ** Software Foundation and appearing in the file LICENSE.LGPLv21 and ** LICENSE.LGPLv3 included in the packaging of this file. Please review the ** following information to ensure the GNU Lesser General Public License ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** As a special exception, The Qt Company gives you certain additional ** rights. These rights are described in The Qt Company LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ /* tree.h */ #ifndef TREE_H #define TREE_H #include #include "node.h" QT_BEGIN_NAMESPACE class QStringList; class QDocDatabase; struct TargetRec { public: enum Type { Unknown, Target, Keyword, Contents, Class, Function, Page, Subtitle }; TargetRec(const QString& name, const QString& title, TargetRec::Type type, Node* node, int priority) : node_(node), ref_(name), title_(title), priority_(priority), type_(type) { } bool isEmpty() const { return ref_.isEmpty(); } Node* node_; QString ref_; QString title_; int priority_; Type type_; }; struct TargetLoc { public: TargetLoc(const Node* loc, const QString& t, const QString& fileName, const QString& text, bool broken) : loc_(loc), target_(t), fileName_(fileName), text_(text), broken_(broken) { } const Node* loc_; QString target_; QString fileName_; QString text_; bool broken_; }; typedef QMultiMap TargetMap; typedef QMultiMap DocumentNodeMultiMap; typedef QMap QmlTypeMap; typedef QMultiMap ExampleNodeMap; typedef QVector TargetList; typedef QMap TargetListMap; class Tree { private: friend class QDocForest; friend class QDocDatabase; typedef QMap RoleMap; typedef QMap PropertyMap; Tree(const QString& camelCaseModuleName, QDocDatabase* qdb); ~Tree(); Node* findNodeForInclude(const QStringList& path) const; ClassNode* findClassNode(const QStringList& path, const Node* start = 0) const; NamespaceNode* findNamespaceNode(const QStringList& path) const; FunctionNode* findFunctionNode(const QStringList& parentPath, const FunctionNode* clone); const Node* findFunctionNode(const QString& target, const Node* relative, Node::Genus genus); Node* findNodeRecursive(const QStringList& path, int pathIndex, const Node* start, Node::Type type) const; Node* findNodeRecursive(const QStringList& path, int pathIndex, Node* start, const NodeTypeList& types) const; const Node* findNodeForTarget(const QStringList& path, const QString& target, const Node* node, int flags, Node::Genus genus, QString& ref) const; const Node* matchPathAndTarget(const QStringList& path, int idx, const QString& target, const Node* node, int flags, Node::Genus genus, QString& ref) const; const Node* findNode(const QStringList &path, const Node* relative, // = 0, int findFlags, // = 0, Node::Genus genus) const; // = Node::DontCare) const; QmlTypeNode* findQmlTypeNode(const QStringList& path); Node* findNodeByNameAndType(const QStringList& path, Node::Type type) const; InnerNode* findRelatesNode(const QStringList& path); QString getRef(const QString& target, const Node* node) const; void insertTarget(const QString& name, const QString& title, TargetRec::Type type, Node* node, int priority); void resolveTargets(InnerNode* root); const Node* findUnambiguousTarget(const QString& target, QString& ref) const; const DocumentNode* findDocumentNodeByTitle(const QString& title) const; void addPropertyFunction(PropertyNode *property, const QString &funcName, PropertyNode::FunctionRole funcRole); void resolveInheritance(InnerNode* n = 0); void resolveInheritanceHelper(int pass, ClassNode* cn); void resolveProperties(); void resolveCppToQmlLinks(); void resolveUsingClauses(); void fixInheritance(NamespaceNode *rootNode = 0); NamespaceNode *root() { return &root_; } const FunctionNode *findFunctionNode(const QStringList &path, const Node *relative = 0, int findFlags = 0, Node::Genus genus = Node::DontCare) const; const NamespaceNode *root() const { return &root_; } FunctionNode *findVirtualFunctionInBaseClasses(ClassNode *classe, FunctionNode *clone); NodeList allBaseClasses(const ClassNode *classe) const; QString refForAtom(const Atom* atom); CNMap* getCollectionMap(Node::Genus genus); const CNMap& groups() const { return groups_; } const CNMap& modules() const { return modules_; } const CNMap& qmlModules() const { return qmlModules_; } const CNMap& jsModules() const { return jsModules_; } CollectionNode* getCollection(const QString& name, Node::Genus genus); CollectionNode* findCollection(const QString& name, Node::Genus genus); CollectionNode* findGroup(const QString& name) { return findCollection(name, Node::DOC); } CollectionNode* findModule(const QString& name) { return findCollection(name, Node::CPP); } CollectionNode* findQmlModule(const QString& name) { return findCollection(name, Node::QML); } CollectionNode* findJsModule(const QString& name) { return findCollection(name, Node::JS); } CollectionNode* addGroup(const QString& name) { return findGroup(name); } CollectionNode* addModule(const QString& name) { return findModule(name); } CollectionNode* addQmlModule(const QString& name) { return findQmlModule(name); } CollectionNode* addJsModule(const QString& name) { return findJsModule(name); } CollectionNode* addToGroup(const QString& name, Node* node); CollectionNode* addToModule(const QString& name, Node* node); CollectionNode* addToQmlModule(const QString& name, Node* node); CollectionNode* addToJsModule(const QString& name, Node* node); QmlTypeNode* lookupQmlType(const QString& name) const { return qmlTypeMap_.value(name); } void insertQmlType(const QString& key, QmlTypeNode* n); void addExampleNode(ExampleNode* n) { exampleNodeMap_.insert(n->title(), n); } ExampleNodeMap& exampleNodeMap() { return exampleNodeMap_; } const Node* checkForCollision(const QString& name); void setIndexFileName(const QString& t) { indexFileName_ = t; } bool treeHasBeenAnalyzed() const { return treeHasBeenAnalyzed_; } bool docsHaveBeenGenerated() const { return docsHaveBeenGenerated_; } void setTreeHasBeenAnalyzed() { treeHasBeenAnalyzed_ = true; } void setdocsHaveBeenGenerated() { docsHaveBeenGenerated_ = true; } QString getNewLinkTarget(const Node* locNode, const Node* t, const QString& fileName, QString& text, bool broken); TargetList* getTargetList(const QString& module); QStringList getTargetListKeys() { return targetListMap_->keys(); } public: const QString& camelCaseModuleName() const { return camelCaseModuleName_; } const QString& physicalModuleName() const { return physicalModuleName_; } const QString& indexFileName() const { return indexFileName_; } long incrementLinkCount() { return --linkCount_; } void clearLinkCount() { linkCount_ = 0; } long linkCount() const { return linkCount_; } private: bool treeHasBeenAnalyzed_; bool docsHaveBeenGenerated_; long linkCount_; QString camelCaseModuleName_; QString physicalModuleName_; QString indexFileName_; QDocDatabase* qdb_; NamespaceNode root_; PropertyMap unresolvedPropertyMap; DocumentNodeMultiMap docNodesByTitle_; TargetMap nodesByTargetRef_; TargetMap nodesByTargetTitle_; CNMap groups_; CNMap modules_; CNMap qmlModules_; CNMap jsModules_; QmlTypeMap qmlTypeMap_; ExampleNodeMap exampleNodeMap_; TargetListMap* targetListMap_; }; QT_END_NAMESPACE #endif