diff options
author | David Blaikie <dblaikie@gmail.com> | 2012-03-18 02:56:47 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2012-03-18 02:56:47 +0000 |
commit | a90e86aa36e2844b980d31cacacdb9fe39ba33fd (patch) | |
tree | 9414c8348278c3b18c9a39b869b90ca29176da8f /clang/lib/Sema/SemaFixItUtils.cpp | |
parent | 61c974b492c8cd6810c95ce9e0222e7203665ced (diff) | |
download | llvm-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.cpp | 8 |
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"; } |