mirror of
https://github.com/ent/ent.git
synced 2026-03-05 19:35:23 +03:00
entc/gen/template: allow nested template access Receiver (#4354)
This commit is contained in:
@@ -39,7 +39,7 @@ use the following template:
|
|||||||
```gotemplate
|
```gotemplate
|
||||||
{{ range $n := $.Nodes }}
|
{{ range $n := $.Nodes }}
|
||||||
{{ $builder := $n.CreateName }}
|
{{ $builder := $n.CreateName }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $n.CreateReceiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) Set{{ $n.Name }}(input *{{ $n.Name }}) *{{ $builder }} {
|
func ({{ $receiver }} *{{ $builder }}) Set{{ $n.Name }}(input *{{ $n.Name }}) *{{ $builder }} {
|
||||||
{{- range $f := $n.Fields }}
|
{{- range $f := $n.Fields }}
|
||||||
|
|||||||
@@ -147,8 +147,8 @@ func ({{ $receiver }} *{{ $builder }}) check() error {
|
|||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
{{ $bulk := printf "%sCreateBulk" (pascal $.Name) }}
|
{{ $bulk := $.CreateBulkName }}
|
||||||
{{ $receiver = receiver $bulk }}
|
{{ $receiver = $.CreateBulReceiver }}
|
||||||
|
|
||||||
// {{ $bulk }} is the builder for creating many {{ $.Name }} entities in bulk.
|
// {{ $bulk }} is the builder for creating many {{ $.Name }} entities in bulk.
|
||||||
type {{ $bulk }} struct {
|
type {{ $bulk }} struct {
|
||||||
@@ -165,7 +165,7 @@ type {{ $bulk }} struct {
|
|||||||
{{/* If the storage driver supports bulk creation */}}
|
{{/* If the storage driver supports bulk creation */}}
|
||||||
{{ $tmpl = printf "dialect/%s/create_bulk" $.Storage }}
|
{{ $tmpl = printf "dialect/%s/create_bulk" $.Storage }}
|
||||||
{{ if hasTemplate $tmpl }}
|
{{ if hasTemplate $tmpl }}
|
||||||
{{ with extend $ "Builder" $bulk "Receiver" $receiver }}
|
{{ with extend $ "Receiver" $receiver "Builder" $bulk }}
|
||||||
{{ xtemplate $tmpl . }}
|
{{ xtemplate $tmpl . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
{{ $builder := $.QueryName }}
|
{{ $builder := $.QueryName }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.QueryReceiver }}
|
||||||
|
|
||||||
// {{ $builder }} is the builder for querying {{ $.Name }} entities.
|
// {{ $builder }} is the builder for querying {{ $.Name }} entities.
|
||||||
type {{ $builder }} struct {
|
type {{ $builder }} struct {
|
||||||
@@ -412,7 +412,7 @@ func ({{ $receiver }} *{{ $builder }}) prepareQuery(ctx context.Context) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
{{ with extend $ "Builder" $builder "Package" $pkg }}
|
{{ with extend $ "Receiver" $receiver "Builder" $builder "Package" $pkg }}
|
||||||
{{ $tmpl := printf "dialect/%s/query" $.Storage }}
|
{{ $tmpl := printf "dialect/%s/query" $.Storage }}
|
||||||
{{ xtemplate $tmpl . }}
|
{{ xtemplate $tmpl . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
@@ -451,7 +451,7 @@ func ({{ $groupReceiver }} *{{ $groupBuilder }}) Scan(ctx context.Context, v any
|
|||||||
return scanWithInterceptors[*{{ $builder }}, *{{ $groupBuilder }}](ctx, {{ $groupReceiver }}.build, {{ $groupReceiver }}, {{ $groupReceiver }}.build.inters, v)
|
return scanWithInterceptors[*{{ $builder }}, *{{ $groupBuilder }}](ctx, {{ $groupReceiver }}.build, {{ $groupReceiver }}, {{ $groupReceiver }}.build.inters, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
{{ with extend $ "Builder" $groupBuilder }}
|
{{ with extend $ "Receiver" $groupReceiver "Builder" $groupBuilder }}
|
||||||
{{ $tmpl := printf "dialect/%s/group" $.Storage }}
|
{{ $tmpl := printf "dialect/%s/group" $.Storage }}
|
||||||
{{ xtemplate $tmpl . }}
|
{{ xtemplate $tmpl . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
@@ -481,7 +481,7 @@ func ({{ $selectReceiver }} *{{ $selectBuilder }}) Scan(ctx context.Context, v a
|
|||||||
return scanWithInterceptors[*{{ $builder }}, *{{ $selectBuilder }}](ctx, {{ $selectReceiver }}.{{ $.QueryName }}, {{ $selectReceiver }}, {{ $selectReceiver }}.inters, v)
|
return scanWithInterceptors[*{{ $builder }}, *{{ $selectBuilder }}](ctx, {{ $selectReceiver }}.{{ $.QueryName }}, {{ $selectReceiver }}, {{ $selectReceiver }}.inters, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
{{ with extend $ "Builder" $selectBuilder }}
|
{{ with extend $ "Receiver" $selectReceiver "Builder" $selectBuilder }}
|
||||||
{{ $tmpl := printf "dialect/%s/select" $.Storage }}
|
{{ $tmpl := printf "dialect/%s/select" $.Storage }}
|
||||||
{{ xtemplate $tmpl . }}
|
{{ xtemplate $tmpl . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ func ({{ $receiver }} *{{ $builder }}) ExecX(ctx context.Context) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{{ with extend $ "Receiver" $receiver "Package" $pkg "Builder" $builder }}
|
{{ with extend $ "Receiver" $receiver "Builder" $builder "Package" $pkg }}
|
||||||
{{ template "update/checks" . }}
|
{{ template "update/checks" . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
@@ -86,7 +86,7 @@ func ({{ $receiver }} *{{ $builder }}) ExecX(ctx context.Context) {
|
|||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
{{ $onebuilder := $.UpdateOneName }}
|
{{ $onebuilder := $.UpdateOneName }}
|
||||||
{{ $receiver = receiver $onebuilder }}
|
{{ $receiver = $.UpdateOneReceiver }}
|
||||||
{{ $mutation = print $receiver ".mutation" }}
|
{{ $mutation = print $receiver ".mutation" }}
|
||||||
|
|
||||||
// {{ $onebuilder }} is the builder for updating a single {{ $.Name }} entity.
|
// {{ $onebuilder }} is the builder for updating a single {{ $.Name }} entity.
|
||||||
@@ -154,7 +154,7 @@ func ({{ $receiver }} *{{ $onebuilder }}) ExecX(ctx context.Context) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{{ with extend $ "Receiver" $receiver "Package" $pkg "Builder" $onebuilder }}
|
{{ with extend $ "Receiver" $receiver "Builder" $onebuilder "Package" $pkg }}
|
||||||
{{ template "update/checks" . }}
|
{{ template "update/checks" . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "dialect/gremlin/group" }}
|
{{ define "dialect/gremlin/group" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) gremlinScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
func ({{ $receiver }} *{{ $builder }}) gremlinScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
||||||
var (
|
var (
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "dialect/gremlin/query" }}
|
{{ define "dialect/gremlin/query" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) gremlinAll(ctx context.Context, hooks ...queryHook) ([]*{{ $.Name }}, error) {
|
func ({{ $receiver }} *{{ $builder }}) gremlinAll(ctx context.Context, hooks ...queryHook) ([]*{{ $.Name }}, error) {
|
||||||
res := &gremlin.Response{}
|
res := &gremlin.Response{}
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "dialect/gremlin/select" }}
|
{{ define "dialect/gremlin/select" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) gremlinScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
func ({{ $receiver }} *{{ $builder }}) gremlinScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
||||||
var (
|
var (
|
||||||
|
|||||||
@@ -85,7 +85,7 @@ type predicateAdder interface {
|
|||||||
|
|
||||||
{{ range $i, $n := $.Nodes }}
|
{{ range $i, $n := $.Nodes }}
|
||||||
{{ $builder := $n.QueryName }}
|
{{ $builder := $n.QueryName }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $n.QueryReceiver }}
|
||||||
{{ $mutation := $n.MutationName }}
|
{{ $mutation := $n.MutationName }}
|
||||||
{{ $filter := print $n.FilterName }}
|
{{ $filter := print $n.FilterName }}
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "helper/sqlock" }}
|
{{ define "helper/sqlock" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
// ForUpdate locks the selected rows against concurrent updates, and prevent them from being
|
// ForUpdate locks the selected rows against concurrent updates, and prevent them from being
|
||||||
// updated, deleted or "selected ... for update" by other sessions, until the transaction is
|
// updated, deleted or "selected ... for update" by other sessions, until the transaction is
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{/* Template for adding the "executing" the list of modifiers on the sql.Selector. */}}
|
{{/* Template for adding the "executing" the list of modifiers on the sql.Selector. */}}
|
||||||
{{ define "dialect/sql/query/selector/modify" }}
|
{{ define "dialect/sql/query/selector/modify" }}
|
||||||
{{- if or ($.FeatureEnabled "sql/lock") ($.FeatureEnabled "sql/modifier") }}
|
{{- if or ($.FeatureEnabled "sql/lock") ($.FeatureEnabled "sql/modifier") }}
|
||||||
{{- $receiver := pascal $.Scope.Builder | receiver }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
for _, m := range {{ $receiver }}.modifiers {
|
for _, m := range {{ $receiver }}.modifiers {
|
||||||
m(selector)
|
m(selector)
|
||||||
}
|
}
|
||||||
@@ -28,7 +28,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{/* Template for passing the modifiers to the sqlgraph.QuerySpec. */}}
|
{{/* Template for passing the modifiers to the sqlgraph.QuerySpec. */}}
|
||||||
{{ define "dialect/sql/query/spec/modify" }}
|
{{ define "dialect/sql/query/spec/modify" }}
|
||||||
{{- if or ($.FeatureEnabled "sql/lock") ($.FeatureEnabled "sql/modifier") }}
|
{{- if or ($.FeatureEnabled "sql/lock") ($.FeatureEnabled "sql/modifier") }}
|
||||||
{{- $receiver := pascal $.Scope.Builder | receiver }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
if len({{ $receiver }}.modifiers) > 0 {
|
if len({{ $receiver }}.modifiers) > 0 {
|
||||||
_spec.Modifiers = {{ $receiver }}.modifiers
|
_spec.Modifiers = {{ $receiver }}.modifiers
|
||||||
}
|
}
|
||||||
@@ -39,7 +39,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ define "dialect/sql/query/additional/modify" }}
|
{{ define "dialect/sql/query/additional/modify" }}
|
||||||
{{ if $.FeatureEnabled "sql/modifier" }}
|
{{ if $.FeatureEnabled "sql/modifier" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
{{ $selectBuilder := pascal $.Name | printf "%sSelect" }}
|
{{ $selectBuilder := pascal $.Name | printf "%sSelect" }}
|
||||||
// Modify adds a query modifier for attaching custom logic to queries.
|
// Modify adds a query modifier for attaching custom logic to queries.
|
||||||
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(s *sql.Selector)) *{{ $selectBuilder }} {
|
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(s *sql.Selector)) *{{ $selectBuilder }} {
|
||||||
@@ -53,7 +53,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ define "dialect/sql/select/additional/modify" }}
|
{{ define "dialect/sql/select/additional/modify" }}
|
||||||
{{ if $.FeatureEnabled "sql/modifier" }}
|
{{ if $.FeatureEnabled "sql/modifier" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
// Modify adds a query modifier for attaching custom logic to queries.
|
// Modify adds a query modifier for attaching custom logic to queries.
|
||||||
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(s *sql.Selector)) *{{ $builder }} {
|
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(s *sql.Selector)) *{{ $builder }} {
|
||||||
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifiers...)
|
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifiers...)
|
||||||
@@ -74,7 +74,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ if $.FeatureEnabled "sql/modifier" }}
|
{{ if $.FeatureEnabled "sql/modifier" }}
|
||||||
{{ $pkg := $.Scope.Package }}
|
{{ $pkg := $.Scope.Package }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
// Modify adds a statement modifier for attaching custom logic to the UPDATE statement.
|
// Modify adds a statement modifier for attaching custom logic to the UPDATE statement.
|
||||||
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(u *sql.UpdateBuilder)) *{{ $builder }} {
|
func ({{ $receiver }} *{{ $builder }}) Modify(modifiers ...func(u *sql.UpdateBuilder)) *{{ $builder }} {
|
||||||
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifiers...)
|
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifiers...)
|
||||||
@@ -86,7 +86,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{/* Template for passing the modifiers to the sqlgraph.UpdateSpec. */}}
|
{{/* Template for passing the modifiers to the sqlgraph.UpdateSpec. */}}
|
||||||
{{ define "dialect/sql/update/spec/modify" }}
|
{{ define "dialect/sql/update/spec/modify" }}
|
||||||
{{- if $.FeatureEnabled "sql/modifier" }}
|
{{- if $.FeatureEnabled "sql/modifier" }}
|
||||||
{{- $receiver := pascal $.Scope.Builder | receiver }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
_spec.AddModifiers({{ $receiver }}.modifiers...)
|
_spec.AddModifiers({{ $receiver }}.modifiers...)
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
@@ -66,7 +66,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ define "dialect/sql/query/additional/namedges" }}
|
{{ define "dialect/sql/query/additional/namedges" }}
|
||||||
{{- if $.FeatureEnabled "namedges" }}
|
{{- if $.FeatureEnabled "namedges" }}
|
||||||
{{ $builder := $.QueryName }}
|
{{ $builder := $.QueryName }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.QueryReceiver }}
|
||||||
{{- range $e := $.Edges }}
|
{{- range $e := $.Edges }}
|
||||||
{{- if not $e.Unique }}
|
{{- if not $e.Unique }}
|
||||||
{{ $ebuilder := $e.Type.QueryName }}
|
{{ $ebuilder := $e.Type.QueryName }}
|
||||||
@@ -93,7 +93,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{- define "dialect/sql/query/all/nodes/namedges" }}
|
{{- define "dialect/sql/query/all/nodes/namedges" }}
|
||||||
{{- if $.FeatureEnabled "namedges" }}
|
{{- if $.FeatureEnabled "namedges" }}
|
||||||
{{- $builder := pascal $.Scope.Builder }}
|
{{- $builder := pascal $.Scope.Builder }}
|
||||||
{{- $receiver := receiver $builder }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
{{- range $e := $.Edges }}
|
{{- range $e := $.Edges }}
|
||||||
{{- if not $e.Unique }}
|
{{- if not $e.Unique }}
|
||||||
for name, query := range {{ $receiver }}.{{ $e.EagerLoadNamedField }} {
|
for name, query := range {{ $receiver }}.{{ $e.EagerLoadNamedField }} {
|
||||||
|
|||||||
@@ -100,7 +100,7 @@ func NewSchemaConfigContext(parent context.Context, config SchemaConfig) context
|
|||||||
{{- define "dialect/sql/defedge/spec/schemaconfig" }}
|
{{- define "dialect/sql/defedge/spec/schemaconfig" }}
|
||||||
{{- $e := $.Scope.Edge }}
|
{{- $e := $.Scope.Edge }}
|
||||||
{{- $builder := pascal $.Scope.Builder }}
|
{{- $builder := pascal $.Scope.Builder }}
|
||||||
{{- $receiver := receiver $builder }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
{{- $ident := "edge" }}{{ with $.Scope.Ident }}{{ $ident = . }}{{ end }}
|
{{- $ident := "edge" }}{{ with $.Scope.Ident }}{{ $ident = . }}{{ end }}
|
||||||
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
||||||
{{- $schema := $e.Type.Name }}
|
{{- $schema := $e.Type.Name }}
|
||||||
@@ -126,7 +126,7 @@ func NewSchemaConfigContext(parent context.Context, config SchemaConfig) context
|
|||||||
{{/* A template for injecting the SchemaConfig to the context. Should be executed before other templates. */}}
|
{{/* A template for injecting the SchemaConfig to the context. Should be executed before other templates. */}}
|
||||||
{{- define "dialect/sql/spec/ctxschemaconfig" -}}
|
{{- define "dialect/sql/spec/ctxschemaconfig" -}}
|
||||||
{{- $builder := pascal $.Scope.Builder }}
|
{{- $builder := pascal $.Scope.Builder }}
|
||||||
{{- $receiver := receiver $builder }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
{{- $ident := "_spec.Node" }}{{ with $.Scope.Ident }}{{ $ident = . }}{{ end }}
|
{{- $ident := "_spec.Node" }}{{ with $.Scope.Ident }}{{ $ident = . }}{{ end }}
|
||||||
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
||||||
{{ $ident }}.Schema = {{ $receiver }}.schemaConfig.{{ $.Name }}
|
{{ $ident }}.Schema = {{ $receiver }}.schemaConfig.{{ $.Name }}
|
||||||
@@ -138,7 +138,7 @@ func NewSchemaConfigContext(parent context.Context, config SchemaConfig) context
|
|||||||
|
|
||||||
{{- define "dialect/sql/query/selector/ctxschemaconfig" -}}
|
{{- define "dialect/sql/query/selector/ctxschemaconfig" -}}
|
||||||
{{- $builder := pascal $.Scope.Builder }}
|
{{- $builder := pascal $.Scope.Builder }}
|
||||||
{{- $receiver := receiver $builder }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
{{- if $.FeatureEnabled "sql/schemaconfig" }}
|
||||||
t1.Schema({{ $receiver }}.schemaConfig.{{ $.Name }})
|
t1.Schema({{ $receiver }}.schemaConfig.{{ $.Name }})
|
||||||
ctx = internal.NewSchemaConfigContext(ctx, {{ $receiver }}.schemaConfig)
|
ctx = internal.NewSchemaConfigContext(ctx, {{ $receiver }}.schemaConfig)
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "dialect/sql/group" }}
|
{{ define "dialect/sql/group" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) sqlScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
func ({{ $receiver }} *{{ $builder }}) sqlScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
||||||
selector := root.sqlQuery(ctx).Select()
|
selector := root.sqlQuery(ctx).Select()
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
{{ define "dialect/sql/query" }}
|
{{ define "dialect/sql/query" }}
|
||||||
{{ $pkg := $.Scope.Package }}
|
{{ $pkg := $.Scope.Package }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) sqlAll(ctx context.Context, hooks ...queryHook) ([]*{{ $.Name }}, error) {
|
func ({{ $receiver }} *{{ $builder }}) sqlAll(ctx context.Context, hooks ...queryHook) ([]*{{ $.Name }}, error) {
|
||||||
var (
|
var (
|
||||||
@@ -353,7 +353,7 @@ func ({{ $receiver }} *{{ $builder }}) querySpec() *sqlgraph.QuerySpec {
|
|||||||
|
|
||||||
{{ define "dialect/sql/query/selector" }}
|
{{ define "dialect/sql/query/selector" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) sqlQuery(ctx context.Context) *sql.Selector {
|
func ({{ $receiver }} *{{ $builder }}) sqlQuery(ctx context.Context) *sql.Selector {
|
||||||
{{- $builderV := "builder" }}{{ if eq $.Package $builderV }}{{ $builderV = "builderC" }}{{ end }}
|
{{- $builderV := "builder" }}{{ if eq $.Package $builderV }}{{ $builderV = "builderC" }}{{ end }}
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ in the LICENSE file in the root directory of this source tree.
|
|||||||
|
|
||||||
{{ define "dialect/sql/select" }}
|
{{ define "dialect/sql/select" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
|
|
||||||
func ({{ $receiver }} *{{ $builder }}) sqlScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
func ({{ $receiver }} *{{ $builder }}) sqlScan(ctx context.Context, root *{{ $.QueryName }}, v any) error {
|
||||||
selector := root.sqlQuery(ctx)
|
selector := root.sqlQuery(ctx)
|
||||||
|
|||||||
@@ -823,6 +823,15 @@ func (t Type) QueryName() string {
|
|||||||
return pascal(t.Name) + "Query"
|
return pascal(t.Name) + "Query"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// QueryReceiver returns the receiver name of the query-builder for this type.
|
||||||
|
func (t Type) QueryReceiver() string {
|
||||||
|
r := receiver(t.QueryName())
|
||||||
|
if t.Package() == r {
|
||||||
|
return "_" + r
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
// FilterName returns the struct name denoting the filter-builder for this type.
|
// FilterName returns the struct name denoting the filter-builder for this type.
|
||||||
func (t Type) FilterName() string {
|
func (t Type) FilterName() string {
|
||||||
return pascal(t.Name) + "Filter"
|
return pascal(t.Name) + "Filter"
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
{{/* A template for adding the Modify method to the query builder. */}}
|
{{/* A template for adding the Modify method to the query builder. */}}
|
||||||
{{ define "dialect/sql/query/additional/modify" }}
|
{{ define "dialect/sql/query/additional/modify" }}
|
||||||
{{ $builder := pascal $.Scope.Builder }}
|
{{ $builder := pascal $.Scope.Builder }}
|
||||||
{{ $receiver := receiver $builder }}
|
{{ $receiver := $.Scope.Receiver }}
|
||||||
func ({{ $receiver }} *{{ $builder }}) Modify(modifier func(s *sql.Selector)) *{{ $builder }} {
|
func ({{ $receiver }} *{{ $builder }}) Modify(modifier func(s *sql.Selector)) *{{ $builder }} {
|
||||||
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifier)
|
{{ $receiver }}.modifiers = append({{ $receiver }}.modifiers, modifier)
|
||||||
return {{ $receiver }}
|
return {{ $receiver }}
|
||||||
@@ -16,14 +16,14 @@
|
|||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
{{ define "dialect/sql/query/selector/modify" }}
|
{{ define "dialect/sql/query/selector/modify" }}
|
||||||
{{- $receiver := pascal $.Scope.Builder | receiver }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
for _, m := range {{ $receiver }}.modifiers {
|
for _, m := range {{ $receiver }}.modifiers {
|
||||||
m(selector)
|
m(selector)
|
||||||
}
|
}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
|
|
||||||
{{ define "dialect/sql/query/spec/modify" }}
|
{{ define "dialect/sql/query/spec/modify" }}
|
||||||
{{- $receiver := pascal $.Scope.Builder | receiver }}
|
{{- $receiver := $.Scope.Receiver }}
|
||||||
if len({{ $receiver }}.modifiers) > 0 {
|
if len({{ $receiver }}.modifiers) > 0 {
|
||||||
_spec.Modifiers = {{ $receiver }}.modifiers
|
_spec.Modifiers = {{ $receiver }}.modifiers
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user