mirror of
https://github.com/chaisql/chai.git
synced 2025-10-24 16:10:30 +08:00
64 lines
1.3 KiB
Go
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.GetCatalog().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)
|
|
}
|