Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F90530
D7773.diff
All Users
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
4 KB
Referenced Files
None
Subscribers
None
D7773.diff
View Options
diff --git a/src/channel/PhutilChannel.php b/src/channel/PhutilChannel.php
--- a/src/channel/PhutilChannel.php
+++ b/src/channel/PhutilChannel.php
@@ -32,9 +32,13 @@
abstract class PhutilChannel {
private $ibuf = '';
- private $obuf = '';
+ private $obuf;
private $name;
+ public function __construct() {
+ $this->obuf = new PhutilRope();
+ }
+
/* -( Reading and Writing )------------------------------------------------ */
@@ -72,7 +76,7 @@
throw new Exception("PhutilChannel->write() may only write strings!");
}
- $this->obuf .= $bytes;
+ $this->obuf->append($bytes);
return $this;
}
@@ -183,13 +187,13 @@
$this->ibuf .= $in;
}
- while (strlen($this->obuf)) {
- $len = $this->writeBytes($this->obuf);
+ while ($this->obuf->getByteLength()) {
+ $len = $this->writeBytes($this->obuf->getAnyPrefix());
if (!$len) {
// Writing is blocked for now.
break;
}
- $this->obuf = substr($this->obuf, $len);
+ $this->obuf->removeBytesFromHead($len);
}
return $this->isOpen();
@@ -320,7 +324,7 @@
*
* @task impl
*/
- protected function isReadBufferEmpty() {
+ public function isReadBufferEmpty() {
return (strlen($this->ibuf) == 0);
}
@@ -332,8 +336,20 @@
*
* @task impl
*/
- protected function isWriteBufferEmpty() {
- return (strlen($this->obuf) == 0);
+ public function isWriteBufferEmpty() {
+ return !$this->getWriteBufferSize();
+ }
+
+
+ /**
+ * Get the number of bytes we're currently waiting to write.
+ *
+ * @return int Number of waiting bytes.
+ *
+ * @task impl
+ */
+ public function getWriteBufferSize() {
+ return $this->obuf->getByteLength();
}
diff --git a/src/channel/PhutilChannelChannel.php b/src/channel/PhutilChannelChannel.php
--- a/src/channel/PhutilChannelChannel.php
+++ b/src/channel/PhutilChannelChannel.php
@@ -15,6 +15,7 @@
private $channel;
public function __construct(PhutilChannel $channel) {
+ parent::__construct();
$this->channel = $channel;
$this->didConstruct();
}
@@ -68,14 +69,18 @@
return $this->channel->getWriteSockets();
}
- protected function isReadBufferEmpty() {
+ public function isReadBufferEmpty() {
return $this->channel->isReadBufferEmpty();
}
- protected function isWriteBufferEmpty() {
+ public function isWriteBufferEmpty() {
return $this->channel->isWriteBufferEmpty();
}
+ public function getWriteBufferSize() {
+ return $this->channel->getWriteBufferSize();
+ }
+
public function flush() {
$this->channel->flush();
return $this;
diff --git a/src/channel/PhutilExecChannel.php b/src/channel/PhutilExecChannel.php
--- a/src/channel/PhutilExecChannel.php
+++ b/src/channel/PhutilExecChannel.php
@@ -63,6 +63,8 @@
* @task construct
*/
public function __construct(ExecFuture $future) {
+ parent::__construct();
+
// Make an empty write to keep the stdin pipe open. By default, futures
// close this pipe when they start.
$future->write('', $keep_pipe = true);
@@ -124,10 +126,14 @@
return $this->future->getWriteSockets();
}
- protected function isWriteBufferEmpty() {
+ public function isWriteBufferEmpty() {
return $this->future->isWriteBufferEmpty();
}
+ public function getWriteBufferSize() {
+ return $this->future->getWriteBufferSize();
+ }
+
/**
* If the wrapped @{class:ExecFuture} outputs data to stderr, we normally
* throw an exception. Instead, you can provide a callback handler that will
diff --git a/src/channel/PhutilSocketChannel.php b/src/channel/PhutilSocketChannel.php
--- a/src/channel/PhutilSocketChannel.php
+++ b/src/channel/PhutilSocketChannel.php
@@ -42,6 +42,7 @@
* @task construct
*/
public function __construct($read_socket, $write_socket = null) {
+ parent::__construct();
foreach (array($read_socket, $write_socket) as $socket) {
if (!$socket) {
diff --git a/src/future/exec/ExecFuture.php b/src/future/exec/ExecFuture.php
--- a/src/future/exec/ExecFuture.php
+++ b/src/future/exec/ExecFuture.php
@@ -513,7 +513,21 @@
* @task internal
*/
public function isWriteBufferEmpty() {
- return !($this->stdin && $this->stdin->getByteLength());
+ return !$this->getWriteBufferSize();
+ }
+
+
+ /**
+ * Determine the number of bytes in the write buffer.
+ *
+ * @return int Number of bytes in the write buffer.
+ * @task internal
+ */
+ public function getWriteBufferSize() {
+ if (!$this->stdin) {
+ return 0;
+ }
+ return $this->stdin->getByteLength();
}
File Metadata
Details
Attached
Mime Type
text/x-diff
Storage Engine
amazon-s3
Storage Format
Raw Data
Storage Handle
phabricator/j7/zw/jreotxdw5fdkw2ov
Default Alt Text
D7773.diff (4 KB)
Attached To
Mode
D7773: Use PhutilRope for Channel write buffers and make write buffer details public
Attached
Detach File
Event Timeline
Log In to Comment