Use an IdentifierTable for names used for Entities.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@77537 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Index/Entity.cpp b/lib/Index/Entity.cpp
index d331100..8c7c8d0 100644
--- a/lib/Index/Entity.cpp
+++ b/lib/Index/Entity.cpp
@@ -70,9 +70,8 @@
if (!II)
return Entity();
- EntityImpl::IdEntryTy *Id =
- &Prog.getIdents().GetOrCreateValue(II->getName(),
- II->getName() + II->getLength());
+ IdentifierInfo *Id = &Prog.getIdents().get(II->getName(),
+ II->getName() + II->getLength());
unsigned IdNS = D->getIdentifierNamespace();
llvm::FoldingSetNodeID ID;
@@ -117,7 +116,8 @@
if (!DC)
return 0; // Couldn't get the parent context.
- IdentifierInfo &II = AST.Idents.get(Id->getKeyData());
+ IdentifierInfo &II = AST.Idents.get(Id->getName(),
+ Id->getName() + Id->getLength());
DeclContext::lookup_result Res = DC->lookup(DeclarationName(&II));
for (DeclContext::lookup_iterator I = Res.first, E = Res.second; I!=E; ++I) {
@@ -136,7 +136,7 @@
}
std::string EntityImpl::getPrintableName() {
- return std::string(Id->getKeyData(), Id->getKeyData() + Id->getKeyLength());
+ return Id->getName();
}
//===----------------------------------------------------------------------===//