- Support template partial specialization
- Avoid infinite recursion in IsStructurallyEquivalent for TemplateArgument with implementing IsStructurallyEquivalent for TemplateName
Details
- Reviewers
- spyffe - khazem 
- Commits
- rG079534760cf3: ASTImporter: fix tests on Windows with removing slashed parts of paths
 rG9931f756c13d: ASTImporter: quick test fix
 rC292781: ASTImporter: fix tests on Windows with removing slashed parts of paths
 rC292779: ASTImporter: quick test fix
 rL292781: ASTImporter: fix tests on Windows with removing slashed parts of paths
 rL292779: ASTImporter: quick test fix
Diff Detail
Event Timeline
Thanks very much for this patch! It certainly fixes the infinite recursion issue on our codebase. It LGTM, but I'd like to add a test case before landing it.
This looks amazing. I have a few minor quibbles and a testing concern, but overall this looks like a great step forward! Thank you!
| lib/AST/ASTImporter.cpp | ||
|---|---|---|
| 458 | Is this really an appropriate default result?  I would argue for false here so that an error would propagate, as is typical in ASTImporter. | |
| 496 | We should probably also check whether DN1->isIdentifier() == DN2->isIdentifier(). | |
| 520 | As above, I'd argue for false here now that we're flipping to the assumption that this code is complete. | |
| 4911 | Could you assign this to a variable here, to avoid the redundant call a line below? | |
| 4931 | This blank line is probably not needed. | |
| 7035 | Is this function properly covered by the test?  I would like to see some deeply-neded name specifiers in the test, with entries for all the cases here. | |
Thank you! I'll update this review again when I have a test for NestedNameSpecifierLocs.
| lib/AST/ASTImporter.cpp | ||
|---|---|---|
| 458 | Good point. Default false will also fail import if a new non-handled property or option will be added in AST and clearly indicate an error so I will change it. | |
Sorry for the late comment, but one of the tests that this introduces is breaking on my end:
/usr/local/google/home/khazem/doc/llvm/tools/clang/test/ASTMerge/class-template-partial-spec.cpp:9:11: error: expected string not found in input
// CHECK: /media/build/smrc-llvm/master/llvm/tools/clang/test/ASTMerge/Inputs/class-template-partial-spec2.cpp:21:32: error: external variable 'X1' declared with incompatible types in different translation units ('TwoOptionTemplate<int, double>' vs. 'TwoOptionTemplate<int, float>')
          ^
<stdin>:1:1: note: scanning from here
/usr/local/google/home/khazem/doc/llvm/tools/clang/test/ASTMerge/Inputs/class-template-partial-spec1.cpp:20:30: error: external variable 'X0' defined in multiple translation units
^
<stdin>:7:15: note: possible intended match here
/usr/local/google/home/khazem/doc/llvm/tools/clang/test/ASTMerge/Inputs/class-template-partial-spec2.cpp:21:32: error: external variable 'X1' declared with incompatible types in different translation units ('TwoOptionTemplate<int, double>' vs. 'TwoOptionTemplate<int, float>')
              ^Is this expected?
Kareem, I have re-checked it and I cannot see the failure. But I'm not going to commit it until NY holidays end (and, anyway, I will not commit it if somebody has failing tests). Could you describe your configuration?
I got it. I have hard-coded paths in CHECK-lines so these tests are passed on my machine but not on other. Thank you Kareem!
Is this really an appropriate default result? I would argue for false here so that an error would propagate, as is typical in ASTImporter.
Note that this does disagree with the original source's true but I think that was because we knew we didn't handle anything, whereas now the assumption is we handle everything.