Index: ppapi/shared_impl/function_group_base.h |
=================================================================== |
--- ppapi/shared_impl/function_group_base.h (revision 87260) |
+++ ppapi/shared_impl/function_group_base.h (working copy) |
@@ -5,51 +5,48 @@ |
#ifndef PPAPI_SHARED_IMPL_FUNCTION_GROUP_BASE_H_ |
#define PPAPI_SHARED_IMPL_FUNCTION_GROUP_BASE_H_ |
+#include <stddef.h> // For NULL. |
+ |
+#define FOR_ALL_PPAPI_FUNCTION_APIS(F) \ |
+ F(PPB_CharSet_FunctionAPI) \ |
+ F(PPB_CursorControl_FunctionAPI) \ |
+ F(PPB_Find_FunctionAPI) \ |
+ F(PPB_Font_FunctionAPI) \ |
+ F(ResourceCreationAPI) |
+ |
namespace ppapi { |
+// Forward declare all the function APIs. |
namespace thunk { |
-class PPB_CharSet_FunctionAPI; |
-class PPB_CursorControl_FunctionAPI; |
-class PPB_Font_FunctionAPI; |
-class ResourceCreationAPI; |
-} |
+#define DECLARE_FUNCTION_CLASS(FUNCTIONS) class FUNCTIONS; |
+FOR_ALL_PPAPI_FUNCTION_APIS(DECLARE_FUNCTION_CLASS) |
+#undef DECLARE_FUNCTION_CLASS |
+} // namespace thunk |
class FunctionGroupBase { |
public: |
+ virtual ~FunctionGroupBase(); |
+ |
// Dynamic casting for this object. Returns the pointer to the given type if |
- // it's supported. |
- virtual thunk::PPB_CharSet_FunctionAPI* AsCharSet_FunctionAPI() { |
- return NULL; |
- } |
- virtual thunk::PPB_CursorControl_FunctionAPI* AsCursorControl_FunctionAPI() { |
- return NULL; |
- } |
- virtual thunk::PPB_Font_FunctionAPI* AsFont_FunctionAPI() { |
- return NULL; |
- } |
- virtual thunk::ResourceCreationAPI* AsResourceCreation() { |
- return NULL; |
- } |
+ // Inheritance-based dynamic casting for this object. Returns the pointer to |
+ // the given type if it's supported. Derived classes override these AsXXX |
piman
2011/06/01 00:41:08
nit: I can't quite parse this comment. Please fix
|
+ #define DEFINE_TYPE_GETTER(FUNCTIONS) \ |
+ virtual thunk::FUNCTIONS* As##FUNCTIONS(); |
+ FOR_ALL_PPAPI_FUNCTION_APIS(DEFINE_TYPE_GETTER) |
+ #undef DEFINE_TYPE_GETTER |
+ // Template-based dynamic casting. See specializations below. |
template <typename T> T* GetAs() { return NULL; } |
}; |
-template<> |
-inline thunk::PPB_CharSet_FunctionAPI* FunctionGroupBase::GetAs() { |
- return AsCharSet_FunctionAPI(); |
-} |
-template<> |
-inline thunk::PPB_CursorControl_FunctionAPI* FunctionGroupBase::GetAs() { |
- return AsCursorControl_FunctionAPI(); |
-} |
-template<> |
-inline thunk::PPB_Font_FunctionAPI* FunctionGroupBase::GetAs() { |
- return AsFont_FunctionAPI(); |
-} |
-template<> |
-inline ppapi::thunk::ResourceCreationAPI* FunctionGroupBase::GetAs() { |
- return AsResourceCreation(); |
-} |
+// Template-based dynamic casting. These specializatins forward to the |
piman
2011/06/01 00:41:08
typo: specializations
|
+// AsXXX virtual functions to return whether the given type is supported. |
+#define DEFINE_FUNCTION_CAST(FUNCTIONS) \ |
+ template<> inline thunk::FUNCTIONS* FunctionGroupBase::GetAs() { \ |
+ return As##FUNCTIONS(); \ |
+ } |
+FOR_ALL_PPAPI_FUNCTION_APIS(DEFINE_FUNCTION_CAST) |
+#undef DEFINE_FUNCTION_CAST |
} // namespace ppapi |