[ 
https://issues.apache.org/jira/browse/THRIFT-4932?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Ewan Higgs closed THRIFT-4932.
------------------------------
    Resolution: Duplicate

> Using a default string on a binary field results in invalid Java code.
> ----------------------------------------------------------------------
>
>                 Key: THRIFT-4932
>                 URL: https://issues.apache.org/jira/browse/THRIFT-4932
>             Project: Thrift
>          Issue Type: Bug
>          Components: Java - Compiler
>    Affects Versions: 0.9.3, 0.12.0
>            Reporter: Ewan Higgs
>            Priority: Major
>
> Given the following service definition:
> {code}
> $ cat Service.thrift 
> service MyService {
>     string doWork(
>     1: string arg1;
>     2: binary arg2 = '';
>     3: binary arg3 = '';
>     );
> }
> {code}
> And the following compilation:
> {code}
> /usr/local/Cellar/thrift/0.12.0/bin/thrift -gen java Service.thrift
> {code}
> Results in code that does not compile. This is because we end up with code 
> like the following:
> {code}    
>     public doWork_args() {
>       this.arg2 = "";
>       this.arg3 = "";
>     }        
> {code}
> In Java you cannot set a {{ByteBuffer}} to a {{String}} value.
> Users can run into this situation if they were generating C++ code before 
> ({{binary}} and {{string}} both resolve to {{std::string}}) and then only 
> later decide to use Java with existing files.



--
This message was sent by Atlassian Jira
(v8.3.2#803003)

Reply via email to