diff options
Diffstat (limited to 'src/animator')
-rw-r--r-- | src/animator/SkDisplayInclude.cpp | 7 | ||||
-rw-r--r-- | src/animator/SkMemberInfo.h | 9 |
2 files changed, 7 insertions, 9 deletions
diff --git a/src/animator/SkDisplayInclude.cpp b/src/animator/SkDisplayInclude.cpp index 860264eb6f..023b3913a5 100644 --- a/src/animator/SkDisplayInclude.cpp +++ b/src/animator/SkDisplayInclude.cpp @@ -11,13 +11,6 @@ #include "SkAnimateMaker.h" #include "SkAnimator.h" -#if 0 -#undef SK_MEMBER -#define SK_MEMBER(_member, _type) \ - { #_member, SK_OFFSETOF(BASE_CLASS::_A, _member), SkType_##_type, \ - sizeof(((BASE_CLASS::_A*) 0)->_member) / sizeof(SkScalar) } -#endif - #if SK_USE_CONDENSED_INFO == 0 const SkMemberInfo SkInclude::fInfo[] = { diff --git a/src/animator/SkMemberInfo.h b/src/animator/SkMemberInfo.h index e07c32270d..3588da2515 100644 --- a/src/animator/SkMemberInfo.h +++ b/src/animator/SkMemberInfo.h @@ -104,13 +104,18 @@ struct SkMemberInfo { // static bool SetValue(void* value, const char* name, SkDisplayTypes , int count); }; +#ifndef SK_OFFSETOF + // This is offsetof for types which are not standard layout. + #define SK_OFFSETOF(type, field) (size_t)((char*)&(((type*)1024)->field) - (char*)1024) +#endif + #define SK_MEMBER(_member, _type) \ { #_member, SK_OFFSETOF(BASE_CLASS, _member), SkType_##_type, \ - sizeof(((BASE_CLASS*) 1)->_member) / sizeof(SkScalar) } + sizeof(skstd::declval<BASE_CLASS>()._member) / sizeof(SkScalar) } #define SK_MEMBER_ALIAS(_member, _alias, _type) \ { #_member, SK_OFFSETOF(BASE_CLASS, _alias), SkType_##_type, \ - sizeof(((BASE_CLASS*) 1)->_alias) / sizeof(SkScalar) } + sizeof(skstd::declval<BASE_CLASS>()._alias) / sizeof(SkScalar) } #define SK_MEMBER_ARRAY(_member, _type) \ { #_member, SK_OFFSETOF(BASE_CLASS, _member), SkType_Array, \ |