-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprecedence.go
96 lines (88 loc) · 1.97 KB
/
precedence.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
Copyright 2019 The Vitess Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package sqlparser
// Precendence is used to know the precedence between operators,
// so we can introduce parens when needed in the String representation of the AST
type Precendence int
const (
Syntactic Precendence = iota
P1
P2
P3
P4
P5
P6
P7
P8
P9
P10
P11
P12
P13
P14
P15
P16
P17
)
// precedenceFor returns the precedence of an expression.
//
// * NOTE: If you change anything here, update sql.y to keep them consistent.
// Also make sure to add the new constructs to random_expr.go so we have test coverage for the new expressions *
func precedenceFor(in Expr) Precendence {
switch node := in.(type) {
case *OrExpr:
return P16
case *XorExpr:
return P15
case *AndExpr:
return P14
case *NotExpr:
return P13
case *RangeCond:
return P12
case *ComparisonExpr:
switch node.Operator {
case EqualOp, NotEqualOp, GreaterThanOp, GreaterEqualOp, LessThanOp, LessEqualOp, LikeOp, InOp, RegexpOp:
return P11
}
case *IsExpr:
return P11
case *BinaryExpr:
switch node.Operator {
case BitOrOp:
return P10
case BitAndOp:
return P9
case ShiftLeftOp, ShiftRightOp:
return P8
case PlusOp, MinusOp:
return P7
case DivOp, MultOp, ModOp, IntDivOp:
return P6
case BitXorOp:
return P5
}
case *UnaryExpr:
switch node.Operator {
case UPlusOp, UMinusOp:
return P4
case BangOp:
return P3
case BinaryOp:
return P2
}
case *IntervalExpr:
return P1
}
return Syntactic
}