ymandel marked an inline comment as done.
ymandel added inline comments.

================
Comment at: clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp:513
+  const RecordDecl *RD = BaseTy->getDecl();
+  if (RD->getIdentifier() == nullptr || RD->getName() != "Message")
+    return false;
----------------
xazax.hun wrote:
> Not sure how often is this invoked but we could reduce the number of string 
> comparisons by caching the identifier ptr and do a pointer comparison.
Good question. It means an extra comparison for each type until the pointer is 
cached (to check if the cache is set) and then, afterwards, 2 comparisons vs 
~10 for the common case where the class name is doesn't match. In the matching 
case, though, it is clearly saving much more.

For proto-heavy code, it seems a win, and a loss otherwise.  But, the question 
is where to put the cache. It seems to me best to move this to be a method on 
DataflowAnalysisContext (since it is a global, not local env, property) and 
make the cached pointer a private member of DAC.

Thoughts?


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D123032/new/

https://reviews.llvm.org/D123032

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

Reply via email to