File: parserdependencypolicy.cpp

package info (click to toggle)
kdevplatform 1.3.1-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 19,868 kB
  • sloc: cpp: 128,247; sh: 697; python: 365; php: 83; makefile: 4
file content (64 lines) | stat: -rw-r--r-- 1,803 bytes parent folder | download | duplicates (3)
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
/*
* This file is part of KDevelop
*
* Copyright 2006 Hamish Rodda <rodda@kde.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Library General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program; if not, write to the
* Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/

#include "parserdependencypolicy.h"

#include <QSet>

#include "parsejob.h"

using namespace ThreadWeaver;

namespace KDevelop
{

bool ParserDependencyPolicy::addDependency(ParseJob* dependency, ParseJob* primaryDependee, ThreadWeaver::Job* actualDependee)
{
  QSet<ParseJob*> encountered;

  gatherDependencies(dependency, encountered);

  if (encountered.contains(primaryDependee))
    return false;

  m_dependencies.insert(dependency, primaryDependee);

  DependencyPolicy::addDependency(dependency, actualDependee ? actualDependee : static_cast<Job*>(primaryDependee));

  return true;
}

void ParserDependencyPolicy::destructed(ThreadWeaver::Job *job)
{
  DependencyPolicy::destructed(job);

  m_dependencies.remove(static_cast<ParseJob*>(job));
}

void ParserDependencyPolicy::gatherDependencies(ParseJob* job, QSet<ParseJob*>& encountered) const
{
  encountered.insert(job);

  foreach (ParseJob* dependency, m_dependencies.values(job))
    gatherDependencies(dependency, encountered);
}

}