diff options
| author | Nick Lewycky <nicholas@mxc.ca> | 2013-01-25 22:11:02 +0000 | 
|---|---|---|
| committer | Nick Lewycky <nicholas@mxc.ca> | 2013-01-25 22:11:02 +0000 | 
| commit | 6bbf4ff9c545c881422da37494b1ccb9c18d9c6a (patch) | |
| tree | f0f97887abc050ded7f894680090de6f08cb49bf | |
| parent | a5597f0eaf1f93c6d0bc641a0cc54ecffb33955a (diff) | |
| download | external_llvm-6bbf4ff9c545c881422da37494b1ccb9c18d9c6a.zip external_llvm-6bbf4ff9c545c881422da37494b1ccb9c18d9c6a.tar.gz external_llvm-6bbf4ff9c545c881422da37494b1ccb9c18d9c6a.tar.bz2 | |
Add an insert() method to MapVector. Adds the first MapVector unit test.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@173505 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | include/llvm/ADT/MapVector.h | 13 | ||||
| -rw-r--r-- | unittests/ADT/MapVectorTest.cpp | 41 | 
2 files changed, 54 insertions, 0 deletions
| diff --git a/include/llvm/ADT/MapVector.h b/include/llvm/ADT/MapVector.h index c34e32a..f29681f 100644 --- a/include/llvm/ADT/MapVector.h +++ b/include/llvm/ADT/MapVector.h @@ -19,6 +19,7 @@  #include "llvm/ADT/ArrayRef.h"  #include "llvm/ADT/DenseMap.h" +#include "llvm/ADT/STLExtras.h"  #include <vector>  namespace llvm { @@ -84,6 +85,18 @@ public:      return Pos == Map.end()? ValueT() : Vector[Pos->second].second;    } +  std::pair<iterator, bool> insert(const std::pair<KeyT, ValueT> &KV) { +    std::pair<KeyT, unsigned> Pair = std::make_pair(KV.first, 0); +    std::pair<typename MapType::iterator, bool> Result = Map.insert(Pair); +    unsigned &I = Result.first->second; +    if (Result.second) { +      Vector.push_back(std::make_pair(KV.first, KV.second)); +      I = Vector.size() - 1; +      return std::make_pair(llvm::prior(end()), true); +    } +    return std::make_pair(begin() + I, false); +  } +    unsigned count(const KeyT &Key) const {      typename MapType::const_iterator Pos = Map.find(Key);      return Pos == Map.end()? 0 : 1; diff --git a/unittests/ADT/MapVectorTest.cpp b/unittests/ADT/MapVectorTest.cpp new file mode 100644 index 0000000..9f61369 --- /dev/null +++ b/unittests/ADT/MapVectorTest.cpp @@ -0,0 +1,41 @@ +//===- unittest/ADT/MapVectorTest.cpp - MapVector unit tests ----*- C++ -*-===// +// +//                     The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "gtest/gtest.h" +#include "llvm/ADT/MapVector.h" +#include <utility> + +using namespace llvm; + +TEST(MapVectorTest, insert) { +  MapVector<int, int> MV; +  std::pair<MapVector<int, int>::iterator, bool> R; + +  R = MV.insert(std::make_pair(1, 2)); +  ASSERT_EQ(R.first, MV.begin()); +  EXPECT_EQ(R.first->first, 1); +  EXPECT_EQ(R.first->second, 2); +  EXPECT_TRUE(R.second); + +  R = MV.insert(std::make_pair(1, 3)); +  ASSERT_EQ(R.first, MV.begin()); +  EXPECT_EQ(R.first->first, 1); +  EXPECT_EQ(R.first->second, 2); +  EXPECT_FALSE(R.second); + +  R = MV.insert(std::make_pair(4, 5)); +  ASSERT_NE(R.first, MV.end()); +  EXPECT_EQ(R.first->first, 4); +  EXPECT_EQ(R.first->second, 5); +  EXPECT_TRUE(R.second); + +  EXPECT_EQ(MV.size(), 2u); +  EXPECT_EQ(MV[1], 2); +  EXPECT_EQ(MV[4], 5); +} | 
