IndexedMap: Document why SmallVector<T, 0> is preferable here.
authorBenjamin Kramer <benny.kra@googlemail.com>
Mon, 2 Mar 2015 22:20:22 +0000 (22:20 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Mon, 2 Mar 2015 22:20:22 +0000 (22:20 +0000)
llvm-svn: 231028

llvm/include/llvm/ADT/IndexedMap.h

index a830a41..5ba85c0 100644 (file)
@@ -30,6 +30,9 @@ namespace llvm {
 template <typename T, typename ToIndexT = llvm::identity<unsigned> >
   class IndexedMap {
     typedef typename ToIndexT::argument_type IndexT;
+    // Prefer SmallVector with zero inline storage over std::vector. IndexedMaps
+    // can grow very large and SmallVector grows more efficiently as long as T
+    // is trivially copyable.
     typedef SmallVector<T, 0> StorageT;
     StorageT storage_;
     T nullVal_;