| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 // This defines helpful methods for dealing with Callbacks. Because Callbacks | |
| 6 // are implemented using templates, with a class per callback signature, adding | |
| 7 // methods to Callback<> itself is unattractive (lots of extra code gets | |
| 8 // generated). Instead, consider adding methods here. | |
| 9 // | |
| 10 // ResetAndReturn(&cb) is like cb.Reset() but allows executing a callback (via a | |
| 11 // copy) after the original callback is Reset(). This can be handy if Run() | |
| 12 // reads/writes the variable holding the Callback. | |
| 13 | |
| 14 #ifndef BASE_CALLBACK_HELPERS_H_ | |
| 15 #define BASE_CALLBACK_HELPERS_H_ | |
| 16 | |
| 17 #include "base/basictypes.h" | |
| 18 #include "base/callback.h" | |
| 19 #include "base/compiler_specific.h" | |
| 20 | |
| 21 namespace base { | |
| 22 | |
| 23 template <typename Sig> | |
| 24 base::Callback<Sig> ResetAndReturn(base::Callback<Sig>* cb) { | |
| 25 base::Callback<Sig> ret(*cb); | |
| 26 cb->Reset(); | |
| 27 return ret; | |
| 28 } | |
| 29 | |
| 30 // ScopedClosureRunner is akin to scoped_ptr for Closures. It ensures that the | |
| 31 // Closure is executed and deleted no matter how the current scope exits. | |
| 32 class BASE_EXPORT ScopedClosureRunner { | |
| 33 public: | |
| 34 ScopedClosureRunner(); | |
| 35 explicit ScopedClosureRunner(const Closure& closure); | |
| 36 ~ScopedClosureRunner(); | |
| 37 | |
| 38 void Reset(); | |
| 39 void Reset(const Closure& closure); | |
| 40 Closure Release() WARN_UNUSED_RESULT; | |
| 41 | |
| 42 private: | |
| 43 Closure closure_; | |
| 44 | |
| 45 DISALLOW_COPY_AND_ASSIGN(ScopedClosureRunner); | |
| 46 }; | |
| 47 | |
| 48 } // namespace base | |
| 49 | |
| 50 #endif // BASE_CALLBACK_HELPERS_H_ | |
| OLD | NEW |