Index: base/mac/bind_objc_block.h |
diff --git a/base/mac/bind_objc_block.h b/base/mac/bind_objc_block.h |
index 9deb2d22e75c5add2da220e47898060eca0f53b7..3aa7e0d7eef8772b683c38b868b1ee3a49c61b99 100644 |
--- a/base/mac/bind_objc_block.h |
+++ b/base/mac/bind_objc_block.h |
@@ -45,6 +45,12 @@ R RunBlock(base::mac::ScopedBlock<R(^)(A1, A2)> block, A1 a, A2 b) { |
return extracted_block(a, b); |
} |
+template<typename R, typename A1, typename A2, typename A3> |
+R RunBlock(base::mac::ScopedBlock<R(^)(A1, A2, A3)> block, A1 a, A2 b, A3 c) { |
+ R(^extracted_block)(A1, A2, A3) = block.get(); |
+ return extracted_block(a, b, c); |
Nico
2014/11/06 17:44:47
Can you make RunBlock() a variadic template? Then
marq (ping after 24h)
2014/11/07 09:00:55
Done, and BindBlock() is now also variadic.
|
+} |
+ |
} // namespace internal |
// Construct a callback with no argument from an objective-C block. |
@@ -68,6 +74,14 @@ base::Callback<R(A1, A2)> BindBlock(R(^block)(A1, A2)) { |
base::mac::ScopedBlock<R(^)(A1, A2)>(Block_copy(block))); |
} |
+// Construct a callback with three arguments from an objective-C block. |
+template<typename R, typename A1, typename A2, typename A3> |
+base::Callback<R(A1, A2, A3)> BindBlock(R(^block)(A1, A2, A3)) { |
+ return base::Bind(&base::internal::RunBlock<R, A1, A2, A3>, |
+ base::mac::ScopedBlock<R(^)(A1, A2, A3)>( |
+ Block_copy(block))); |
+} |
+ |
} // namespace base |
#endif // BASE_MAC_BIND_OBJC_BLOCK_H_ |