THRIFT-169: Fixes framed/buffered transport state on underlying flush failure
authorMark Slee <mcslee@apache.org>
Tue, 14 Oct 2008 22:00:36 +0000 (22:00 +0000)
committerMark Slee <mcslee@apache.org>
Tue, 14 Oct 2008 22:00:36 +0000 (22:00 +0000)
git-svn-id: https://svn.apache.org/repos/asf/incubator/thrift/trunk@704710 13f79535-47bb-0310-9956-ffa450edef68

lib/php/src/transport/TBufferedTransport.php
lib/php/src/transport/TFramedTransport.php

index eb76167..2682569 100644 (file)
@@ -131,8 +131,13 @@ class TBufferedTransport extends TTransport {
   public function write($buf) {
     $this->wBuf_ .= $buf;
     if (strlen($this->wBuf_) >= $this->wBufSize_) {
-      $this->transport_->write($this->wBuf_);
+      $out = $this->wBuf_;
+
+      // Note that we clear the internal wBuf_ prior to the underlying write
+      // to ensure we're in a sane state (i.e. internal buffer cleaned)
+      // if the underlying write throws up an exception
       $this->wBuf_ = '';
+      $this->transport_->write($out);
     }
   }
 
index e2f8d6b..2c7a344 100644 (file)
@@ -158,9 +158,13 @@ class TFramedTransport extends TTransport {
 
     $out = pack('N', strlen($this->wBuf_));
     $out .= $this->wBuf_;
+
+    // Note that we clear the internal wBuf_ prior to the underlying write
+    // to ensure we're in a sane state (i.e. internal buffer cleaned)
+    // if the underlying write throws up an exception
+    $this->wBuf_ = '';
     $this->transport_->write($out);
     $this->transport_->flush();
-    $this->wBuf_ = '';
   }
 
 }