aboutsummaryrefslogtreecommitdiff
path: root/lldb/source/Plugins/ScriptInterpreter/Python/ScriptedThreadPythonInterface.cpp
diff options
context:
space:
mode:
authorMuhammad Usman Shahid <codesbyusman@gmail.com>2022-07-28 07:45:28 -0400
committerAaron Ballman <aaron@aaronballman.com>2022-07-28 07:45:28 -0400
commit0cc3c184c784d5f0d55de8ad0a9eeee876acd149 (patch)
tree2205eddeba010f8dd0aedf70f192f7a860733c9e /lldb/source/Plugins/ScriptInterpreter/Python/ScriptedThreadPythonInterface.cpp
parent955cc56af448301e2d353df90ca1f0c6a74118f2 (diff)
downloadllvm-0cc3c184c784d5f0d55de8ad0a9eeee876acd149.zip
llvm-0cc3c184c784d5f0d55de8ad0a9eeee876acd149.tar.gz
llvm-0cc3c184c784d5f0d55de8ad0a9eeee876acd149.tar.bz2
Missing tautological compare warnings due to unary operators
The patch mainly focuses on the lack of warnings for -Wtautological-compare. It works fine for positive numbers but doesn't for negative numbers. This is because the warning explicitly checks for an IntegerLiteral AST node, but -1 is represented by a UnaryOperator with an IntegerLiteral sub-Expr. For the below code we have warnings: if (0 == (5 | x)) {} but not for if (0 == (-5 | x)) {} This patch changes the analysis to not look at the AST node directly to see if it is an IntegerLiteral, but instead attempts to evaluate the expression to see if it is an integer constant expression. This handles unary negation signs, but also handles all the other possible operators as well. Fixes #42918 Differential Revision: https://reviews.llvm.org/D130510
Diffstat (limited to 'lldb/source/Plugins/ScriptInterpreter/Python/ScriptedThreadPythonInterface.cpp')
0 files changed, 0 insertions, 0 deletions