2018-05-01 14:46:39 -04:00
|
|
|
// Copyright 2018 Google LLC
|
|
|
|
|
//
|
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
//
|
|
|
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
//
|
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
2018-04-27 13:44:54 -04:00
|
|
|
// Package goose contains directives for goose code generation.
|
|
|
|
|
package goose
|
|
|
|
|
|
|
|
|
|
// ProviderSet is a marker type that collects a group of providers.
|
|
|
|
|
type ProviderSet struct{}
|
|
|
|
|
|
|
|
|
|
// NewSet creates a new provider set that includes the providers in
|
|
|
|
|
// its arguments. Each argument is either an exported function value,
|
2018-05-25 12:36:39 -07:00
|
|
|
// an exported struct (zero) value, a provider set, a call to Bind, or
|
|
|
|
|
// a call to Value.
|
2018-04-27 13:44:54 -04:00
|
|
|
func NewSet(...interface{}) ProviderSet {
|
|
|
|
|
return ProviderSet{}
|
|
|
|
|
}
|
|
|
|
|
|
2018-05-24 14:29:05 -07:00
|
|
|
// Build is placed in the body of an injector function to declare the
|
2018-04-27 13:44:54 -04:00
|
|
|
// providers to use. Its arguments are the same as NewSet. Its return
|
|
|
|
|
// value is an error message that can be sent to panic.
|
|
|
|
|
//
|
|
|
|
|
// Example:
|
|
|
|
|
//
|
|
|
|
|
// func injector(ctx context.Context) (*sql.DB, error) {
|
2018-05-25 12:36:39 -07:00
|
|
|
// panic(goose.Build(otherpkg.FooSet, myProviderFunc))
|
2018-04-27 13:44:54 -04:00
|
|
|
// }
|
2018-05-24 14:29:05 -07:00
|
|
|
func Build(...interface{}) string {
|
2018-04-27 13:44:54 -04:00
|
|
|
return "implementation not generated, run goose"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// A Binding maps an interface to a concrete type.
|
|
|
|
|
type Binding struct{}
|
|
|
|
|
|
|
|
|
|
// Bind declares that a concrete type should be used to satisfy a
|
2018-05-29 08:45:14 -07:00
|
|
|
// dependency on the type of iface, which must be a pointer to an
|
|
|
|
|
// interface type.
|
2018-04-27 13:44:54 -04:00
|
|
|
//
|
|
|
|
|
// Example:
|
|
|
|
|
//
|
2018-05-29 08:45:14 -07:00
|
|
|
// var MySet = goose.NewSet(goose.Bind(new(MyInterface), new(MyStruct)))
|
2018-04-27 13:44:54 -04:00
|
|
|
func Bind(iface, to interface{}) Binding {
|
|
|
|
|
return Binding{}
|
|
|
|
|
}
|
2018-05-04 12:44:53 -04:00
|
|
|
|
|
|
|
|
// A ProvidedValue is an expression that is copied to the generated injector.
|
|
|
|
|
type ProvidedValue struct{}
|
|
|
|
|
|
|
|
|
|
// Value binds an expression to provide the type of the expression.
|
|
|
|
|
//
|
|
|
|
|
// Example:
|
|
|
|
|
//
|
|
|
|
|
// var MySet = goose.NewSet(goose.Value([]string(nil)))
|
|
|
|
|
func Value(interface{}) ProvidedValue {
|
|
|
|
|
return ProvidedValue{}
|
|
|
|
|
}
|