xazax.hun added inline comments.

================
Comment at: clang/lib/Analysis/MacroExpansionContext.cpp:22
+    : PP(PP), SM(PP.getSourceManager()), LangOpts(LangOpts) {
+  class MacroExpansionRangeRecorder : public PPCallbacks {
+    const Preprocessor &PP;
----------------
whisperity wrote:
> xazax.hun wrote:
> > steakhal wrote:
> > > xazax.hun wrote:
> > > > It may be more idiomatic to put classes in an anonymous namespace 
> > > > rather than expanding them in a method.
> > > I tried, but I could not hide the `MacroExpansionRangeRecorder` class as 
> > > a detail.
> > > https://godbolt.org/z/bcYK7x
> > > Let me know if there is a better way to hide details.
> > I don't see any problems with the code you linked. What do you mean by 
> > could not hide it better? I think, it is very common to have utility 
> > functions with the current file as the visibility. 
> @steakhal You need to forward declare the class in the detail namespace first 
> **within the header** (so both the namespace and the qualified name 
> `detail::Class` is introduced), and then the `friend class` declaration works 
> as intended, see: https://godbolt.org/z/hs45ze
Oh, I see the problem now. Somehow I did not see the error message. I would 
also not mind not hiding the `using ExpansionRangeMap ...` part,


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D93222

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

Reply via email to