Hahnfeld added a comment.

Right, it's not ideal to land APIs without usage in Clang itself... The context 
is, once again, ROOT and the Cling interpreter (where we are already using this 
API via downstream patches): When unloading a "transaction" (now 
`PartialTranslationUnit` in `clang-repl`) we need to "unload" all contained 
declarations, ie make the code generator forget that it had already emitted 
them. For templates, this is a bit tricky so we need to iterate specializations 
without triggering more deserialization. This will get important with D41416 
<https://reviews.llvm.org/D41416> where we only load needed specializations.

When playing a bit earlier this week, I learned that the problem related to 
"unloading" of template specializations can be observed upstream in 
`clang-repl`:

  clang-repl> template <typename T> void f() {}
  clang-repl> f<int>();
  clang-repl> %undo
  clang-repl> template <> void f<int>() {}
  In file included from <<< inputs >>>:1:
  input_line_3:1:18: error: explicit specialization of 'f<int>' after 
instantiation
      1 | template <> void f<int>() {}
        |                  ^
  input_line_2:1:1: note: implicit instantiation first required here
      1 | f<int>();
        | ^
  error: Parsing failed.

Let me see if I can come up a fix for that in `clang-repl` that would then need 
this API. But for now, it's also fine for us if the patch stays pending in 
review, still better than completely disconnected local commits...


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D154328

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

Reply via email to