diff options
| author | Alexander Kornienko <alexfh@google.com> | 2018-02-28 23:30:29 +0000 |
|---|---|---|
| committer | Alexander Kornienko <alexfh@google.com> | 2018-02-28 23:30:29 +0000 |
| commit | cb6d32034514bcdd152a95684ed309149f06070d (patch) | |
| tree | 5f755c450fb834f7a0b1837eacf42743efed5cb1 /clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst | |
| parent | ff9595a002d48a4470f0518c26920fab39e2f62c (diff) | |
| download | bcm5719-llvm-cb6d32034514bcdd152a95684ed309149f06070d.tar.gz bcm5719-llvm-cb6d32034514bcdd152a95684ed309149f06070d.zip | |
Rename more checks from misc- to bugprone-.
Summary:
clang-tidy/rename_check.py {misc,bugprone}-string-integer-assignment
clang-tidy/rename_check.py {misc,bugprone}-string-literal-with-embedded-nul
clang-tidy/rename_check.py {misc,bugprone}-suspicious-enum-usage
clang-tidy/rename_check.py {misc,bugprone}-suspicious-missing-comma
Reviewers: hokein, sammccall, aaron.ballman
Subscribers: klimek, cfe-commits, mgorny
Differential Revision: https://reviews.llvm.org/D43868
llvm-svn: 326384
Diffstat (limited to 'clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst')
| -rw-r--r-- | clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst b/clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst new file mode 100644 index 00000000000..6401f008d2e --- /dev/null +++ b/clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst @@ -0,0 +1,37 @@ +.. title:: clang-tidy - bugprone-string-integer-assignment + +bugprone-string-integer-assignment +================================== + +The check finds assignments of an integer to ``std::basic_string<CharT>`` +(``std::string``, ``std::wstring``, etc.). The source of the problem is the +following assignment operator of ``std::basic_string<CharT>``: + +.. code-block:: c++ + + basic_string& operator=( CharT ch ); + +Numeric types can be implicitly casted to character types. + +.. code-block:: c++ + + std::string s; + int x = 5965; + s = 6; + s = x; + +Use the appropriate conversion functions or character literals. + +.. code-block:: c++ + + std::string s; + int x = 5965; + s = '6'; + s = std::to_string(x); + +In order to suppress false positives, use an explicit cast. + +.. code-block:: c++ + + std::string s; + s = static_cast<char>(6); |

