forked from qt-creator/qt-creator
Qmake: Make finding pro-files fast, second attempt
Finding the right pro-file was surprisingly slow. Make that fast again by storing a pointer in QmakePriFileNode back to the QmakePriFile that created it. This is save since the Nodes in the ProjectTree get nuked whenever the tree of QmakePriFiles changes. Task-number: QTCREATORBUG-19131 Change-Id: I4b5a8887cb13c36273a553f935a00d87cee4a7b6 Reviewed-by: Eike Ziller <eike.ziller@qt.io> Reviewed-by: Christian Stenger <christian.stenger@qt.io>
This commit is contained in:
@@ -44,20 +44,21 @@ namespace QmakeProjectManager {
|
||||
*/
|
||||
|
||||
QmakePriFileNode::QmakePriFileNode(QmakeProject *project, QmakeProFileNode *qmakeProFileNode,
|
||||
const FileName &filePath) :
|
||||
const FileName &filePath, QmakePriFile *pf) :
|
||||
ProjectNode(filePath),
|
||||
m_project(project),
|
||||
m_qmakeProFileNode(qmakeProFileNode)
|
||||
m_qmakeProFileNode(qmakeProFileNode),
|
||||
m_qmakePriFile(pf)
|
||||
{ }
|
||||
|
||||
QmakePriFile *QmakePriFileNode::priFile() const
|
||||
{
|
||||
return m_project->rootProFile()->findPriFile(filePath());
|
||||
return m_qmakePriFile;
|
||||
}
|
||||
|
||||
bool QmakePriFileNode::deploysFolder(const QString &folder) const
|
||||
{
|
||||
QmakePriFile *pri = priFile();
|
||||
const QmakePriFile *pri = priFile();
|
||||
return pri ? pri->deploysFolder(folder) : false;
|
||||
}
|
||||
|
||||
@@ -145,7 +146,7 @@ bool QmakePriFileNode::supportsAction(ProjectAction action, const Node *node) co
|
||||
|
||||
bool QmakePriFileNode::canAddSubProject(const QString &proFilePath) const
|
||||
{
|
||||
QmakePriFile *pri = priFile();
|
||||
const QmakePriFile *pri = priFile();
|
||||
return pri ? pri->canAddSubProject(proFilePath) : false;
|
||||
}
|
||||
|
||||
@@ -213,8 +214,8 @@ QmakeProFileNode *QmakeProFileNode::findProFileFor(const FileName &fileName) con
|
||||
\class QmakeProFileNode
|
||||
Implements abstract ProjectNode class
|
||||
*/
|
||||
QmakeProFileNode::QmakeProFileNode(QmakeProject *project, const FileName &filePath) :
|
||||
QmakePriFileNode(project, this, filePath)
|
||||
QmakeProFileNode::QmakeProFileNode(QmakeProject *project, const FileName &filePath, QmakeProFile *pf) :
|
||||
QmakePriFileNode(project, this, filePath, pf)
|
||||
{ }
|
||||
|
||||
bool QmakeProFileNode::showInSimpleTree() const
|
||||
@@ -224,7 +225,7 @@ bool QmakeProFileNode::showInSimpleTree() const
|
||||
|
||||
QmakeProFile *QmakeProFileNode::proFile() const
|
||||
{
|
||||
return m_project->rootProFile()->findProFile(filePath());
|
||||
return static_cast<QmakeProFile*>(QmakePriFileNode::priFile());
|
||||
}
|
||||
|
||||
FolderNode::AddNewInformation QmakeProFileNode::addNewInformation(const QStringList &files, Node *context) const
|
||||
|
||||
@@ -42,7 +42,7 @@ class QMAKEPROJECTMANAGER_EXPORT QmakePriFileNode : public ProjectExplorer::Proj
|
||||
{
|
||||
public:
|
||||
QmakePriFileNode(QmakeProject *project, QmakeProFileNode *qmakeProFileNode,
|
||||
const Utils::FileName &filePath);
|
||||
const Utils::FileName &filePath, QmakePriFile *pf);
|
||||
|
||||
QmakePriFile *priFile() const;
|
||||
|
||||
@@ -73,13 +73,14 @@ protected:
|
||||
|
||||
private:
|
||||
QmakeProFileNode *m_qmakeProFileNode = nullptr;
|
||||
QmakePriFile *m_qmakePriFile = nullptr;
|
||||
};
|
||||
|
||||
// Implements ProjectNode for qmake .pro files
|
||||
class QMAKEPROJECTMANAGER_EXPORT QmakeProFileNode : public QmakePriFileNode
|
||||
{
|
||||
public:
|
||||
QmakeProFileNode(QmakeProject *project, const Utils::FileName &filePath);
|
||||
QmakeProFileNode(QmakeProject *project, const Utils::FileName &filePath, QmakeProFile *pf);
|
||||
|
||||
QmakeProFile *proFile() const;
|
||||
|
||||
|
||||
@@ -183,12 +183,12 @@ static void createTree(const QmakePriFile *pri, QmakePriFileNode *node, const Fi
|
||||
}
|
||||
|
||||
// Virtual folders:
|
||||
for (const QmakePriFile *c : pri->children()) {
|
||||
for (QmakePriFile *c : pri->children()) {
|
||||
QmakePriFileNode *newNode = nullptr;
|
||||
if (dynamic_cast<const QmakeProFile *>(c))
|
||||
newNode = new QmakeProFileNode(c->project(), c->filePath());
|
||||
if (auto pf = dynamic_cast<QmakeProFile *>(c))
|
||||
newNode = new QmakeProFileNode(c->project(), c->filePath(), pf);
|
||||
else
|
||||
newNode = new QmakePriFileNode(c->project(), node->proFileNode(), c->filePath());
|
||||
newNode = new QmakePriFileNode(c->project(), node->proFileNode(), c->filePath(), c);
|
||||
createTree(c, newNode, toExclude);
|
||||
node->addNode(newNode);
|
||||
}
|
||||
@@ -203,7 +203,7 @@ QmakeProFileNode *QmakeNodeTreeBuilder::buildTree(QmakeProject *project)
|
||||
|
||||
const FileNameList toExclude = qt ? qt->directoriesToIgnoreInProjectTree() : FileNameList();
|
||||
|
||||
auto root = new QmakeProFileNode(project, project->projectFilePath());
|
||||
auto root = new QmakeProFileNode(project, project->projectFilePath(), project->rootProFile());
|
||||
createTree(project->rootProFile(), root, toExclude);
|
||||
|
||||
return root;
|
||||
|
||||
Reference in New Issue
Block a user