[
https://issues.apache.org/jira/browse/THRIFT-3325?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
James E. King III closed THRIFT-3325.
-------------------------------------
This issue was resolved without a fixVersion but was not closed - closing.
> Extended services aren't subclasses in generated Cocoa
> ------------------------------------------------------
>
> Key: THRIFT-3325
> URL: https://issues.apache.org/jira/browse/THRIFT-3325
> Project: Thrift
> Issue Type: Bug
> Components: Cocoa - Library
> Reporter: Ryan Joseph
> Priority: Critical
>
> The following interface definition:
> {noformat}
> service Parent {
> string name();
> }
> service Child extends Parent {
> i32 age();
> }
> {noformat}
> Produces the following generated Cocoa (truncated for readability):
> {noformat}
> @protocol Parent <NSObject>
> - (NSString *) name; // throws TException
> @end
> // ...
> @protocol Child <NSObject>
> - (int32_t) age; // throws TException
> @end
> @interface ChildClient : NSObject <Child> {
> id <TProtocol> inProtocol;
> id <TProtocol> outProtocol;
> }
> - (id) initWithProtocol: (id <TProtocol>) protocol;
> - (id) initWithInProtocol: (id <TProtocol>) inProtocol outProtocol: (id
> <TProtocol>) outProtocol;
> @end
> {noformat}
> With these definitions, an instance of "Child" knows nothing of nor can ever
> have superclass method {{name()}} called on it. This completely breaks not
> only polymorphism, but the use of the "extends" keyword when generating Cocoa.
> This could be easily resolved by simply having the "Child" class also conform
> to the "Parent" protocol, or more-correctly resolved by making "Child" an
> actual subclass of "Parent".
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)