From 0f657da81fe739570d74a95eec837f2b6e902bf8 Mon Sep 17 00:00:00 2001 From: Gasol Wu Date: Fri, 14 Dec 2018 11:16:27 +0800 Subject: [PATCH] Eliminate property $beInherited Use local variable instead --- lib/Client.php | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/lib/Client.php b/lib/Client.php index 1aa9612..cc2bc09 100644 --- a/lib/Client.php +++ b/lib/Client.php @@ -68,21 +68,21 @@ class Client extends EventEmitter protected $headerLinesMap = []; - protected $beInherited; - /** * Initializes the client. */ public function __construct() { - $this->beInherited = __CLASS__ !== get_class($this); + // See https://github.com/sabre-io/http/pull/115#discussion_r241292068 + // Preserve compatibility for sub-classes that implements their own method `parseCurlResult` + $separatedHeaders = __CLASS__ !== get_class($this); $this->curlSettings = [ CURLOPT_RETURNTRANSFER => true, CURLOPT_NOBODY => false, CURLOPT_USERAGENT => 'sabre-http/'.Version::VERSION.' (http://sabre.io/)', ]; - if ($this->beInherited) { + if ($separatedHeaders) { $this->curlSettings[CURLOPT_HEADER] = true; } else { $this->curlSettings[CURLOPT_HEADERFUNCTION] = [$this, 'receiveCurlHeader']; @@ -418,9 +418,10 @@ protected function createCurlSettingsArray(RequestInterface $request): array private function parseResponse(string $response, $curlHandle): array { - if ($this->beInherited) { - $response = $this->parseCurlResult($response, $curlHandle); - } else { + $settings = $this->curlSettings; + $separatedHeaders = isset($settings[CURLOPT_HEADERFUNCTION]) && (bool) $settings[CURLOPT_HEADERFUNCTION]; + + if ($separatedHeaders) { $resourceId = (int) $curlHandle; if (isset($this->headerLinesMap[$resourceId])) { $headers = $this->headerLinesMap[$resourceId]; @@ -428,6 +429,8 @@ private function parseResponse(string $response, $curlHandle): array $headers = []; } $response = $this->parseCurlResponse($headers, $response, $curlHandle); + } else { + $response = $this->parseCurlResult($response, $curlHandle); } return $response;