Hi,

what puzzles me is, that

TBinaryProtocol.java:204

is the first line, where the version number is read. If at that place the input stream is empty, then there is something fundamentally wrong. I'm not the Java expert, but could it be, that the server (not the client!) throws an exception and does not respond to the call corectly, which in turn leads to the client trying to read from an empty response stream?



-----Ursprüngliche Nachricht----- From: Avinash Dongre
Sent: Tuesday, May 14, 2013 8:48 AM
To: [email protected]
Subject: Re: Optional Field in Thrift Structure

Thanks Jens,
I am using Binary protocol. I have further debugged the issue. and What I
found is that
I have
List<List<AnotherStructure>> to return. All the fields in the
AnotherStructure is optional. When I try to update this list then only I am
getting the exception.

List<List<AnotherStructure>> allrows = new
ArrayList<List<AnotherStructure>>();
       while (rs.next()) {
           List<AnotherStructure> singleRow = new
ArrayList<AnotherStructure>();
           for (int i = 1; i <= 100; i++) {
               AnotherStructure cv = createAnotherStructure();
               singleRow.add(cv);
           }
           allrows.add(singleRow);
       }
       sr.getResultSet().setRows(allrows);

If I do following by commenting the population i do not get any exception.

List<List<AnotherStructure>> allrows = new
ArrayList<List<AnotherStructure>>();
       while (rs.next()) {
           List<AnotherStructure> singleRow = new
ArrayList<AnotherStructure>();
           allrows.add(singleRow);
       }
       sr.getResultSet().setRows(allrows);


Thanks
Avinash



On Tue, May 14, 2013 at 3:17 AM, Jens Geyer <[email protected]> wrote:

Hi Avinash,


 When I implement my server in Java, do i need to update all the fields
while constructing response . Or just some field updates is enough.


You would have to set required fields, if there were any. Since your
Response struct only consists of optionals, it would be perfectly legal to
send a response structure back with no values at all.


 Sometimes I get following kind of exception


From what I see in the code, the exception is TTransportException.END_OF_*
*FILE. Therefore I don't think that the problem has anything to do with
optionals being set or not set. But it could be helpful to the Java guys if
they had a little more information about your setup, especially which
transport and which protocol(s) you are using.



-----Ursprüngliche Nachricht----- From: Avinash Dongre
Sent: Monday, May 13, 2013 1:49 PM
To: [email protected]
Subject: Optional Field in Thrift Structure


I have following structure

struct Response {
 1: optional bool isFinished, // for BLOB and CLOB
 2: optional ResponseSubset r1,
 3: optional i32 Count,
 4: optional list<alue> params,
 6: optional ResponseSubset1 warnings,
}

and Have api like this

Response performanOperation(1. required i32 id)

When I implement my server in Java, do i need to update all the fields
while constructing response . Or just some field updates is enough.

Sometimes I get following kind of exception


org.apache.thrift.transport.**TTransportException
   at
org.apache.thrift.transport.**TIOStreamTransport.read(**
TIOStreamTransport.java:132)
   at org.apache.thrift.transport.**TTransport.readAll(TTransport.**
java:84)
   at
org.apache.thrift.protocol.**TBinaryProtocol.readAll(**
TBinaryProtocol.java:378)
   at
org.apache.thrift.protocol.**TBinaryProtocol.readI32(**
TBinaryProtocol.java:297)
   at
org.apache.thrift.protocol.**TBinaryProtocol.**readMessageBegin(**
TBinaryProtocol.java:204)
   at org.apache.thrift.**TServiceClient.receiveBase(**
TServiceClient.java:69)


Thanks
Avinash


Reply via email to