Documentation ¶
Index ¶
- func AddTagOf[TAG any](c *Component, tag TAG)
- func All(_ *Component) bool
- func CloseAll(ball *Ball, timeout time.Duration) error
- func DependsOn[BASE any, DEPENDENCY any](ball *Ball)
- func Dereference[A any](a *A) A
- func DisableImplementation[BASE any](ball *Ball)
- func DisableImplementationOf(c *Component)
- func Dot(w io.Writer, components []*Component) (err error)
- func DotAll(w io.Writer, ball *Ball) (err error)
- func Execute[A any](ctx context.Context, ball *Ball, factory interface{}, options ...any) (A, error)
- func Execute0(ctx context.Context, ball *Ball, factory interface{}) error
- func Factory[A any](ball *Ball, factory interface{})
- func ForEach(ball *Ball, callback func(component *Component) error, ...) error
- func ForEachDependency(ball *Ball, target ComponentSelector, ...) error
- func ForEachDependencyReverse(ball *Ball, target ComponentSelector, ...) error
- func GenerateComponentsGraph(fileprefix string, components []*Component) error
- func GetTag[A any, Tag any](ball *Ball) (Tag, bool)
- func GetTagOf[Tag any](c *Component) (Tag, bool)
- func Implementation[L ~[]T, Instance any, T any](ball *Ball)
- func Initialize(ctx context.Context) func(c *Component) error
- func MustGenerateGraph(ball *Ball, fileprefix string, selector ComponentSelector)
- func MustLookup[T any](ball *Ball) T
- func Provide[A any](ball *Ball, factory interface{}, options ...any)
- func RegisterImplementation[L ~[]T, T any](ball *Ball)
- func RegisterInterfaceImplementation[BASE any, DEP any](ball *Ball)
- func RegisterManual[T any](ball *Ball, factory func(ctx context.Context) (T, error))
- func RemoveTag[A any, Tag any](ball *Ball)
- func RemoveTagOf[TAG any](c *Component)
- func ReplaceDependency[BASE any, DEP any](ball *Ball)
- func ReplaceDependencyOf(from *Component, to *Component)
- func RunWithDependencies(ctx context.Context, ball *Ball, selector ComponentSelector) error
- func Supply[T any](ball *Ball, t T)
- func Tag[A any, Tag any](ball *Ball, tag Tag)
- func Tagged[Tag any]() func(c *Component) bool
- func View[From any, To any](ball *Ball, convert func(From) To)
- type Ball
- type Component
- func (c *Component) Close(ctx context.Context) error
- func (c *Component) GetTarget() reflect.Type
- func (c *Component) ID() string
- func (c *Component) Init(ctx context.Context) error
- func (c *Component) Instance() any
- func (c *Component) Name() string
- func (c *Component) Run(ctx context.Context, eg *errgroup.Group) error
- func (c *Component) String() string
- type ComponentSelector
- type CustomDotNode
- type Injector
- type Interface
- type Nullable
- type Optional
- type Stage
- type StageName
- type Wrapper
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func DependsOn ¶
DependsOn creates a dependency relation between two components. With the help of the dependency graph, they can be executed in the right order.
func Dereference ¶
func Dereference[A any](a *A) A
Dereference is a simple transformation to make real value from a pointer. Useful with View. for example: `View[*DB, DB](ball, Dereference[DB])`.
func DisableImplementation ¶
DisableImplementation removes the implementation from the list of dependencies.
func DisableImplementationOf ¶
func DisableImplementationOf(c *Component)
DisableImplementationOf is like DisableImplementation, but using components instead of generics.
func Dot ¶
Dot generates graph report of the modules in dot format, but only the selected components are included.
func Execute ¶
func Execute[A any](ctx context.Context, ball *Ball, factory interface{}, options ...any) (A, error)
Execute executes a function with injecting all the required dependencies with type based Dependency Injection.
func Execute0 ¶
Execute0 executes a function with injection all required parameters. Same as Execute but without return type.
func Factory ¶
Factory is like Provide, but instead of storing an instance in the component, it stores a factory function. factory function is called each time when the instance is required. Useful for logger, which requires further adjustment when it's injected.
func ForEach ¶
func ForEach(ball *Ball, callback func(component *Component) error, selectors ...ComponentSelector) error
ForEach executes a callback action on all the selected components.
func ForEachDependency ¶
func ForEachDependency(ball *Ball, target ComponentSelector, callback func(component *Component) error, selectors ...ComponentSelector) error
ForEachDependency executes a callback action on all the components, matching the target selector and dependencies, but only if selectors parameter is matching them.
func ForEachDependencyReverse ¶
func ForEachDependencyReverse(ball *Ball, target ComponentSelector, callback func(component *Component) error, selectors ...ComponentSelector) error
ForEachDependencyReverse executes a callback action on all the components in reverse order, matching the target selector and dependencies, but only if selectors parameter is matching them.
func GenerateComponentsGraph ¶
GenerateComponentsGraph generates dot and svg file including the selected components.
func Implementation ¶
Implementation registers a new []T component, which will be filled with any registered instances. Instances will be marked with "Optional{}" tag, and will be injected only, if they are initialized. It's the responsibility of the Init code to exclude / include them during initialization.
func Initialize ¶
Initialize components as ForEach callback.
func MustGenerateGraph ¶
func MustGenerateGraph(ball *Ball, fileprefix string, selector ComponentSelector)
MustGenerateGraph generates dot and svg files from components selected by the selector.
func MustLookup ¶
MustLookup returns with the registered component instance (or panic).
func Provide ¶
Provide registers a new instance to the dependency pool. Run/Close methods are auto-detected (stage is created if they exist).
func RegisterImplementation ¶
RegisterImplementation registers the implementation interface, without adding concrete implementation.
func RegisterInterfaceImplementation ¶
RegisterInterfaceImplementation registers an interface with an implementation. Later the implementation can be replaced. Only one (or zero) implementation can be registered/used at the same time.
func RegisterManual ¶
RegisterManual registers a component manually. Most of the time you need either Provide or View instead of this.
func RemoveTagOf ¶
RemoveTagOf removes all the Tag type of tags from the component.
func ReplaceDependency ¶
ReplaceDependency replaces the dependency of a component. Can be used to switch to an alternative implementation.
func ReplaceDependencyOf ¶
ReplaceDependencyOf is like ReplaceDependency but using components instead of generics.
func RunWithDependencies ¶
func RunWithDependencies(ctx context.Context, ball *Ball, selector ComponentSelector) error
RunWithDependencies will init and run all components which are matched by the selector.
Types ¶
type Ball ¶
type Ball struct {
// contains filtered or unexported fields
}
Ball is the component registry.
Example ¶
ball := NewBall() Provide[string](ball, func() string { return "test" }) Provide[string](ball, func() string { return "test" }) components := Find(ball, All) _ = components[0].Init(context.Background()) fmt.Println(components[0].Instance())
Output:
type Component ¶
type Component struct {
// contains filtered or unexported fields
}
Component manages the lifecycle of a singleton Golang struct.
func Find ¶
func Find(ball *Ball, selector ComponentSelector) (result []*Component)
Find selects components matching the selector.
func FindSelectedWithDependencies ¶
func FindSelectedWithDependencies(ball *Ball, selector ComponentSelector) (result []*Component)
FindSelectedWithDependencies selects components matching the selector, together with all the dependencies.
func MustLookupComponent ¶
MustLookupComponent gets the component (or panics if doesn't exist) based on a type.
func (*Component) Instance ¶
Instance returns the singleton instance of the component. Can be null, if not yet initialized.
type ComponentSelector ¶
ComponentSelector can filter components.
func And ¶
func And(selectors ...ComponentSelector) ComponentSelector
And selects components which matches all the selectors.
func ImplementationOf ¶
func ImplementationOf[L ~[]T, T any](ball *Ball) ComponentSelector
ImplementationOf is a ForEach filter to get all the dependency of an implementation.
func Or ¶
func Or(selectors ...ComponentSelector) ComponentSelector
Or selects components which matches any of the selectors.
func Select ¶
func Select[A any](ball *Ball) ComponentSelector
Select is a component selector based on the specified type ([A]).
type CustomDotNode ¶
type CustomDotNode interface { // CustomizeDotNode can replace / modify entries, which are key=value parameters of graphviz dot. CustomizeDotNode(tags []string) []string }
CustomDotNode is an interface that can be implemented by a component to customize the SVG output for debugging..
type Interface ¶
type Interface struct { }
Interface is a marker tag, to make it easier to list all possible extension points. Only used for debug / helper commands.
func (Interface) CustomizeDotNode ¶
CustomizeDotNode customize the graphical representation of the node in the graph, when rendered for debugging.
type Nullable ¶
type Nullable struct { }
Nullable is a custom tag, which enables injecting null value, even if the component is not initialized.
type Optional ¶
type Optional struct{}
Optional tag is used to mark components which may not required.
type Stage ¶
type Stage struct {
// contains filtered or unexported fields
}
Stage represents a function which should be called on the component at the right time (like start, stop, init).