forked from qt-creator/qt-creator
Clang: Clean up TranslationUnits
* Use shared pointer to simplify ownership, also for a follow-up change. * Remove pointless else-if * Rename some variables Change-Id: I6a9c5760c3812e071e9199228502c87b6944926a Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
@@ -35,59 +35,59 @@
|
|||||||
#include <QLoggingCategory>
|
#include <QLoggingCategory>
|
||||||
#include <QUuid>
|
#include <QUuid>
|
||||||
|
|
||||||
#include <algorithm>
|
|
||||||
|
|
||||||
Q_LOGGING_CATEGORY(tuLog, "qtc.clangbackend.translationunits");
|
Q_LOGGING_CATEGORY(tuLog, "qtc.clangbackend.translationunits");
|
||||||
|
|
||||||
namespace ClangBackEnd {
|
namespace ClangBackEnd {
|
||||||
|
|
||||||
|
TranslationUnits::TranslationUnitData::TranslationUnitData(const Utf8String &id)
|
||||||
|
: id(id)
|
||||||
|
{}
|
||||||
|
|
||||||
|
TranslationUnits::TranslationUnitData::~TranslationUnitData()
|
||||||
|
{
|
||||||
|
qCDebug(tuLog) << "Destroying TranslationUnit" << id;
|
||||||
|
clang_disposeTranslationUnit(cxTranslationUnit);
|
||||||
|
clang_disposeIndex(cxIndex);
|
||||||
|
}
|
||||||
|
|
||||||
TranslationUnits::TranslationUnits(const Utf8String &filePath)
|
TranslationUnits::TranslationUnits(const Utf8String &filePath)
|
||||||
: m_filePath(filePath)
|
: m_filePath(filePath)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
TranslationUnits::~TranslationUnits()
|
|
||||||
{
|
|
||||||
foreach (const TranslationUnitData &unit, m_tuDatas) {
|
|
||||||
clang_disposeTranslationUnit(unit.cxTranslationUnit);
|
|
||||||
clang_disposeIndex(unit.cxIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TranslationUnit TranslationUnits::createAndAppend()
|
TranslationUnit TranslationUnits::createAndAppend()
|
||||||
{
|
{
|
||||||
const Utf8String id = Utf8String::fromByteArray(QUuid::createUuid().toByteArray());
|
const Utf8String id = Utf8String::fromByteArray(QUuid::createUuid().toByteArray());
|
||||||
qCDebug(tuLog) << "Creating TranslationUnit" << id << "for" << QFileInfo(m_filePath).fileName();
|
qCDebug(tuLog) << "Creating TranslationUnit" << id << "for" << QFileInfo(m_filePath).fileName();
|
||||||
|
|
||||||
m_tuDatas.append(TranslationUnitData(id));
|
m_units.append(TranslationUnitDataPtr(new TranslationUnitData(id)));
|
||||||
TranslationUnitData &translationUnitData = m_tuDatas.last();
|
|
||||||
|
|
||||||
return toTranslationUnit(translationUnitData);
|
return toTranslationUnit(m_units.last());
|
||||||
}
|
}
|
||||||
|
|
||||||
TranslationUnit TranslationUnits::get(PreferredTranslationUnit type)
|
TranslationUnit TranslationUnits::get(PreferredTranslationUnit type)
|
||||||
{
|
{
|
||||||
if (m_tuDatas.isEmpty())
|
if (m_units.isEmpty())
|
||||||
throw TranslationUnitDoesNotExist(m_filePath);
|
throw TranslationUnitDoesNotExist(m_filePath);
|
||||||
|
|
||||||
if (m_tuDatas.size() == 1)
|
if (m_units.size() == 1)
|
||||||
return toTranslationUnit(m_tuDatas.first());
|
return toTranslationUnit(m_units.first());
|
||||||
|
|
||||||
if (areAllTranslationUnitsParsed())
|
if (areAllTranslationUnitsParsed())
|
||||||
return getPreferredTranslationUnit(type);
|
return getPreferredTranslationUnit(type);
|
||||||
else if (type == PreferredTranslationUnit::LastUninitialized)
|
|
||||||
return toTranslationUnit(m_tuDatas.last());
|
|
||||||
|
|
||||||
return toTranslationUnit(m_tuDatas.first());
|
if (type == PreferredTranslationUnit::LastUninitialized)
|
||||||
|
return toTranslationUnit(m_units.last());
|
||||||
|
|
||||||
|
return toTranslationUnit(m_units.first());
|
||||||
}
|
}
|
||||||
|
|
||||||
void TranslationUnits::updateParseTimePoint(const Utf8String &translationUnitId,
|
void TranslationUnits::updateParseTimePoint(const Utf8String &translationUnitId,
|
||||||
TimePoint timePoint)
|
TimePoint timePoint)
|
||||||
{
|
{
|
||||||
TranslationUnitData &unit = findUnit(translationUnitId);
|
|
||||||
|
|
||||||
QTC_CHECK(timePoint != TimePoint());
|
QTC_CHECK(timePoint != TimePoint());
|
||||||
unit.parseTimePoint = timePoint;
|
|
||||||
|
findUnit(translationUnitId).parseTimePoint = timePoint;
|
||||||
|
|
||||||
qCDebug(tuLog) << "Updated" << translationUnitId << "for" << QFileInfo(m_filePath).fileName()
|
qCDebug(tuLog) << "Updated" << translationUnitId << "for" << QFileInfo(m_filePath).fileName()
|
||||||
<< "RecentlyParsed:" << get(PreferredTranslationUnit::RecentlyParsed).id()
|
<< "RecentlyParsed:" << get(PreferredTranslationUnit::RecentlyParsed).id()
|
||||||
@@ -101,50 +101,50 @@ TimePoint TranslationUnits::parseTimePoint(const Utf8String &translationUnitId)
|
|||||||
|
|
||||||
bool TranslationUnits::areAllTranslationUnitsParsed() const
|
bool TranslationUnits::areAllTranslationUnitsParsed() const
|
||||||
{
|
{
|
||||||
return Utils::allOf(m_tuDatas, [](const TranslationUnitData &unit) {
|
return Utils::allOf(m_units, [](const TranslationUnitDataPtr &unit) {
|
||||||
return unit.parseTimePoint != TimePoint();
|
return unit->parseTimePoint != TimePoint();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
int TranslationUnits::size() const
|
int TranslationUnits::size() const
|
||||||
{
|
{
|
||||||
return m_tuDatas.size();
|
return m_units.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
TranslationUnit TranslationUnits::getPreferredTranslationUnit(PreferredTranslationUnit type)
|
TranslationUnit TranslationUnits::getPreferredTranslationUnit(PreferredTranslationUnit type)
|
||||||
{
|
{
|
||||||
using TuData = TranslationUnitData;
|
using TuDataPtr = TranslationUnitDataPtr;
|
||||||
|
|
||||||
const auto lessThan = [](const TuData &a, const TuData &b) {
|
const auto lessThan = [](const TuDataPtr &a, const TuDataPtr &b) {
|
||||||
return a.parseTimePoint < b.parseTimePoint;
|
return a->parseTimePoint < b->parseTimePoint;
|
||||||
};
|
};
|
||||||
auto translationUnitData = type == PreferredTranslationUnit::RecentlyParsed
|
auto it = type == PreferredTranslationUnit::RecentlyParsed
|
||||||
? std::max_element(m_tuDatas.begin(), m_tuDatas.end(), lessThan)
|
? std::max_element(m_units.begin(), m_units.end(), lessThan)
|
||||||
: std::min_element(m_tuDatas.begin(), m_tuDatas.end(), lessThan);
|
: std::min_element(m_units.begin(), m_units.end(), lessThan);
|
||||||
|
|
||||||
if (translationUnitData == m_tuDatas.end())
|
if (it == m_units.end())
|
||||||
throw TranslationUnitDoesNotExist(m_filePath);
|
throw TranslationUnitDoesNotExist(m_filePath);
|
||||||
|
|
||||||
return toTranslationUnit(*translationUnitData);
|
return toTranslationUnit(*it);
|
||||||
}
|
}
|
||||||
|
|
||||||
TranslationUnits::TranslationUnitData &TranslationUnits::findUnit(
|
TranslationUnits::TranslationUnitData &TranslationUnits::findUnit(
|
||||||
const Utf8String &translationUnitId)
|
const Utf8String &translationUnitId)
|
||||||
{
|
{
|
||||||
for (TranslationUnitData &unit : m_tuDatas) {
|
for (TranslationUnitDataPtr &unit : m_units) {
|
||||||
if (translationUnitId == unit.id)
|
if (translationUnitId == unit->id)
|
||||||
return unit;
|
return *unit;
|
||||||
}
|
}
|
||||||
|
|
||||||
throw TranslationUnitDoesNotExist(m_filePath);
|
throw TranslationUnitDoesNotExist(m_filePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
TranslationUnit TranslationUnits::toTranslationUnit(TranslationUnits::TranslationUnitData &unit)
|
TranslationUnit TranslationUnits::toTranslationUnit(const TranslationUnitDataPtr &unit)
|
||||||
{
|
{
|
||||||
return TranslationUnit(unit.id,
|
return TranslationUnit(unit->id,
|
||||||
m_filePath,
|
m_filePath,
|
||||||
unit.cxIndex,
|
unit->cxIndex,
|
||||||
unit.cxTranslationUnit);
|
unit->cxTranslationUnit);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace ClangBackEnd
|
} // namespace ClangBackEnd
|
||||||
|
|||||||
@@ -33,6 +33,7 @@
|
|||||||
#include <clang-c/Index.h>
|
#include <clang-c/Index.h>
|
||||||
|
|
||||||
#include <QList>
|
#include <QList>
|
||||||
|
#include <QSharedPointer>
|
||||||
|
|
||||||
namespace ClangBackEnd {
|
namespace ClangBackEnd {
|
||||||
|
|
||||||
@@ -43,9 +44,8 @@ class TranslationUnits
|
|||||||
public:
|
public:
|
||||||
class TranslationUnitData {
|
class TranslationUnitData {
|
||||||
public:
|
public:
|
||||||
TranslationUnitData(const Utf8String &id)
|
TranslationUnitData(const Utf8String &id);
|
||||||
: id(id)
|
~TranslationUnitData();
|
||||||
{}
|
|
||||||
|
|
||||||
Utf8String id;
|
Utf8String id;
|
||||||
|
|
||||||
@@ -54,10 +54,10 @@ public:
|
|||||||
|
|
||||||
TimePoint parseTimePoint;
|
TimePoint parseTimePoint;
|
||||||
};
|
};
|
||||||
|
using TranslationUnitDataPtr = QSharedPointer<TranslationUnitData>;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
TranslationUnits(const Utf8String &filePath);
|
TranslationUnits(const Utf8String &filePath);
|
||||||
~TranslationUnits();
|
|
||||||
|
|
||||||
TranslationUnit createAndAppend();
|
TranslationUnit createAndAppend();
|
||||||
TranslationUnit get(PreferredTranslationUnit type = PreferredTranslationUnit::RecentlyParsed);
|
TranslationUnit get(PreferredTranslationUnit type = PreferredTranslationUnit::RecentlyParsed);
|
||||||
@@ -72,11 +72,11 @@ public: // for tests
|
|||||||
private:
|
private:
|
||||||
TranslationUnit getPreferredTranslationUnit(PreferredTranslationUnit type);
|
TranslationUnit getPreferredTranslationUnit(PreferredTranslationUnit type);
|
||||||
TranslationUnitData &findUnit(const Utf8String &translationUnitId);
|
TranslationUnitData &findUnit(const Utf8String &translationUnitId);
|
||||||
TranslationUnit toTranslationUnit(TranslationUnitData &unit);
|
TranslationUnit toTranslationUnit(const TranslationUnitDataPtr &unit);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Utf8String m_filePath;
|
Utf8String m_filePath;
|
||||||
QList<TranslationUnitData> m_tuDatas;
|
QList<TranslationUnitDataPtr> m_units;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace ClangBackEnd
|
} // namespace ClangBackEnd
|
||||||
|
|||||||
Reference in New Issue
Block a user