mirror of
https://github.com/mgechev/revive.git
synced 2025-01-24 03:47:45 +02:00
47 lines
1.6 KiB
Go
47 lines
1.6 KiB
Go
package fixtures
|
|
|
|
func conditionalExpr(x, y bool) bool {
|
|
equal := x == y // should not match, not AND or OR operators
|
|
if x || y { // should not match, no caller
|
|
return true
|
|
}
|
|
or := caller(x, y) || y // MATCH /for better performance 'caller(x, y) || y' might be rewritten as 'y || caller(x, y)'/
|
|
if caller(x, y) || y { // MATCH /for better performance 'caller(x, y) || y' might be rewritten as 'y || caller(x, y)'/
|
|
return true
|
|
}
|
|
|
|
switch {
|
|
case x == y:
|
|
return y
|
|
case caller(x, y) && y: // MATCH /for better performance 'caller(x, y) && y' might be rewritten as 'y && caller(x, y)'/
|
|
return x
|
|
}
|
|
|
|
complexExpr := caller(caller(x, y) && y, y) || y
|
|
// MATCH:20 /for better performance 'caller(caller(x, y) && y, y) || y' might be rewritten as 'y || caller(caller(x, y) && y, y)'/
|
|
// MATCH:20 /for better performance 'caller(x, y) && y' might be rewritten as 'y && caller(x, y)'/
|
|
|
|
noSwap := caller(x, y) || (x && caller(y, x)) // should not match, caller in the right operand
|
|
|
|
callRight := caller(x, y) && (x && caller(y, x)) // should not match, caller in the right operand
|
|
return caller(x, y) && y // MATCH /for better performance 'caller(x, y) && y' might be rewritten as 'y && caller(x, y)'/
|
|
}
|
|
|
|
func conditionalExprSlice(s []string) bool {
|
|
if len(s) > 0 || s[0] == "" { // should not match, not safe
|
|
return false
|
|
}
|
|
|
|
f := func() bool {
|
|
len(s) > 1
|
|
}
|
|
|
|
if f() || s[0] == "test" { // MATCH /for better performance 'f() || s[0] == "test"' might be rewritten as 's[0] == "test" || f()'/
|
|
return true
|
|
}
|
|
}
|
|
|
|
func caller(x, y bool) bool {
|
|
return true
|
|
}
|