/*
* Copyright 2014 Google Inc. All rights reserved.
*
* 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
*
* http://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.
*/
#ifndef FRUIT_BINDINGS_H
#define FRUIT_BINDINGS_H
#include <fruit/impl/meta/metaprogramming.h>
namespace fruit {
namespace impl {
// The types here represent individual entries added in a PartialComponent.
/**
* Binds the base class I to the implementation C.
* I must be a base class of C. I=C is not allowed.
* I and/or C may be annotated using fruit::Annotated<>.
*/
template <typename I, typename C>
struct Bind {};
/**
* Registers Signature as the constructor signature to use to inject a type.
* Signature must be a valid signature and its return type must be constructible with those argument
* types.
* The arguments and the return type can be annotated using fruit::Annotated<>.
*/
template <typename Signature>
struct RegisterConstructor {};
/**
* Binds an instance (i.e., object) to the type C.
* AnnotatedC may be annotated using fruit::Annotated<>.
* NOTE: for this binding, the runtime binding is added in advance.
*/
template <typename AnnotatedC, typename C>
struct BindInstance {};
/**
* A variant of BindInstance that binds a constant reference.
*/
template <typename AnnotatedC, typename C>
struct BindConstInstance {};
template <typename... Params>
struct RegisterProvider;
/**
* Registers `provider' as a provider of C, where provider is a lambda with no captures returning
* either C or C*.
*/
template <typename Lambda>
struct RegisterProvider<Lambda> {};
/**
* Registers `provider' as a provider of C, where provider is a lambda with no captures returning
* either C or C*. Lambda must have the signature AnnotatedSignature (ignoring annotations).
*/
template <typename AnnotatedSignature, typename Lambda>
struct RegisterProvider<Lambda, AnnotatedSignature> {};
/**
* Adds a multibinding for an instance (as a C&).
*/
template <typename C>
struct AddInstanceMultibinding {};
/**
* Adds multibindings for a vector of instances (as a std::vector<C>&).
*/
template <typename C>
struct AddInstanceVectorMultibindings {};
/**
* Similar to Bind<I, C>, but adds a multibinding instead.
*/
template <typename I, typename C>
struct AddMultibinding {};
template <typename... Params>
struct AddMultibindingProvider;
/**
* Similar to RegisterProvider, but adds a multibinding instead.
*/
template <typename Lambda>
struct AddMultibindingProvider<Lambda> {};
/**
* Similar to RegisterProvider, but adds a multibinding instead.
* Lambda must have the signature AnnotatedSignature (ignoring annotations).
*/
template <typename AnnotatedSignature, typename Lambda>
struct AddMultibindingProvider<AnnotatedSignature, Lambda> {};
/**
* Registers `Lambda' as a factory of C, where `Lambda' is a lambda with no captures returning C.
* Lambda must have signature DecoratedSignature (ignoring any fruit::Annotated<> and
* fruit::Assisted<>).
* Lambda must return a C by value, or a std::unique_ptr<C>.
*/
template <typename DecoratedSignature, typename Lambda>
struct RegisterFactory {};
/**
* Adds the bindings (and multibindings) in `component' to the current component.
* OtherComponent must be of the form Component<...>.
* NOTE: for this binding, the runtime binding is added in advance.
*/
template <typename GetComponentFunction>
struct InstallComponent {};
/**
* Installs all the specified ComponentFunction objects.
*/
template <typename... ComponentFunctions>
struct InstallComponentFunctions {};
/**
* An in-progress ReplaceComponent operation, where we don't have all the required information yet.
*/
template <typename GetReplacedComponent>
struct PartialReplaceComponent {};
/**
* Replaces install()s for a component with install()s for another one.
* The two Get*Component function signatures must return the same Component<...> type.
*/
template <typename GetReplacedComponent, typename GetReplacementComponent>
struct ReplaceComponent {};
} // namespace impl
} // namespace fruit
#endif // FRUIT_BINDINGS_H