fishy opened a new pull request #2181:
URL: https://github.com/apache/thrift/pull/2181


   Client: go
   
   As discussed in the JIRA ticket, this commit changes how we handle I/O
   timeouts in the go library.
   
   This is a breaking change that adds context to all Read*, Write*, and
   Skip functions to TProtocol, along with the compiler change to support
   that, and also adds context to TStandardClient.Recv, TDeserializer,
   TStruct, and a few others.
   
   Along with the function signature changes, this commit also implements
   context cancellation check in the following TProtocol's ReadMessageBegin
   implementations:
   
   - TBinaryProtocol
   - TCompactProtocol
   - THeaderProtocol
   
   In those ReadMessageBegin implementations, if the passed in context
   object has a deadline attached, it will keep retrying the I/O timeout
   errors, until the deadline on the context object passed. They won't
   retry I/O timeout errors if the passed in context does not have a
   deadline attached (still return on the first error).
   
   <!-- Explain the changes in the pull request below: -->
     
   
   <!-- We recommend you review the checklist/tips before submitting a pull 
request. -->
   
   - [ ] Did you create an [Apache 
Jira](https://issues.apache.org/jira/projects/THRIFT/issues/) ticket?  (not 
required for trivial changes)
   - [ ] If a ticket exists: Does your pull request title follow the pattern 
"THRIFT-NNNN: describe my issue"?
   - [ ] Did you squash your changes to a single commit?  (not required, but 
preferred)
   - [ ] Did you do your best to avoid breaking changes?  If one was needed, 
did you label the Jira ticket with "Breaking-Change"?
   - [ ] If your change does not involve any code, include `[skip ci]` anywhere 
in the commit message to free up build resources.
   
   <!--
     The Contributing Guide at:
     https://github.com/apache/thrift/blob/master/CONTRIBUTING.md
     has more details and tips for committing properly.
   -->
   


----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


Reply via email to