| Index: base/bind.h
|
| diff --git a/base/bind.h b/base/bind.h
|
| index 9cf65b67764b0cbcb393cd392f6fdb480d57496b..5d3b6cba11b7422e0e4f40d8c9313c3b21347f06 100644
|
| --- a/base/bind.h
|
| +++ b/base/bind.h
|
| @@ -23,21 +23,46 @@
|
| // terms and concepts.
|
|
|
| namespace base {
|
| +namespace internal {
|
|
|
| +// Bind as RepeatingCallback.
|
| template <typename Functor, typename... Args>
|
| -inline base::Callback<MakeUnboundRunType<Functor, Args...>> Bind(
|
| - Functor&& functor,
|
| - Args&&... args) {
|
| +inline RepeatingCallback<MakeUnboundRunType<Functor, Args...>>
|
| +BindRepeating(Functor&& functor, Args&&... args) {
|
| using BindState = internal::MakeBindStateType<Functor, Args...>;
|
| using UnboundRunType = MakeUnboundRunType<Functor, Args...>;
|
| using Invoker = internal::Invoker<BindState, UnboundRunType>;
|
|
|
| - using CallbackType = Callback<UnboundRunType>;
|
| + using CallbackType = RepeatingCallback<UnboundRunType>;
|
| return CallbackType(new BindState(std::forward<Functor>(functor),
|
| std::forward<Args>(args)...),
|
| &Invoker::Run);
|
| }
|
|
|
| +// Bind as OneShotCallback.
|
| +template <typename Functor, typename... Args>
|
| +inline OneShotCallback<MakeUnboundRunType<Functor, Args...>>
|
| +BindOneShot(Functor&& functor, Args&&... args) {
|
| + using BindState = internal::MakeBindStateType<Functor, Args...>;
|
| + using UnboundRunType = MakeUnboundRunType<Functor, Args...>;
|
| + using Invoker = internal::Invoker<BindState, UnboundRunType>;
|
| +
|
| + using CallbackType = OneShotCallback<UnboundRunType>;
|
| + return CallbackType(new BindState(std::forward<Functor>(functor),
|
| + std::forward<Args>(args)...),
|
| + &Invoker::RunOneShot);
|
| +}
|
| +
|
| +} // namespace internal
|
| +
|
| +// Unannotated Bind.
|
| +template <typename Functor, typename... Args>
|
| +inline Callback<MakeUnboundRunType<Functor, Args...>>
|
| +Bind(Functor&& functor, Args&&... args) {
|
| + return internal::BindRepeating(std::forward<Functor>(functor),
|
| + std::forward<Args>(args)...);
|
| +}
|
| +
|
| } // namespace base
|
|
|
| #endif // BASE_BIND_H_
|
|
|