DmitryPolukhin added inline comments.

================
Comment at: clang/lib/Lex/HeaderMap.cpp:265
+  }
+  return ReverseMap.lookup(DestPath);
+}
----------------
bruno wrote:
> How about something along the lines of:
> 
> ```
> ...
> StringRef Key;
> for (unsigned i = 0; i != NumBuckets; ++i) {
>     HMapBucket B = getBucket(i);
>     if (B.Key == HMAP_EmptyBucketKey)
>       continue;
> 
>     Key = getString(B.Key);
>     Optional<StringRef> Prefix = getString(B.Prefix);
>     Optional<StringRef> Suffix = getString(B.Suffix);
>     if (!Key.empty() && Prefix && Suffix) {
>       SmallVector<char, 1024> Buf;
>       Buf.append(Prefix->begin(), Prefix->end());
>       Buf.append(Suffix->begin(), Suffix->end());
>       ReverseMap[StringRef(Buf.begin(), Buf.size())] = Key;
>       break;
>     }
> }
> assert(!Key.empty() && "expected valid key");
> return Key;
> ```
> 
> While proposing this change I've noticed that it would keep looking for other 
> buckets even in face of a valid result, so I've added a `break`. Was that 
> intentional? 
Yes, keep iterating over all key-value pairs in the header map is important to 
add all elements to the map for subsequent lookups. If we stop on the current 
match, next lookup will not even try to populate the reverse lookup map 
(because the map is not empty) but not all elements are in the map due to early 
return from previous lookup, so subsequent lookup may not find the match even 
if it exists in the header map. We also cannot expect that DestPath is present 
in the given header map, so we cannot assert if it is missing. This function 
should return empty string as an indication that DestPath is not found.

Updated implementation with the review suggestion, please take another look.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D103142

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

Reply via email to