aboutsummaryrefslogtreecommitdiff
path: root/lib/Serialization/ASTWriter.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Serialization/ASTWriter.cpp')
-rw-r--r--lib/Serialization/ASTWriter.cpp27
1 files changed, 10 insertions, 17 deletions
diff --git a/lib/Serialization/ASTWriter.cpp b/lib/Serialization/ASTWriter.cpp
index 16c6f4b101..5a376a9f12 100644
--- a/lib/Serialization/ASTWriter.cpp
+++ b/lib/Serialization/ASTWriter.cpp
@@ -2579,21 +2579,18 @@ void ASTWriter::AddTypeSourceInfo(TypeSourceInfo *TInfo, RecordData &Record) {
}
void ASTWriter::AddTypeRef(QualType T, RecordData &Record) {
- if (T.isNull()) {
- Record.push_back(PREDEF_TYPE_NULL_ID);
- return;
- }
+ Record.push_back(GetOrCreateTypeID(T));
+}
+
+TypeID ASTWriter::GetOrCreateTypeID(QualType T) {
+ if (T.isNull())
+ return PREDEF_TYPE_NULL_ID;
unsigned FastQuals = T.getLocalFastQualifiers();
T.removeFastQualifiers();
- if (T.hasLocalNonFastQualifiers()) {
- TypeIdx Idx = GetOrCreateTypeIdx(T);
-
- // Encode the type qualifiers in the type reference.
- Record.push_back(Idx.asTypeID(FastQuals));
- return;
- }
+ if (T.hasLocalNonFastQualifiers())
+ return GetOrCreateTypeIdx(T).asTypeID(FastQuals);
assert(!T.hasLocalQualifiers());
@@ -2633,14 +2630,10 @@ void ASTWriter::AddTypeRef(QualType T, RecordData &Record) {
break;
}
- Record.push_back(TypeIdx(ID).asTypeID(FastQuals));
- return;
+ return TypeIdx(ID).asTypeID(FastQuals);
}
- TypeIdx Idx = GetOrCreateTypeIdx(T);
-
- // Encode the type qualifiers in the type reference.
- Record.push_back(Idx.asTypeID(FastQuals));
+ return GetOrCreateTypeIdx(T).asTypeID(FastQuals);
}
TypeIdx ASTWriter::GetOrCreateTypeIdx(QualType T) {