> GET_INTERFACE seems overcomplicated and error prone. It requires the first
> two parameters to match up - when in every use the second is a second macro
> with no other use that calls a third with the first parameter. Confused?
>
> Current usage: GET_INTERFACE (CCSContextInterface, CCS_CONTEXT_INTERFACE_TYPE,
> context))
> Suggest usage: GET_INTERFACE (CCSContextInterface, context))
>
>
> Current #define GET_INTERFACE(CType,IType, o) (CType *) ccsObjectGetInterface
> ((CCSObject *) o, IType)
> Suggest #define GET_INTERFACE(CType, o)
> (CType*)ccsObjectGetInterface((CCSObject*) o, GET_INTERFACE_TYPE(CType))
>
> And get rid of CCS_CONTEXT_INTERFACE_TYPE which is then unused.
I'm a bit confused - how would GET_INTERFACE_TYPE(CCSContext) be able to replace CCS_CONTEXT_INTERFACE_TYPE ? There's no templates available so we can't do it that way ....
> GET_INTERFACE seems overcomplicated and error prone. It requires the first rface, CCS_CONTEXT_ INTERFACE_ TYPE, rface, context)) CType,IType, o) (CType *) ccsObjectGetInt erface CType, o) )ccsObjectGetIn terface( (CCSObject* ) o, GET_INTERFACE_ TYPE(CType) ) INTERFACE_ TYPE which is then unused.
> two parameters to match up - when in every use the second is a second macro
> with no other use that calls a third with the first parameter. Confused?
>
> Current usage: GET_INTERFACE (CCSContextInte
> context))
> Suggest usage: GET_INTERFACE (CCSContextInte
>
>
> Current #define GET_INTERFACE(
> ((CCSObject *) o, IType)
> Suggest #define GET_INTERFACE(
> (CType*
>
> And get rid of CCS_CONTEXT_
I'm a bit confused - how would GET_INTERFACE_ TYPE(CCSContext ) be able to replace CCS_CONTEXT_ INTERFACE_ TYPE ? There's no templates available so we can't do it that way ....