https://github.com/Discookie created https://github.com/llvm/llvm-project/pull/139068
Finds instances of always-true and always-false conditions in branch statements, a straightforward use case for the dataflow framework. This check is a work in progress - the core of the check is simple, but there are too many false positives currently for the check to be usable. More heuristics are needed to reduce the count of false positives. Currently only assert-like statements are filtered out. More information on false-positive types are in the docs here: https://github.com/Discookie/llvm-project/blob/dataflow-deadcode/clang-tools-extra/docs/clang-tidy/checks/bugprone/dataflow-dead-code.rst [Results on some open-source projects](https://codechecker-demo.eastus.cloudapp.azure.com/Default/runs?run=discookie-dataflow-deadcode) Framework improvements needed for the check to be fully functional: - A branch transfer function in the Diagnoser entity. The workaround for this missing function is wonky and causes many false positives. - Some kind of support for C++ classes. I can technically work this around inside my check, but first-class support for it would be nice. <!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8"> <meta http-equiv="Content-Security-Policy" content="default-src 'none'; base-uri 'self'; connect-src 'self'; form-action 'self'; img-src 'self' data:; script-src 'self'; style-src 'unsafe-inline'"> <meta content="origin" name="referrer"> <title>Rate limit · GitHub</title> <meta name="viewport" content="width=device-width"> <style type="text/css" media="screen"> body { background-color: #f6f8fa; color: #24292e; font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol; font-size: 14px; line-height: 1.5; margin: 0; } .container { margin: 50px auto; max-width: 600px; text-align: center; padding: 0 24px; } a { color: #0366d6; text-decoration: none; } a:hover { text-decoration: underline; } h1 { line-height: 60px; font-size: 48px; font-weight: 300; margin: 0px; text-shadow: 0 1px 0 #fff; } p { color: rgba(0, 0, 0, 0.5); margin: 20px 0 40px; } ul { list-style: none; margin: 25px 0; padding: 0; } li { display: table-cell; font-weight: bold; width: 1%; } .logo { display: inline-block; margin-top: 35px; } .logo-img-2x { display: none; } @media only screen and (-webkit-min-device-pixel-ratio: 2), only screen and ( min--moz-device-pixel-ratio: 2), only screen and ( -o-min-device-pixel-ratio: 2/1), only screen and ( min-device-pixel-ratio: 2), only screen and ( min-resolution: 192dpi), only screen and ( min-resolution: 2dppx) { .logo-img-1x { display: none; } .logo-img-2x { display: inline-block; } } #suggestions { margin-top: 35px; color: #ccc; } #suggestions a { color: #666666; font-weight: 200; font-size: 14px; margin: 0 10px; } </style> </head> <body> <div class="container"> <h1>Whoa there!</h1> <p>You have exceeded a secondary rate limit.<br><br> Please wait a few minutes before you try again;<br> in some cases this may take up to an hour. </p> <div id="suggestions"> <a href="https://support.github.com/contact">Contact Support</a> — <a href="https://githubstatus.com">GitHub Status</a> — <a href="https://twitter.com/githubstatus">@githubstatus</a> </div> <a href="/" class="logo logo-img-1x"> <img width="32" height="32" title="" alt="" src=""> </a> <a href="/" class="logo logo-img-2x"> <img width="32" height="32" title="" alt="" src=""> </a> </div> </body> </html> _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits