Skip to content

Commit

Permalink
opt: remove CanHaveSideEffects
Browse files Browse the repository at this point in the history
All uses of `CanHaveSideEffects` have been replaced with uses of VolatilitySet.
Remove this property.

Release note: None
  • Loading branch information
RaduBerinde committed Jun 25, 2020
1 parent b6038e9 commit 1b07b3f
Show file tree
Hide file tree
Showing 54 changed files with 724 additions and 762 deletions.
6 changes: 0 additions & 6 deletions pkg/sql/opt/memo/expr_format.go
Original file line number Diff line number Diff line change
Expand Up @@ -653,9 +653,6 @@ func (f *ExprFmtCtx) formatRelational(e RelExpr, tp treeprinter.Node) {
if !relational.VolatilitySet.IsLeakProof() {
writeFlag(relational.VolatilitySet.String())
}
if relational.CanHaveSideEffects {
writeFlag("side-effects")
}
if relational.CanMutate {
writeFlag("mutations")
}
Expand Down Expand Up @@ -923,9 +920,6 @@ func (f *ExprFmtCtx) scalarPropsStrings(scalar opt.ScalarExpr) []string {
if !scalarProps.VolatilitySet.IsLeakProof() {
emitProp(scalarProps.VolatilitySet.String())
}
if scalarProps.CanHaveSideEffects {
emitProp("side-effects")
}
if scalarProps.HasCorrelatedSubquery {
emitProp("correlated-subquery")
} else if scalarProps.HasSubquery {
Expand Down
15 changes: 2 additions & 13 deletions pkg/sql/opt/memo/logical_props_builder.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@ func (b *logicalPropsBuilder) buildScanProps(scan *ScanExpr, rel *props.Relation
// ------------
// A Locking option is a side-effect (we don't want to elide this scan).
if scan.Locking != nil {
rel.CanHaveSideEffects = true
rel.VolatilitySet.AddVolatile()
}

Expand Down Expand Up @@ -911,7 +910,6 @@ func (b *logicalPropsBuilder) buildLimitProps(limit *LimitExpr, rel *props.Relat
// ------------
// Negative limits can trigger a runtime error.
if constLimit < 0 || !haveConstLimit {
rel.CanHaveSideEffects = true
rel.VolatilitySet.AddImmutable()
}

Expand Down Expand Up @@ -1356,8 +1354,8 @@ func (b *logicalPropsBuilder) buildZipItemProps(item *ZipItem, scalar *props.Sca
//
// Note that shared is an "input-output" argument, and should be assumed
// to be partially filled in already. Boolean fields such as HasPlaceholder,
// CanHaveSideEffects and HasCorrelatedSubquery should never be reset to false
// once set to true.
// HasCorrelatedSubquery should never be reset to false once set to true;
// VolatilitySet should never be re-initialized.
func BuildSharedProps(e opt.Expr, shared *props.Shared) {
switch t := e.(type) {
case *VariableExpr:
Expand Down Expand Up @@ -1387,7 +1385,6 @@ func BuildSharedProps(e opt.Expr, shared *props.Shared) {
}
}
if !nonZero {
shared.CanHaveSideEffects = true
shared.VolatilitySet.AddImmutable()
}

Expand All @@ -1401,10 +1398,6 @@ func BuildSharedProps(e opt.Expr, shared *props.Shared) {
}

case *FunctionExpr:
if t.Properties.Impure {
// Impure functions can return different value on each call.
shared.CanHaveSideEffects = true
}
shared.VolatilitySet.Add(t.Overload.Volatility)

case *CastExpr:
Expand Down Expand Up @@ -1444,7 +1437,6 @@ func BuildSharedProps(e opt.Expr, shared *props.Shared) {
}
shared.VolatilitySet.Add(o.Volatility)
} else if opt.IsMutationOp(e) {
shared.CanHaveSideEffects = true
shared.CanMutate = true
shared.VolatilitySet.AddVolatile()
}
Expand All @@ -1470,9 +1462,6 @@ func BuildSharedProps(e opt.Expr, shared *props.Shared) {
shared.HasPlaceholder = true
}
shared.VolatilitySet.UnionWith(cached.VolatilitySet)
if cached.CanHaveSideEffects {
shared.CanHaveSideEffects = true
}
if cached.CanMutate {
shared.CanMutate = true
}
Expand Down
14 changes: 7 additions & 7 deletions pkg/sql/opt/memo/testdata/logprops/delete
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ delete abcde
├── columns: <none>
├── fetch columns: a:7(int) b:8(int) c:9(int) d:10(int) rowid:11(int) e:12(int)
├── cardinality: [0 - 0]
├── volatile, side-effects, mutations
├── volatile, mutations
└── select
├── columns: a:7(int!null) b:8(int) c:9(int!null) d:10(int) rowid:11(int!null) e:12(int)
├── key: (11)
Expand Down Expand Up @@ -55,13 +55,13 @@ DELETE FROM abcde WHERE a=1 RETURNING *
----
project
├── columns: a:1(int!null) b:2(int) c:3(int!null) d:4(int)
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(1)
├── prune: (1-4)
└── delete abcde
├── columns: a:1(int!null) b:2(int) c:3(int!null) d:4(int) rowid:5(int!null)
├── fetch columns: a:7(int) b:8(int) c:9(int) d:10(int) rowid:11(int) e:12(int)
├── volatile, side-effects, mutations
├── volatile, mutations
├── key: (5)
├── fd: ()-->(1), (5)-->(2-4)
├── prune: (1-4)
Expand Down Expand Up @@ -96,15 +96,15 @@ DELETE FROM abcde WHERE rowid=1 RETURNING *
project
├── columns: a:1(int!null) b:2(int) c:3(int!null) d:4(int)
├── cardinality: [0 - 1]
├── volatile, side-effects, mutations
├── volatile, mutations
├── key: ()
├── fd: ()-->(1-4)
├── prune: (1-4)
└── delete abcde
├── columns: a:1(int!null) b:2(int) c:3(int!null) d:4(int) rowid:5(int!null)
├── fetch columns: a:7(int) b:8(int) c:9(int) d:10(int) rowid:11(int) e:12(int)
├── cardinality: [0 - 1]
├── volatile, side-effects, mutations
├── volatile, mutations
├── key: ()
├── fd: ()-->(1-5)
├── prune: (1-4)
Expand Down Expand Up @@ -139,13 +139,13 @@ DELETE FROM abcde WHERE b=c RETURNING *;
----
project
├── columns: a:1(int!null) b:2(int!null) c:3(int!null) d:4(int)
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: (2)==(3), (3)==(2)
├── prune: (1-4)
└── delete abcde
├── columns: a:1(int!null) b:2(int!null) c:3(int!null) d:4(int) rowid:5(int!null)
├── fetch columns: a:7(int) b:8(int) c:9(int) d:10(int) rowid:11(int) e:12(int)
├── volatile, side-effects, mutations
├── volatile, mutations
├── key: (5)
├── fd: (2)==(3), (3)==(2), (5)-->(1-4)
├── prune: (1-4)
Expand Down
46 changes: 23 additions & 23 deletions pkg/sql/opt/memo/testdata/logprops/insert
Original file line number Diff line number Diff line change
Expand Up @@ -30,18 +30,18 @@ insert abcde
│ ├── column11:11 => rowid:5
│ └── column12:12 => e:6
├── cardinality: [0 - 0]
├── volatile, side-effects, mutations
├── volatile, mutations
└── project
├── columns: column13:13(int!null) y:8(int!null) column10:10(int!null) column11:11(int) column12:12(int)
├── cardinality: [0 - 10]
├── volatile, side-effects
├── volatile
├── fd: ()-->(10,12), (8)-->(13)
├── prune: (8,10-13)
├── interesting orderings: (+8)
├── project
│ ├── columns: column10:10(int!null) column11:11(int) column12:12(int) y:8(int!null)
│ ├── cardinality: [0 - 10]
│ ├── volatile, side-effects
│ ├── volatile
│ ├── fd: ()-->(10,12)
│ ├── prune: (8,10-12)
│ ├── interesting orderings: (+8)
Expand All @@ -67,7 +67,7 @@ insert abcde
│ │ └── const: 10 [type=int]
│ └── projections
│ ├── const: 10 [as=column10:10, type=int]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile, side-effects]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile]
│ └── cast: INT8 [as=column12:12, type=int, immutable]
│ └── null [type=unknown]
└── projections
Expand All @@ -84,7 +84,7 @@ INSERT INTO abcde (a, b) SELECT y, y FROM xyz ORDER BY y, z LIMIT 10 RETURNING *
project
├── columns: a:1(int!null) b:2(int!null) c:3(int!null) d:4(int!null)
├── cardinality: [0 - 10]
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(3), (1)==(2), (2)==(1), (1)-->(4)
├── prune: (1-4)
└── insert abcde
Expand All @@ -97,19 +97,19 @@ project
│ ├── column11:11 => rowid:5
│ └── column12:12 => e:6
├── cardinality: [0 - 10]
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(3), (1)==(2), (2)==(1), (1)-->(4)
└── project
├── columns: column13:13(int!null) y:8(int!null) column10:10(int!null) column11:11(int) column12:12(int)
├── cardinality: [0 - 10]
├── volatile, side-effects
├── volatile
├── fd: ()-->(10,12), (8)-->(13)
├── prune: (8,10-13)
├── interesting orderings: (+8)
├── project
│ ├── columns: column10:10(int!null) column11:11(int) column12:12(int) y:8(int!null)
│ ├── cardinality: [0 - 10]
│ ├── volatile, side-effects
│ ├── volatile
│ ├── fd: ()-->(10,12)
│ ├── prune: (8,10-12)
│ ├── interesting orderings: (+8)
Expand All @@ -135,7 +135,7 @@ project
│ │ └── const: 10 [type=int]
│ └── projections
│ ├── const: 10 [as=column10:10, type=int]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile, side-effects]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile]
│ └── cast: INT8 [as=column12:12, type=int, immutable]
│ └── null [type=unknown]
└── projections
Expand All @@ -151,7 +151,7 @@ INSERT INTO abcde (a, b) SELECT y, y FROM xyz ORDER BY y, z RETURNING *
----
project
├── columns: a:1(int!null) b:2(int!null) c:3(int!null) d:4(int!null)
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(3), (1)==(2), (2)==(1), (1)-->(4)
├── prune: (1-4)
└── insert abcde
Expand All @@ -163,16 +163,16 @@ project
│ ├── column13:13 => d:4
│ ├── column11:11 => rowid:5
│ └── column12:12 => e:6
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(3), (1)==(2), (2)==(1), (1)-->(4)
└── project
├── columns: column13:13(int!null) y:8(int!null) column10:10(int!null) column11:11(int) column12:12(int)
├── volatile, side-effects
├── volatile
├── fd: ()-->(10,12), (8)-->(13)
├── prune: (8,10-13)
├── project
│ ├── columns: column10:10(int!null) column11:11(int) column12:12(int) y:8(int!null)
│ ├── volatile, side-effects
│ ├── volatile
│ ├── fd: ()-->(10,12)
│ ├── prune: (8,10-12)
│ ├── project
Expand All @@ -186,7 +186,7 @@ project
│ │ └── interesting orderings: (+7)
│ └── projections
│ ├── const: 10 [as=column10:10, type=int]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile, side-effects]
│ ├── function: unique_rowid [as=column11:11, type=int, volatile]
│ └── cast: INT8 [as=column12:12, type=int, immutable]
│ └── null [type=unknown]
└── projections
Expand All @@ -210,20 +210,20 @@ insert abcde
│ ├── column10:10 => rowid:5
│ └── column11:11 => e:6
├── cardinality: [1 - 1]
├── volatile, side-effects, mutations
├── volatile, mutations
├── key: ()
├── fd: ()-->(1-5)
└── project
├── columns: column12:12(int!null) column1:7(int!null) column2:8(int!null) column9:9(int!null) column10:10(int) column11:11(int)
├── cardinality: [1 - 1]
├── volatile, side-effects
├── volatile
├── key: ()
├── fd: ()-->(7-12)
├── prune: (7-12)
├── project
│ ├── columns: column9:9(int!null) column10:10(int) column11:11(int) column1:7(int!null) column2:8(int!null)
│ ├── cardinality: [1 - 1]
│ ├── volatile, side-effects
│ ├── volatile
│ ├── key: ()
│ ├── fd: ()-->(7-11)
│ ├── prune: (7-11)
Expand All @@ -238,7 +238,7 @@ insert abcde
│ │ └── const: 2 [type=int]
│ └── projections
│ ├── const: 10 [as=column9:9, type=int]
│ ├── function: unique_rowid [as=column10:10, type=int, volatile, side-effects]
│ ├── function: unique_rowid [as=column10:10, type=int, volatile]
│ └── cast: INT8 [as=column11:11, type=int, immutable]
│ └── null [type=unknown]
└── projections
Expand All @@ -254,7 +254,7 @@ INSERT INTO abcde (a, b) SELECT y, (z+1)::int FROM xyz WHERE y=1 RETURNING a, c;
----
project
├── columns: a:1(int!null) c:3(int!null)
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(1,3)
├── prune: (1,3)
└── insert abcde
Expand All @@ -266,16 +266,16 @@ project
│ ├── column14:14 => d:4
│ ├── column12:12 => rowid:5
│ └── column13:13 => e:6
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(1,3), (2)-->(4)
└── project
├── columns: column14:14(int) y:8(int!null) int8:10(int) column11:11(int!null) column12:12(int) column13:13(int)
├── volatile, side-effects
├── volatile
├── fd: ()-->(8,11,13), (10)-->(14)
├── prune: (8,10-14)
├── project
│ ├── columns: column11:11(int!null) column12:12(int) column13:13(int) y:8(int!null) int8:10(int)
│ ├── volatile, side-effects
│ ├── volatile
│ ├── fd: ()-->(8,11,13)
│ ├── prune: (8,10-13)
│ ├── project
Expand Down Expand Up @@ -306,7 +306,7 @@ project
│ │ └── const: 1.0 [type=float]
│ └── projections
│ ├── const: 10 [as=column11:11, type=int]
│ ├── function: unique_rowid [as=column12:12, type=int, volatile, side-effects]
│ ├── function: unique_rowid [as=column12:12, type=int, volatile]
│ └── cast: INT8 [as=column13:13, type=int, immutable]
│ └── null [type=unknown]
└── projections
Expand Down
8 changes: 4 additions & 4 deletions pkg/sql/opt/memo/testdata/logprops/join
Original file line number Diff line number Diff line change
Expand Up @@ -1476,13 +1476,13 @@ SELECT (SELECT m FROM
----
with &1
├── columns: m:19(int)
├── volatile, side-effects, mutations
├── volatile, mutations
├── fd: ()-->(19)
├── prune: (19)
├── project
│ ├── columns: uv.u:4(int!null) uv.v:5(int!null)
│ ├── cardinality: [1 - 1]
│ ├── volatile, side-effects, mutations
│ ├── volatile, mutations
│ ├── key: ()
│ ├── fd: ()-->(4,5)
│ ├── prune: (4,5)
Expand All @@ -1493,13 +1493,13 @@ with &1
│ │ ├── column2:8 => uv.v:5
│ │ └── column9:9 => rowid:6
│ ├── cardinality: [1 - 1]
│ ├── volatile, side-effects, mutations
│ ├── volatile, mutations
│ ├── key: ()
│ ├── fd: ()-->(4-6)
│ └── values
│ ├── columns: column1:7(int!null) column2:8(int!null) column9:9(int)
│ ├── cardinality: [1 - 1]
│ ├── volatile, side-effects
│ ├── volatile
│ ├── key: ()
│ ├── fd: ()-->(7-9)
│ ├── prune: (7-9)
Expand Down
10 changes: 5 additions & 5 deletions pkg/sql/opt/memo/testdata/logprops/limit
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ SELECT * FROM xyzs LIMIT (SELECT 1)
----
limit
├── columns: x:1(int!null) y:2(int) z:3(float!null) s:4(string)
├── immutable, side-effects
├── immutable
├── key: (1)
├── fd: (1)-->(2-4), (3,4)~~>(1,2)
├── prune: (1-4)
Expand Down Expand Up @@ -113,7 +113,7 @@ SELECT (SELECT x FROM kuv LIMIT y) FROM xyzs
----
project
├── columns: x:9(int)
├── immutable, side-effects
├── immutable
├── prune: (9)
├── scan xyzs
│ ├── columns: xyzs.x:1(int!null) y:2(int) z:3(float!null) s:4(string)
Expand All @@ -122,19 +122,19 @@ project
│ ├── prune: (1-4)
│ └── interesting orderings: (+1) (-4,+3,+1)
└── projections
└── subquery [as=x:9, type=int, outer=(1,2), immutable, side-effects, correlated-subquery]
└── subquery [as=x:9, type=int, outer=(1,2), immutable, correlated-subquery]
└── max1-row
├── columns: x:8(int)
├── error: "more than one row returned by a subquery used as an expression"
├── outer: (1,2)
├── cardinality: [0 - 1]
├── immutable, side-effects
├── immutable
├── key: ()
├── fd: ()-->(8)
└── limit
├── columns: x:8(int)
├── outer: (1,2)
├── immutable, side-effects
├── immutable
├── fd: ()-->(8)
├── prune: (8)
├── project
Expand Down
Loading

0 comments on commit 1b07b3f

Please sign in to comment.