summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst
diff options
context:
space:
mode:
authorAlexander Kornienko <alexfh@google.com>2018-02-28 23:30:29 +0000
committerAlexander Kornienko <alexfh@google.com>2018-02-28 23:30:29 +0000
commitcb6d32034514bcdd152a95684ed309149f06070d (patch)
tree5f755c450fb834f7a0b1837eacf42743efed5cb1 /clang-tools-extra/docs/clang-tidy/checks/bugprone-string-integer-assignment.rst
parentff9595a002d48a4470f0518c26920fab39e2f62c (diff)
downloadbcm5719-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.rst37
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);
OpenPOWER on IntegriCloud