diff options
author | Roeland Jago Douma <roeland@famdouma.nl> | 2019-03-07 12:57:04 +0100 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2019-03-07 12:59:47 +0100 |
commit | f5f4673827b72a20428493661027e5f60a2e0bf5 (patch) | |
tree | c265de23bde544b1d799028c6cf80aa516a7cc54 /apps/files_external | |
parent | 3de750c88cf83ba6e70a091029186ecae5ba6008 (diff) | |
download | nextcloud-server-f5f4673827b72a20428493661027e5f60a2e0bf5.tar.gz nextcloud-server-f5f4673827b72a20428493661027e5f60a2e0bf5.zip |
Have streams of files_external in sync
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
Diffstat (limited to 'apps/files_external')
4 files changed, 28 insertions, 16 deletions
diff --git a/apps/files_external/3rdparty/composer.json b/apps/files_external/3rdparty/composer.json index 06911c05fe9..8b67bbd0586 100644 --- a/apps/files_external/3rdparty/composer.json +++ b/apps/files_external/3rdparty/composer.json @@ -8,7 +8,7 @@ "classmap-authoritative": true }, "require": { - "icewind/streams": "0.6.1", + "icewind/streams": "0.7.1", "icewind/smb": "3.0.2" } } diff --git a/apps/files_external/3rdparty/composer.lock b/apps/files_external/3rdparty/composer.lock index 329a73dfe98..c41836410d4 100644 --- a/apps/files_external/3rdparty/composer.lock +++ b/apps/files_external/3rdparty/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "1357a8ac93fc039db0cf2c5cf5a45f13", + "content-hash": "641ed61db5e07e8e9eaebfb6918ea521", "packages": [ { "name": "icewind/smb", @@ -49,16 +49,16 @@ }, { "name": "icewind/streams", - "version": "0.6.1", + "version": "v0.7.1", "source": { "type": "git", "url": "https://github.com/icewind1991/Streams.git", - "reference": "0a78597117d8a02937ea05206f219294449fb06e" + "reference": "4db3ed6c366e90b958d00e1d4c6360a9b39b2121" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/icewind1991/Streams/zipball/0a78597117d8a02937ea05206f219294449fb06e", - "reference": "0a78597117d8a02937ea05206f219294449fb06e", + "url": "https://api.github.com/repos/icewind1991/Streams/zipball/4db3ed6c366e90b958d00e1d4c6360a9b39b2121", + "reference": "4db3ed6c366e90b958d00e1d4c6360a9b39b2121", "shasum": "" }, "require": { @@ -86,7 +86,7 @@ } ], "description": "A set of generic stream wrappers", - "time": "2018-04-24T09:07:38+00:00" + "time": "2019-02-15T12:57:29+00:00" } ], "packages-dev": [], diff --git a/apps/files_external/3rdparty/composer/installed.json b/apps/files_external/3rdparty/composer/installed.json index 06fed9ebadb..e4c4dc5de79 100644 --- a/apps/files_external/3rdparty/composer/installed.json +++ b/apps/files_external/3rdparty/composer/installed.json @@ -44,17 +44,17 @@ }, { "name": "icewind/streams", - "version": "0.6.1", - "version_normalized": "0.6.1.0", + "version": "v0.7.1", + "version_normalized": "0.7.1.0", "source": { "type": "git", "url": "https://github.com/icewind1991/Streams.git", - "reference": "0a78597117d8a02937ea05206f219294449fb06e" + "reference": "4db3ed6c366e90b958d00e1d4c6360a9b39b2121" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/icewind1991/Streams/zipball/0a78597117d8a02937ea05206f219294449fb06e", - "reference": "0a78597117d8a02937ea05206f219294449fb06e", + "url": "https://api.github.com/repos/icewind1991/Streams/zipball/4db3ed6c366e90b958d00e1d4c6360a9b39b2121", + "reference": "4db3ed6c366e90b958d00e1d4c6360a9b39b2121", "shasum": "" }, "require": { @@ -64,7 +64,7 @@ "phpunit/phpunit": "^4.8", "satooshi/php-coveralls": "v1.0.0" }, - "time": "2018-04-24T09:07:38+00:00", + "time": "2019-02-15T12:57:29+00:00", "type": "library", "installation-source": "dist", "autoload": { diff --git a/apps/files_external/3rdparty/icewind/streams/src/CallbackWrapper.php b/apps/files_external/3rdparty/icewind/streams/src/CallbackWrapper.php index 4eef55681c7..67f9110d100 100644 --- a/apps/files_external/3rdparty/icewind/streams/src/CallbackWrapper.php +++ b/apps/files_external/3rdparty/icewind/streams/src/CallbackWrapper.php @@ -45,6 +45,11 @@ class CallbackWrapper extends Wrapper { protected $readDirCallBack; /** + * @var callable + */ + protected $preCloseCallback; + + /** * Wraps a stream with the provided callbacks * * @param resource $source @@ -56,14 +61,15 @@ class CallbackWrapper extends Wrapper { * * @throws \BadMethodCallException */ - public static function wrap($source, $read = null, $write = null, $close = null, $readDir = null) { + public static function wrap($source, $read = null, $write = null, $close = null, $readDir = null, $preClose = null) { $context = stream_context_create(array( 'callback' => array( 'source' => $source, 'read' => $read, 'write' => $write, 'close' => $close, - 'readDir' => $readDir + 'readDir' => $readDir, + 'preClose' => $preClose, ) )); return Wrapper::wrapSource($source, $context, 'callback', '\Icewind\Streams\CallbackWrapper'); @@ -76,6 +82,7 @@ class CallbackWrapper extends Wrapper { $this->writeCallback = $context['write']; $this->closeCallback = $context['close']; $this->readDirCallBack = $context['readDir']; + $this->preCloseCallback = $context['preClose']; return true; } @@ -90,7 +97,7 @@ class CallbackWrapper extends Wrapper { public function stream_read($count) { $result = parent::stream_read($count); if (is_callable($this->readCallback)) { - call_user_func($this->readCallback, $count); + call_user_func($this->readCallback, strlen($result)); } return $result; } @@ -104,6 +111,11 @@ class CallbackWrapper extends Wrapper { } public function stream_close() { + if (is_callable($this->preCloseCallback)) { + call_user_func($this->preCloseCallback, $this->loadContext('callback')['source']); + // prevent further calls by potential PHP 7 GC ghosts + $this->preCloseCallback = null; + } $result = parent::stream_close(); if (is_callable($this->closeCallback)) { call_user_func($this->closeCallback); |