ChuanqiXu added a comment.

In D121177#3371695 <https://reviews.llvm.org/D121177#3371695>, @vsapsai wrote:

> Thanks for the review, Chuanqi! I believe you were touching recently 
> `isSameEntity`. Do you have any concerns about using 
> `StructuralEquivalenceContext` instead of `isSameEntity`? I've decided to go 
> with `StructuralEquivalenceContext` because at this point we are still 
> dealing with deserialization and deduplication while 
> `ASTContext::isSameEntity` kinda assumes that all deduplication is already 
> done, at least based on the comment
>
>   // Objective-C classes and protocols with the same name always match.
>   if (isa<ObjCInterfaceDecl>(X) || isa<ObjCProtocolDecl>(X))
>     return true;

Yeah, I was touching `isSameEntity`. But I don't know about 
`StructuralEquivalenceContext`. I just skipped over the implementation of 
`StructuralEquivalenceContext`. I feel like it would be OK if we could assume 
the input is duplicated indeed. 
I see it is guaranteed by `lookupInstanceVariable(Identifier)` now. I don't 
know much about ObjC. But I feel a little bit strange. Is it possible that two 
distinct variable with the same identifier in ObjC? If it is impossible, I 
think it might be OK.



================
Comment at: clang/include/clang/Serialization/ASTReader.h:1110
+  template <typename DeclTy>
+  using DuplicateDecls = std::pair<DeclTy *, DeclTy *>;
+
----------------
vsapsai wrote:
> ChuanqiXu wrote:
> > How about change the name to:
> > ```
> >   template <typename DeclTy>
> >   using DuplicateObjDecls = std::pair<DeclTy *, DeclTy *>;
> > ```
> > 
> > to clarify it is only used for ObjC. So the developer of other languages 
> > would skip this when reading.
> Would `DuplicateObjCDecls` work? `ObjC` part is common enough and I want to 
> avoid just `Obj` because it can imply "Object" which is not the goal. Also we 
> have `getObjCObjectType` which doesn't help with disambiguating the meaning 
> of "Obj".
Yeah, it should be `ObjC`. It's my typo originally.


================
Comment at: clang/include/clang/Serialization/ASTReader.h:1117
+  llvm::MapVector<DuplicateDecls<ObjCCategoryDecl>,
+                  llvm::SmallVector<DuplicateDecls<ObjCIvarDecl>, 4>>
+      PendingExtensionIvarRedeclarations;
----------------
vsapsai wrote:
> ChuanqiXu wrote:
> > It looks a little bit odd for me to use `Vector` for duplicate vars. 
> > Especially, the structure is `Vector<pair<>>`. I feel it is better with 
> > `llvm::SmallSet`. If the order is important here, I think 
> > `llvm::SmallSetVector` might be an option.
> I'm not sure the use of `llvm::SmallSet` is warranted here. We deserialize 
> each ObjCIvarDecl from each module (and corresponding DeclContext) only once, 
> so we don't have to ensure there are no repeated pairs of same ObjCIvarDecl. 
> And for stable diagnostic we need to use some kind of ordered container. Also 
> a bunch of other "Pending..." fields don't use sets as uniqueness is enforced 
> in different ways.
Oh, I got it. `llvm::SmallVector` might not be wrong in this case. And for the 
mapping relationship, `llvm::SmallMapVector` is considerable too.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D121177

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

Reply via email to