$$ This is a pump file for generating file templates. Pump is a python $$ script that is part of the Google Test suite of utilities. Description $$ can be found here: $$ $$ http://code.google.com/p/googletest/wiki/PumpManual $$ $var MAX_ARITY = 7 // Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_BIND_H_ #define BASE_BIND_H_ #pragma once #include "base/bind_internal.h" #include "base/callback_internal.h" // See base/callback.h for how to use these functions. // // IMPLEMENTATION NOTE // Though Bind()'s result is meant to be stored in a Callback<> type, it // cannot actually return the exact type without requiring a large amount // of extra template specializations. The problem is that in order to // discern the correct specialization of Callback<>, Bind would need to // unwrap the function signature to determine the signature's arity, and // whether or not it is a method. // // Each unique combination of (arity, function_type, num_prebound) where // function_type is one of {function, method, const_method} would require // one specialization. We eventually have to do a similar number of // specializations anyways in the implementation (see the FunctionTraitsN, // classes). However, it is avoidable in Bind if we return the result // via an indirection like we do below. namespace base { $range BOUND 0..MAX_ARITY $for BOUND [[ $range BOUND_ARG 1..BOUND $if BOUND == 0 [[ template internal::InvokerStorageHolder > Bind(Sig f) { return internal::MakeInvokerStorageHolder( new internal::InvokerStorage0(f)); } ]] $else [[ template internal::InvokerStorageHolder > Bind(Sig f, $for BOUND_ARG , [[const P$(BOUND_ARG)& p$(BOUND_ARG)]]) { return internal::MakeInvokerStorageHolder( new internal::InvokerStorage$(BOUND)( f, $for BOUND_ARG , [[p$(BOUND_ARG)]])); } ]] ]] $$ for BOUND // Specializations to allow binding all the free arguments in a // pre-existing base::Callback<>. This does not give full support for // currying, but is significantly simpler and addresses the use case // where a base::Callback<> needs to be invoked on another context/thread. $for BOUND [[ $range BOUND_ARG 1..BOUND $if BOUND != 0 [[ template base::Closure Bind(const base::Callback& callback, [[]] $for BOUND_ARG , [[const P$(BOUND_ARG)& p$(BOUND_ARG)]]) { return base::Bind([[]] &internal::BindMoreFunc$(BOUND), [[]] callback, [[]] $for BOUND_ARG , [[p$(BOUND_ARG)]]); } ]] ]] $$ for BOUND } // namespace base #endif // BASE_BIND_H_