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:
Nikolai Kosjar
2017-05-03 12:42:55 +02:00
parent d4ac34449b
commit b091b20685
2 changed files with 46 additions and 46 deletions

View File

@@ -35,59 +35,59 @@
#include <QLoggingCategory>
#include <QUuid>
#include <algorithm>
Q_LOGGING_CATEGORY(tuLog, "qtc.clangbackend.translationunits");
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)
: m_filePath(filePath)
{
}
TranslationUnits::~TranslationUnits()
{
foreach (const TranslationUnitData &unit, m_tuDatas) {
clang_disposeTranslationUnit(unit.cxTranslationUnit);
clang_disposeIndex(unit.cxIndex);
}
}
TranslationUnit TranslationUnits::createAndAppend()
{
const Utf8String id = Utf8String::fromByteArray(QUuid::createUuid().toByteArray());
qCDebug(tuLog) << "Creating TranslationUnit" << id << "for" << QFileInfo(m_filePath).fileName();
m_tuDatas.append(TranslationUnitData(id));
TranslationUnitData &translationUnitData = m_tuDatas.last();
m_units.append(TranslationUnitDataPtr(new TranslationUnitData(id)));
return toTranslationUnit(translationUnitData);
return toTranslationUnit(m_units.last());
}
TranslationUnit TranslationUnits::get(PreferredTranslationUnit type)
{
if (m_tuDatas.isEmpty())
if (m_units.isEmpty())
throw TranslationUnitDoesNotExist(m_filePath);
if (m_tuDatas.size() == 1)
return toTranslationUnit(m_tuDatas.first());
if (m_units.size() == 1)
return toTranslationUnit(m_units.first());
if (areAllTranslationUnitsParsed())
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,
TimePoint timePoint)
{
TranslationUnitData &unit = findUnit(translationUnitId);
QTC_CHECK(timePoint != TimePoint());
unit.parseTimePoint = timePoint;
findUnit(translationUnitId).parseTimePoint = timePoint;
qCDebug(tuLog) << "Updated" << translationUnitId << "for" << QFileInfo(m_filePath).fileName()
<< "RecentlyParsed:" << get(PreferredTranslationUnit::RecentlyParsed).id()
@@ -101,50 +101,50 @@ TimePoint TranslationUnits::parseTimePoint(const Utf8String &translationUnitId)
bool TranslationUnits::areAllTranslationUnitsParsed() const
{
return Utils::allOf(m_tuDatas, [](const TranslationUnitData &unit) {
return unit.parseTimePoint != TimePoint();
return Utils::allOf(m_units, [](const TranslationUnitDataPtr &unit) {
return unit->parseTimePoint != TimePoint();
});
}
int TranslationUnits::size() const
{
return m_tuDatas.size();
return m_units.size();
}
TranslationUnit TranslationUnits::getPreferredTranslationUnit(PreferredTranslationUnit type)
{
using TuData = TranslationUnitData;
using TuDataPtr = TranslationUnitDataPtr;
const auto lessThan = [](const TuData &a, const TuData &b) {
return a.parseTimePoint < b.parseTimePoint;
const auto lessThan = [](const TuDataPtr &a, const TuDataPtr &b) {
return a->parseTimePoint < b->parseTimePoint;
};
auto translationUnitData = type == PreferredTranslationUnit::RecentlyParsed
? std::max_element(m_tuDatas.begin(), m_tuDatas.end(), lessThan)
: std::min_element(m_tuDatas.begin(), m_tuDatas.end(), lessThan);
auto it = type == PreferredTranslationUnit::RecentlyParsed
? std::max_element(m_units.begin(), m_units.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);
return toTranslationUnit(*translationUnitData);
return toTranslationUnit(*it);
}
TranslationUnits::TranslationUnitData &TranslationUnits::findUnit(
const Utf8String &translationUnitId)
{
for (TranslationUnitData &unit : m_tuDatas) {
if (translationUnitId == unit.id)
return unit;
for (TranslationUnitDataPtr &unit : m_units) {
if (translationUnitId == unit->id)
return *unit;
}
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,
unit.cxIndex,
unit.cxTranslationUnit);
unit->cxIndex,
unit->cxTranslationUnit);
}
} // namespace ClangBackEnd

View File

@@ -33,6 +33,7 @@
#include <clang-c/Index.h>
#include <QList>
#include <QSharedPointer>
namespace ClangBackEnd {
@@ -43,9 +44,8 @@ class TranslationUnits
public:
class TranslationUnitData {
public:
TranslationUnitData(const Utf8String &id)
: id(id)
{}
TranslationUnitData(const Utf8String &id);
~TranslationUnitData();
Utf8String id;
@@ -54,10 +54,10 @@ public:
TimePoint parseTimePoint;
};
using TranslationUnitDataPtr = QSharedPointer<TranslationUnitData>;
public:
TranslationUnits(const Utf8String &filePath);
~TranslationUnits();
TranslationUnit createAndAppend();
TranslationUnit get(PreferredTranslationUnit type = PreferredTranslationUnit::RecentlyParsed);
@@ -72,11 +72,11 @@ public: // for tests
private:
TranslationUnit getPreferredTranslationUnit(PreferredTranslationUnit type);
TranslationUnitData &findUnit(const Utf8String &translationUnitId);
TranslationUnit toTranslationUnit(TranslationUnitData &unit);
TranslationUnit toTranslationUnit(const TranslationUnitDataPtr &unit);
private:
Utf8String m_filePath;
QList<TranslationUnitData> m_tuDatas;
QList<TranslationUnitDataPtr> m_units;
};
} // namespace ClangBackEnd