diff options
Diffstat (limited to 'clang-tools-extra/test/clang-tidy/readability-implicit-bool-conversion-allow-in-conditions.cpp')
-rw-r--r-- | clang-tools-extra/test/clang-tidy/readability-implicit-bool-conversion-allow-in-conditions.cpp | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/clang-tools-extra/test/clang-tidy/readability-implicit-bool-conversion-allow-in-conditions.cpp b/clang-tools-extra/test/clang-tidy/readability-implicit-bool-conversion-allow-in-conditions.cpp new file mode 100644 index 00000000000..13524de8383 --- /dev/null +++ b/clang-tools-extra/test/clang-tidy/readability-implicit-bool-conversion-allow-in-conditions.cpp @@ -0,0 +1,66 @@ +// RUN: %check_clang_tidy %s readability-implicit-bool-conversion %t \ +// RUN: -config='{CheckOptions: \ +// RUN: [{key: readability-implicit-bool-conversion.AllowIntegerConditions, value: 1}, \ +// RUN: {key: readability-implicit-bool-conversion.AllowPointerConditions, value: 1}]}' \ +// RUN: -- -std=c++11 + +template<typename T> +void functionTaking(T); + +int functionReturningInt(); +int* functionReturningPointer(); + +struct Struct { + int member; +}; + + +void regularImplicitConversionIntegerToBoolIsNotIgnored() { + int integer = 0; + functionTaking<bool>(integer); + // CHECK-MESSAGES: :[[@LINE-1]]:24: warning: implicit conversion 'int' -> bool [readability-implicit-bool-conversion] + // CHECK-FIXES: functionTaking<bool>(integer != 0); +} + +void implicitConversionIntegerToBoolInConditionalsIsAllowed() { + if (functionReturningInt()) {} + if (!functionReturningInt()) {} + if (functionReturningInt() && functionReturningPointer()) {} + if (!functionReturningInt() && !functionReturningPointer()) {} + for (; functionReturningInt(); ) {} + for (; functionReturningPointer(); ) {} + for (; functionReturningInt() && !functionReturningPointer() || (!functionReturningInt() && functionReturningPointer()); ) {} + while (functionReturningInt()) {} + while (functionReturningPointer()) {} + while (functionReturningInt() && !functionReturningPointer() || (!functionReturningInt() && functionReturningPointer())) {} + int value1 = functionReturningInt() ? 1 : 2; + int value2 = !functionReturningInt() ? 1 : 2; + int value3 = (functionReturningInt() && functionReturningPointer() || !functionReturningInt()) ? 1 : 2; + int value4 = functionReturningInt() ?: value3; + int *p1 = functionReturningPointer() ?: &value3; +} + +void regularImplicitConversionPointerToBoolIsNotIgnored() { + int* pointer = nullptr; + functionTaking<bool>(pointer); + // CHECK-MESSAGES: :[[@LINE-1]]:24: warning: implicit conversion 'int *' -> bool + // CHECK-FIXES: functionTaking<bool>(pointer != nullptr); + + int Struct::* memberPointer = &Struct::member; + functionTaking<bool>(memberPointer); + // CHECK-MESSAGES: :[[@LINE-1]]:24: warning: implicit conversion 'int Struct::*' -> bool + // CHECK-FIXES: functionTaking<bool>(memberPointer != nullptr); +} + +void implicitConversionPointerToBoolInConditionalsIsAllowed() { + if (functionReturningPointer()) {} + if (not functionReturningPointer()) {} + int value1 = functionReturningPointer() ? 1 : 2; + int value2 = (not functionReturningPointer()) ? 1 : 2; + + int Struct::* memberPointer = &Struct::member; + if (memberPointer) {} + if (memberPointer) {} + int value3 = memberPointer ? 1 : 2; + int value4 = (not memberPointer) ? 1 : 2; +} |