Files
chaisql/internal/stream/table/replace.go
2023-11-04 10:26:04 +04:00

64 lines
1.3 KiB
Go

package table
import (
"fmt"
"github.com/cockroachdb/errors"
"github.com/genjidb/genji/internal/database"
"github.com/genjidb/genji/internal/environment"
"github.com/genjidb/genji/internal/stream"
)
// A ReplaceOperator replaces documents in the table
type ReplaceOperator struct {
stream.BaseOperator
Name string
}
// Replace replaces documents in the table. Incoming documents must implement the document.Keyer interface.
func Replace(tableName string) *ReplaceOperator {
return &ReplaceOperator{Name: tableName}
}
// Iterate implements the Operator interface.
func (op *ReplaceOperator) Iterate(in *environment.Environment, f func(out *environment.Environment) error) error {
var table *database.Table
it := func(out *environment.Environment) error {
d, ok := out.GetDocument()
if !ok {
return errors.New("missing document")
}
if table == nil {
var err error
table, err = out.GetTx().Catalog.GetTable(out.GetTx(), op.Name)
if err != nil {
return err
}
}
key, ok := out.GetKey()
if !ok {
return errors.New("missing key")
}
_, err := table.Replace(key, d)
if err != nil {
return err
}
return f(out)
}
if op.Prev == nil {
return it(in)
}
return op.Prev.Iterate(in, it)
}
func (op *ReplaceOperator) String() string {
return fmt.Sprintf("table.Replace(%q)", op.Name)
}