The default expression of a parameter variable should be imported before
the parameter variable object is created. Otherwise the function is created
with an incomplete parameter variable (default argument is nullptr) and in
this intermediary state the expression is imported. This import can have
a reference to the incomplete parameter variable that causes crash.
Details
- Reviewers
- martong - a.sidorin - shafik 
- Commits
- rGc50959431928: [ASTImporter] Import default expression of param before creating the param.
 rL368818: [ASTImporter] Import default expression of param before creating the param.
 rC368818: [ASTImporter] Import default expression of param before creating the param.
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
| clang/lib/AST/ASTImporter.cpp | ||
|---|---|---|
| 3892 | I am not sure if it is always correct, specially in the hasUninstantiatedDefaultArg case. (The constructor calls setDefaultArg only, probably this was the reason to set the default arg afterwards in different ways that is not doable with the constructor.) | |
| clang/test/Analysis/Inputs/ctu-other.cpp | ||
| 144 | The reason for this name was that the import is incomplete, not the the default parameter. (Exactly, before the fix, the import results in a ParmVarDecl that is for temporary time interval incomplete when the default expression is missing.) In this way testIncompleteImportOfDefaultParm can be better, or testImportWithIncompleteDefaultParm. | |
A new kind of solution, the previous does not work always.
Still no test for this new problem case (circular dependency between a ParmVarDecl and function of it and a CXXDefaultArgExpr that references to the function probably by UsedContext).
Still looks good to me, other than some style nits.
| clang/lib/AST/ASTImporter.cpp | ||
|---|---|---|
| 3847 | This line seems to be longer than 80 columns, forgot to run clang-format? | |
| 6964 | This would be more appropriate I guess: "ParmVarDecl was not imported?" | |
| clang/test/Analysis/Inputs/ctu-other.cpp | ||
| 135 | Please do not forget to rename. | |
Would it be an alternative solution if we imported the function parameters after we created the FunctionDecl? I guess it would be. Maybe that would result in a smaller change, what do you think?
| clang/test/Analysis/Inputs/ctu-other.cpp | ||
|---|---|---|
| 135 | I did not get response to the name of testDefParmIncompleteImport, I think testImportOfIncompleteDefaultParm is not good, probably testImportOfIncompleteDefaultParmDuringImport is better. | |
Yes importing the parameters should be doable after the create of the function. I am not sure if it fixes this problem, the parameter that has the default expression can still be encountered without the default expression set in it.
| clang/test/Analysis/Inputs/ctu-other.cpp | ||
|---|---|---|
| 135 | Okay, so let's proceed with testImportOfIncompleteDefaultParmDuringImport. | |
This line seems to be longer than 80 columns, forgot to run clang-format?