sammccall added a comment.

Trying this on a few files, this seems like it increases preamble sizes up to 
1% or so:

                       | Before    | After
  ---------------------+-----------+----------
  AST.cpp              | 42249648  | 42419732
  XRefsTests.cpp       | 56525116  | 56763768
  SelectionDAGISel.cpp | 37546764  | 37668564
  internal_s.cc        | 59582216  | 60024876
  internal_m.cc        | 192084984 | 193850560
  internal_l.cc        | 365811816 | 368841388

I can't see any reason to think that RAM/CPU usage would be out of proportion 
to this.
A 1% regression here isn't trivial but seems worthwhile for significant 
functional improvements.
I suppose we can add:

- diagnostics (already with this patch)
- inlay hints
- signature help

WDYT about keeping this behind a flag until these are working?
For diagnostics alone, I'm not sure this is a good tradeoff (otherwise why 
would we restrict it to variadics? FWIW allowing all function templates to be 
parsed is +4% to preamble size for internal_l.cc.

I'm less concerned about the effects on the main file, partly because preambles 
are a bigger performance cliff, and partly because we're probably only 
regressing in cases where the user really is seeing benefits too.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D124688

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

Reply via email to