aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Sema/SemaFixItUtils.cpp
diff options
context:
space:
mode:
authorDavid Blaikie <dblaikie@gmail.com>2012-03-18 02:56:47 +0000
committerDavid Blaikie <dblaikie@gmail.com>2012-03-18 02:56:47 +0000
commita90e86aa36e2844b980d31cacacdb9fe39ba33fd (patch)
tree9414c8348278c3b18c9a39b869b90ca29176da8f /clang/lib/Sema/SemaFixItUtils.cpp
parent61c974b492c8cd6810c95ce9e0222e7203665ced (diff)
downloadllvm-a90e86aa36e2844b980d31cacacdb9fe39ba33fd.zip
llvm-a90e86aa36e2844b980d31cacacdb9fe39ba33fd.tar.gz
llvm-a90e86aa36e2844b980d31cacacdb9fe39ba33fd.tar.bz2
Use character literals for vexing initialization fixit hints.
Instead of suggesting " = 0" for "char c();", suggest " = '\0'", and similarly for other char types (wide, 16, and 32). Add tests for all these, and since this means testing such hints under C++0x, add tests for some untested C++0x hint cases in the existing code, including suggesting nullptr for pointer initialization. This sets up the initialization helper to provide better type fidelity that will be especially helpful for non-assignment cases (such as fixit-correcting NULL usage in function calls (eg: foo(char) + foo(NULL) => foo('\0') instead of the less informative foo(0))) llvm-svn: 153008
Diffstat (limited to 'clang/lib/Sema/SemaFixItUtils.cpp')
-rw-r--r--clang/lib/Sema/SemaFixItUtils.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaFixItUtils.cpp b/clang/lib/Sema/SemaFixItUtils.cpp
index 3b76213..b78ea7d 100644
--- a/clang/lib/Sema/SemaFixItUtils.cpp
+++ b/clang/lib/Sema/SemaFixItUtils.cpp
@@ -182,6 +182,14 @@ const char *Sema::getFixItZeroInitializerForType(QualType T) const {
else if (isMacroDefined(*this, "NULL"))
return " = NULL";
}
+ if (T->isCharType())
+ return " = '\\0'";
+ if (T->isWideCharType())
+ return " = L'\\0'";
+ if (T->isChar16Type())
+ return " = u'\\0'";
+ if (T->isChar32Type())
+ return " = U'\\0'";
return " = 0";
}