filterPlan.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. // Copyright 2021 EMQ Technologies Co., Ltd.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package planner
  15. import "github.com/lf-edge/ekuiper/pkg/ast"
  16. type FilterPlan struct {
  17. baseLogicalPlan
  18. condition ast.Expr
  19. }
  20. func (p FilterPlan) Init() *FilterPlan {
  21. p.baseLogicalPlan.self = &p
  22. return &p
  23. }
  24. func (p *FilterPlan) PushDownPredicate(condition ast.Expr) (ast.Expr, LogicalPlan) {
  25. // if no child, swallow all conditions
  26. a := combine(condition, p.condition)
  27. if len(p.children) == 0 {
  28. p.condition = a
  29. return nil, p
  30. }
  31. rest, _ := p.baseLogicalPlan.PushDownPredicate(a)
  32. if rest != nil {
  33. p.condition = rest
  34. return nil, p
  35. } else if len(p.children) == 1 {
  36. // eliminate this filter
  37. return nil, p.children[0]
  38. } else {
  39. return nil, p
  40. }
  41. }
  42. func (p *FilterPlan) PruneColumns(fields []ast.Expr) error {
  43. f := getFields(p.condition)
  44. return p.baseLogicalPlan.PruneColumns(append(fields, f...))
  45. }