dexonsmith added a comment.

It seems like using `CachedModuleLoads` wasn't quite right in the first place. 
I wonder if `-fmodule-file=<pcm>` could/should use a different map (maybe one 
that doesn't exist yet), instead of replacing the key in CachedModuleLoads.

In D111543#3054922 <https://reviews.llvm.org/D111543#3054922>, @jansvoboda11 
wrote:

> It'd be great if someone could clarify why the extra `IdentifierInfo` would 
> trip up name resolution.

My guess would be that the attribute parsing does a lookup of "Identifier" and 
finds the entity introduced by `-fmodule-file` instead of the one that's part 
of the declaration. Not sure though.

Are you sure this is only for Objective-C interfaces? Doesn't also happen if 
you name a module after a C++ class or something, and reference it from an 
attribute?

> Suggestions on naming the test file are also welcome.

Doesn't really seem to be about visibility. Maybe 
`module-name-used-by-objc-bridge`?



================
Comment at: clang/include/clang/Lex/ModuleMap.h:101-102
 
   /// The top-level modules that are known.
   llvm::StringMap<Module *> Modules;
 
----------------
I wonder, could `-fmodule-file=...` be using this map instead (already a 
StringMap), and the map below reserved for "real" identifiers?



================
Comment at: clang/include/clang/Lex/ModuleMap.h:104-106
+  /// Module loading cache that includes submodules, indexed by module names.
   /// nullptr is stored for modules that are known to fail to load.
+  llvm::StringMap<Module *> CachedModuleLoads;
----------------
In builds with lots of fine-grained submodules, this will add many tiny 
allocations (one for each map entry). Maybe use 
`StringMap<Module*,BumpPtrAllocator>` to group them together?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D111543

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

Reply via email to