Prazek added inline comments.

================
Comment at: clang-tidy/modernize/UseEmplaceCheck.cpp:45
@@ -33,3 +44,3 @@
       hasDeclaration(functionDecl(hasName("push_back"))),
-      on(hasType(cxxRecordDecl(hasAnyName("std::vector", "llvm::SmallVector",
-                                          "std::list", "std::deque")))));
+      on(hasType(cxxRecordDecl(hasAnyName(SmallVector<StringRef, 5>(
+          ContainersWithPushBack.begin(), ContainersWithPushBack.end()))))));
----------------
alexfh wrote:
> What's the reason for explicitly creating a `SmallVector`? 
> `VariadicFunction::operator()` takes an `ArrayRef`, which `std::vector<>` 
> should be implicitly convertible to. Am I missing something?
It is not. I guess it is because it is ArrayRef<StringRef> and I have 
std::vector<std::string>

================
Comment at: docs/clang-tidy/checks/modernize-use-emplace.rst:12
@@ +11,3 @@
+uses it. It also doesn't support ``insert`` functions for associative 
containers
+because chaning ``insert`` to ``emplace`` may result in
+`speed regression 
<http://htmlpreview.github.io/?https://github.com/HowardHinnant/papers/blob/master/insert_vs_emplace.html>`_.
----------------
alexfh wrote:
> alexfh wrote:
> > s/chaning/changing/
> How about the `insert` method of `std::vector<>`?
insert -> emplace should be fine for the vector, but this patch is trying to 
mainly fix the bugs (and I want it to land in clang-3.9).

I will add ``insert`` near the ``push_front``


Repository:
  rL LLVM

https://reviews.llvm.org/D22208



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to