diff options
author | Alexander Kornienko <alexfh@google.com> | 2015-05-17 12:31:12 +0000 |
---|---|---|
committer | Alexander Kornienko <alexfh@google.com> | 2015-05-17 12:31:12 +0000 |
commit | fb3e2cd8ccea054cae31d6576f5b98b97f15f6ac (patch) | |
tree | ed0124d819b826dd38b813316cf5d5bcde951534 /clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp | |
parent | 53958e187a624142498f42d4a67a8e64b65b1c6c (diff) | |
download | bcm5719-llvm-fb3e2cd8ccea054cae31d6576f5b98b97f15f6ac.tar.gz bcm5719-llvm-fb3e2cd8ccea054cae31d6576f5b98b97f15f6ac.zip |
[clang-tidy] Enhance clang-tidy readability-simplify-boolean-expr check...
Enhance clang-tidy readability-simplify-boolean-expr check to handle chained
conditional assignment and chained conditional return.
Based on feedback from applying this tool to the clang/LLVM codebase, this
changeset improves the readability-simplify-boolean-expr check so that
conditional assignment or return statements at the end of a chain of if/else if
statements are left unchanged unless a configuration option is supplied.
http://reviews.llvm.org/D8996
Patch by Richard Thomson!
llvm-svn: 237541
Diffstat (limited to 'clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp')
-rw-r--r-- | clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp b/clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp new file mode 100644 index 00000000000..a4e60263ec7 --- /dev/null +++ b/clang-tools-extra/test/clang-tidy/readability-simplify-bool-expr-chained-conditional-assignment.cpp @@ -0,0 +1,35 @@ +// RUN: $(dirname %s)/check_clang_tidy.sh %s readability-simplify-boolean-expr %t -config="{CheckOptions: [{key: "readability-simplify-boolean-expr.ChainedConditionalAssignment", value: 1}]}" -- +// REQUIRES: shell + +void chained_conditional_compound_assignment(int i) { + bool b; + if (i < 0) { + b = true; + } else if (i < 10) { + b = false; + } else if (i > 20) { + b = true; + } else { + b = false; + } + // CHECK-MESSAGES: :[[@LINE-4]]:9: warning: redundant boolean literal in conditional assignment [readability-simplify-boolean-expr] + // CHECK-FIXES: {{^}} } else if (i < 10) {{{$}} + // CHECK-FIXES-NEXT: {{^}} b = false;{{$}} + // CHECK-FIXES-NEXT: {{^}} } else b = i > 20;{{$}} +} + +void chained_conditional_assignment(int i) { + bool b; + if (i < 0) + b = true; + else if (i < 10) + b = false; + else if (i > 20) + b = true; + else + b = false; + // CHECK-MESSAGES: :[[@LINE-3]]:9: warning: {{.*}} in conditional assignment + // CHECK-FIXES: {{^}} else if (i < 10) + // CHECK-FIXES-NEXT: {{^}} b = false; + // CHECK-FIXES-NEXT: {{^}} else b = i > 20; +} |