Rename StringMap::emplace_second to try_emplace.

Coincidentally this function maps to the C++17 try_emplace. Rename it
for consistentcy with C++17 std::map. NFC.

llvm-svn: 276276
This commit is contained in:
Benjamin Kramer 2016-07-21 13:37:48 +00:00
parent 6eae9f2c67
commit eab3d36753
5 changed files with 7 additions and 9 deletions

View File

@ -329,9 +329,7 @@ public:
/// Lookup the ValueTy for the \p Key, or create a default constructed value /// Lookup the ValueTy for the \p Key, or create a default constructed value
/// if the key is not in the map. /// if the key is not in the map.
ValueTy &operator[](StringRef Key) { ValueTy &operator[](StringRef Key) { return try_emplace(Key).first->second; }
return emplace_second(Key).first->second;
}
/// count - Return 1 if the element is in the map, 0 otherwise. /// count - Return 1 if the element is in the map, 0 otherwise.
size_type count(StringRef Key) const { size_type count(StringRef Key) const {
@ -362,7 +360,7 @@ public:
/// if and only if the insertion takes place, and the iterator component of /// if and only if the insertion takes place, and the iterator component of
/// the pair points to the element with key equivalent to the key of the pair. /// the pair points to the element with key equivalent to the key of the pair.
std::pair<iterator, bool> insert(std::pair<StringRef, ValueTy> KV) { std::pair<iterator, bool> insert(std::pair<StringRef, ValueTy> KV) {
return emplace_second(KV.first, std::move(KV.second)); return try_emplace(KV.first, std::move(KV.second));
} }
/// Emplace a new element for the specified key into the map if the key isn't /// Emplace a new element for the specified key into the map if the key isn't
@ -370,7 +368,7 @@ public:
/// if and only if the insertion takes place, and the iterator component of /// if and only if the insertion takes place, and the iterator component of
/// the pair points to the element with key equivalent to the key of the pair. /// the pair points to the element with key equivalent to the key of the pair.
template <typename... ArgsTy> template <typename... ArgsTy>
std::pair<iterator, bool> emplace_second(StringRef Key, ArgsTy &&... Args) { std::pair<iterator, bool> try_emplace(StringRef Key, ArgsTy &&... Args) {
unsigned BucketNo = LookupBucketFor(Key); unsigned BucketNo = LookupBucketFor(Key);
StringMapEntryBase *&Bucket = TheTable[BucketNo]; StringMapEntryBase *&Bucket = TheTable[BucketNo];
if (Bucket && Bucket != getTombstoneVal()) if (Bucket && Bucket != getTombstoneVal())

View File

@ -416,7 +416,7 @@ void ValueAsMetadata::handleRAUW(Value *From, Value *To) {
MDString *MDString::get(LLVMContext &Context, StringRef Str) { MDString *MDString::get(LLVMContext &Context, StringRef Str) {
auto &Store = Context.pImpl->MDStringCache; auto &Store = Context.pImpl->MDStringCache;
auto I = Store.emplace_second(Str); auto I = Store.try_emplace(Str);
auto &MapEntry = I.first->getValue(); auto &MapEntry = I.first->getValue();
if (!I.second) if (!I.second)
return &MapEntry; return &MapEntry;

View File

@ -251,7 +251,7 @@ namespace {
class GCOVBlock : public GCOVRecord { class GCOVBlock : public GCOVRecord {
public: public:
GCOVLines &getFile(StringRef Filename) { GCOVLines &getFile(StringRef Filename) {
return LinesByFile.emplace_second(Filename, Filename, os).first->second; return LinesByFile.try_emplace(Filename, Filename, os).first->second;
} }
void addEdge(GCOVBlock &Successor) { void addEdge(GCOVBlock &Successor) {

View File

@ -458,7 +458,7 @@ struct NonMoveableNonCopyableType {
// Test that we can "emplace" an element in the map without involving map/move // Test that we can "emplace" an element in the map without involving map/move
TEST(StringMapCustomTest, EmplaceTest) { TEST(StringMapCustomTest, EmplaceTest) {
StringMap<NonMoveableNonCopyableType> Map; StringMap<NonMoveableNonCopyableType> Map;
Map.emplace_second("abcd", 42); Map.try_emplace("abcd", 42);
EXPECT_EQ(1u, Map.count("abcd")); EXPECT_EQ(1u, Map.count("abcd"));
EXPECT_EQ(42, Map["abcd"].Data); EXPECT_EQ(42, Map["abcd"].Data);
} }

View File

@ -116,7 +116,7 @@ struct CoverageMappingTest : ::testing::Test {
if (R != Files.end()) if (R != Files.end())
return R->second; return R->second;
unsigned Index = Files.size(); unsigned Index = Files.size();
Files.emplace_second(Name, Index); Files.try_emplace(Name, Index);
return Index; return Index;
} }