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