Files
ent/entc/integration/migrate/entv2/group_delete.go
Ariel Mashraki 1e47de5300 move lib/go/gremlin to ent/dialect (#1192)
Summary:
Pull Request resolved: https://github.com/facebookexternal/fbc/pull/1192

Pull Request resolved: https://github.com/facebookincubator/ent/pull/11

Reviewed By: alexsn

Differential Revision: D16377224

fbshipit-source-id: 07ca7436eb9b64fbe2299568560b91466b2417ba
2019-07-20 08:27:06 -07:00

88 lines
2.0 KiB
Go

// Code generated (@generated) by entc, DO NOT EDIT.
package entv2
import (
"context"
"errors"
"fbc/ent/entc/integration/migrate/entv2/group"
"fbc/ent"
"fbc/ent/dialect"
"fbc/ent/dialect/gremlin"
"fbc/ent/dialect/gremlin/graph/dsl"
"fbc/ent/dialect/gremlin/graph/dsl/g"
"fbc/ent/dialect/sql"
)
// GroupDelete is the builder for deleting a Group entity.
type GroupDelete struct {
config
predicates []ent.Predicate
}
// Where adds a new predicate for the builder.
func (gd *GroupDelete) Where(ps ...ent.Predicate) *GroupDelete {
gd.predicates = append(gd.predicates, ps...)
return gd
}
// Exec executes the deletion query.
func (gd *GroupDelete) Exec(ctx context.Context) error {
switch gd.driver.Dialect() {
case dialect.MySQL, dialect.SQLite:
return gd.sqlExec(ctx)
case dialect.Neptune:
return gd.gremlinExec(ctx)
default:
return errors.New("entv2: unsupported dialect")
}
}
// ExecX is like Exec, but panics if an error occurs.
func (gd *GroupDelete) ExecX(ctx context.Context) {
if err := gd.Exec(ctx); err != nil {
panic(err)
}
}
func (gd *GroupDelete) sqlExec(ctx context.Context) error {
var res sql.Result
selector := sql.Select().From(sql.Table(group.Table))
for _, p := range gd.predicates {
p.SQL(selector)
}
query, args := sql.Delete(group.Table).FromSelect(selector).Query()
return gd.driver.Exec(ctx, query, args, &res)
}
func (gd *GroupDelete) gremlinExec(ctx context.Context) error {
res := &gremlin.Response{}
query, bindings := gd.gremlin().Query()
return gd.driver.Exec(ctx, query, bindings, res)
}
func (gd *GroupDelete) gremlin() *dsl.Traversal {
t := g.V().HasLabel(group.Label)
for _, p := range gd.predicates {
p.Gremlin(t)
}
return t.Drop()
}
// GroupDeleteOne is the builder for deleting a single Group entity.
type GroupDeleteOne struct {
gd *GroupDelete
}
// Exec executes the deletion query.
func (gdo *GroupDeleteOne) Exec(ctx context.Context) error {
return gdo.gd.Exec(ctx)
}
// ExecX is like Exec, but panics if an error occurs.
func (gdo *GroupDeleteOne) ExecX(ctx context.Context) {
gdo.gd.ExecX(ctx)
}