// RUN: %check_clang_tidy %s readability-operators-representation %t -- -config="{CheckOptions: {\ // RUN: readability-operators-representation.BinaryOperators: 'and;and_eq;bitand;bitor;compl;not;not_eq;or;or_eq;xor;xor_eq', \ // RUN: readability-operators-representation.OverloadedOperators: 'and;and_eq;bitand;bitor;compl;not;not_eq;or;or_eq;xor;xor_eq'}}" -- void testAllTokensToAlternative(int a, int b) { int value = 0; value = a||b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '||' is a traditional token spelling, consider using an alternative token 'or' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a or b;{{$}} value = a&&b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '&&' is a traditional token spelling, consider using an alternative token 'and' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a and b;{{$}} value = a | b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '|' is a traditional token spelling, consider using an alternative token 'bitor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a bitor b;{{$}} value = a & b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '&' is a traditional token spelling, consider using an alternative token 'bitand' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a bitand b;{{$}} value = !a; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '!' is a traditional token spelling, consider using an alternative token 'not' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = not a;{{$}} value = a^b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '^' is a traditional token spelling, consider using an alternative token 'xor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a xor b;{{$}} value = ~b; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '~' is a traditional token spelling, consider using an alternative token 'compl' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = compl b;{{$}} value &= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '&=' is a traditional token spelling, consider using an alternative token 'and_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value and_eq b;{{$}} value |= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '|=' is a traditional token spelling, consider using an alternative token 'or_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value or_eq b;{{$}} value = a != b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '!=' is a traditional token spelling, consider using an alternative token 'not_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a not_eq b;{{$}} value ^= a; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '^=' is a traditional token spelling, consider using an alternative token 'xor_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value xor_eq a;{{$}} } struct Class { bool operator!() const; Class operator~() const; bool operator&&(const Class&) const; Class operator&(const Class&) const; bool operator||(const Class&) const; Class operator|(const Class&) const; Class operator^(const Class&) const; Class& operator&=(const Class&) const; Class& operator|=(const Class&) const; Class& operator^=(const Class&) const; bool operator!=(const Class&) const; }; void testAllTokensToAlternative(Class a, Class b) { int value = 0; Class clval; value = a||b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '||' is a traditional token spelling, consider using an alternative token 'or' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a or b;{{$}} value = a&&b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '&&' is a traditional token spelling, consider using an alternative token 'and' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a and b;{{$}} clval = a | b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '|' is a traditional token spelling, consider using an alternative token 'bitor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a bitor b;{{$}} clval = a & b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '&' is a traditional token spelling, consider using an alternative token 'bitand' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a bitand b;{{$}} value = !a; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '!' is a traditional token spelling, consider using an alternative token 'not' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = not a;{{$}} clval = a^b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '^' is a traditional token spelling, consider using an alternative token 'xor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a xor b;{{$}} clval = ~b; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '~' is a traditional token spelling, consider using an alternative token 'compl' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = compl b;{{$}} clval &= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '&=' is a traditional token spelling, consider using an alternative token 'and_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval and_eq b;{{$}} clval |= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '|=' is a traditional token spelling, consider using an alternative token 'or_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval or_eq b;{{$}} value = a != b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '!=' is a traditional token spelling, consider using an alternative token 'not_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a not_eq b;{{$}} clval ^= a; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '^=' is a traditional token spelling, consider using an alternative token 'xor_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval xor_eq a;{{$}} } struct ClassO {}; ClassO& operator&=(ClassO&, const ClassO&); ClassO& operator|=(ClassO&, const ClassO&); ClassO& operator^=(ClassO&, const ClassO&); bool operator!=(const ClassO&, const ClassO&); bool operator&&(const ClassO&, const ClassO&); bool operator||(const ClassO&, const ClassO&); bool operator!(const ClassO&); ClassO operator&(const ClassO&, const ClassO&); ClassO operator|(const ClassO&, const ClassO&); ClassO operator^(const ClassO&, const ClassO&); ClassO operator~(const ClassO&); void testAllTokensToAlternative(ClassO a, ClassO b) { int value = 0; ClassO clval; value = a||b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '||' is a traditional token spelling, consider using an alternative token 'or' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a or b;{{$}} value = a&&b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '&&' is a traditional token spelling, consider using an alternative token 'and' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a and b;{{$}} clval = a | b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '|' is a traditional token spelling, consider using an alternative token 'bitor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a bitor b;{{$}} clval = a & b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '&' is a traditional token spelling, consider using an alternative token 'bitand' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a bitand b;{{$}} value = !a; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '!' is a traditional token spelling, consider using an alternative token 'not' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = not a;{{$}} clval = a^b; // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: '^' is a traditional token spelling, consider using an alternative token 'xor' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = a xor b;{{$}} clval = ~b; // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: '~' is a traditional token spelling, consider using an alternative token 'compl' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval = compl b;{{$}} clval &= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '&=' is a traditional token spelling, consider using an alternative token 'and_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval and_eq b;{{$}} clval |= b; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '|=' is a traditional token spelling, consider using an alternative token 'or_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval or_eq b;{{$}} value = a != b; // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: '!=' is a traditional token spelling, consider using an alternative token 'not_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}value = a not_eq b;{{$}} clval ^= a; // CHECK-MESSAGES: :[[@LINE-1]]:9: warning: '^=' is a traditional token spelling, consider using an alternative token 'xor_eq' for consistency [readability-operators-representation] // CHECK-FIXES: {{^ }}clval xor_eq a;{{$}} }