You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@thrift.apache.org by "Allen George (JIRA)" <ji...@apache.org> on 2018/12/29 22:00:00 UTC
[jira] [Resolved] (THRIFT-3325) Extended services aren't subclasses
in generated Cocoa
[ https://issues.apache.org/jira/browse/THRIFT-3325?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Allen George resolved THRIFT-3325.
----------------------------------
Resolution: Won't Fix
Cocoa support is deprecated as of Thrift 0.12.0.
> 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)