@@ -60,6 +60,9 @@ discard block |
||
| 60 | 60 | } |
| 61 | 61 | } |
| 62 | 62 | |
| 63 | + /** |
|
| 64 | + * @param string $url |
|
| 65 | + */ |
|
| 63 | 66 | public function importURL($url) |
| 64 | 67 | { |
| 65 | 68 | $struct = parse_url($url); |
@@ -78,6 +81,11 @@ discard block |
||
| 78 | 81 | } |
| 79 | 82 | |
| 80 | 83 | // utility for __construct |
| 84 | + |
|
| 85 | + /** |
|
| 86 | + * @param string $key |
|
| 87 | + * @param string $default |
|
| 88 | + */ |
|
| 81 | 89 | private static function setOr(array $struct, $key, $default=null) |
| 82 | 90 | { |
| 83 | 91 | if (!empty($struct[$key])) { |
@@ -63,7 +63,9 @@ discard block |
||
| 63 | 63 | public function importURL($url) |
| 64 | 64 | { |
| 65 | 65 | $struct = parse_url($url); |
| 66 | - if (! $struct) throw new \InvalidArgumentException("$url is not valid URL"); |
|
| 66 | + if (! $struct) { |
|
| 67 | + throw new \InvalidArgumentException("$url is not valid URL"); |
|
| 68 | + } |
|
| 67 | 69 | |
| 68 | 70 | $this->scheme = self::setOr($struct, 'scheme', $this->scheme); |
| 69 | 71 | $this->host = self::setOr($struct, 'host', $this->host); |
@@ -149,7 +151,9 @@ discard block |
||
| 149 | 151 | |
| 150 | 152 | public static function genUA() { |
| 151 | 153 | static $ua; |
| 152 | - if ($ua) return $ua; |
|
| 154 | + if ($ua) { |
|
| 155 | + return $ua; |
|
| 156 | + } |
|
| 153 | 157 | $phpVersion = defined('HHVM_VERSION') ? 'HHVM ' . HHVM_VERSION : 'PHP ' . PHP_VERSION; |
| 154 | 158 | |
| 155 | 159 | return $ua = sprintf( |
@@ -79,7 +79,7 @@ discard block |
||
| 79 | 79 | /** |
| 80 | 80 | * Get the content. |
| 81 | 81 | * |
| 82 | - * @param string $originUrl The origin URL |
|
| 82 | + * @param string $origin The origin URL |
|
| 83 | 83 | * @param string $fileUrl The file URL |
| 84 | 84 | * @param bool $progress Display the progression |
| 85 | 85 | * @param array $options Additional context options |
@@ -97,6 +97,11 @@ discard block |
||
| 97 | 97 | }); |
| 98 | 98 | } |
| 99 | 99 | |
| 100 | + /** |
|
| 101 | + * @param string $fileUrl |
|
| 102 | + * @param boolean $progress |
|
| 103 | + * @param \Closure $exec |
|
| 104 | + */ |
|
| 100 | 105 | protected function fetch($origin, $fileUrl, $progress, $options, $exec) |
| 101 | 106 | { |
| 102 | 107 | do { |
@@ -216,6 +221,9 @@ discard block |
||
| 216 | 221 | return 0; |
| 217 | 222 | } |
| 218 | 223 | |
| 224 | + /** |
|
| 225 | + * @param string $fileName |
|
| 226 | + */ |
|
| 219 | 227 | public static function createFile($fileName) |
| 220 | 228 | { |
| 221 | 229 | if (is_dir($fileName)) { |
@@ -110,24 +110,31 @@ |
||
| 110 | 110 | } |
| 111 | 111 | |
| 112 | 112 | // start multi download |
| 113 | - do $stat = curl_multi_exec($mh, $running); |
|
| 114 | - while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 113 | + do { |
|
| 114 | + $stat = curl_multi_exec($mh, $running); |
|
| 115 | + } while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 115 | 116 | |
| 116 | 117 | // wait for any event |
| 117 | - do switch (curl_multi_select($mh, 5)) { |
|
| 118 | + do { |
|
| 119 | + switch (curl_multi_select($mh, 5)) { |
|
| 118 | 120 | case -1: |
| 119 | 121 | usleep(10); |
| 120 | - do $stat = curl_multi_exec($mh, $running); |
|
| 121 | - while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 122 | + } |
|
| 123 | + do { |
|
| 124 | + $stat = curl_multi_exec($mh, $running); |
|
| 125 | + } while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 122 | 126 | continue 2; |
| 123 | 127 | case 0: |
| 124 | 128 | continue 2; |
| 125 | 129 | default: |
| 126 | - do $stat = curl_multi_exec($mh, $running); |
|
| 127 | - while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 130 | + do { |
|
| 131 | + $stat = curl_multi_exec($mh, $running); |
|
| 132 | + } while ($stat === CURLM_CALL_MULTI_PERFORM); |
|
| 128 | 133 | |
| 129 | - do if ($raised = curl_multi_info_read($mh, $remains)) { |
|
| 134 | + do { |
|
| 135 | + if ($raised = curl_multi_info_read($mh, $remains)) { |
|
| 130 | 136 | $ch = $raised['handle']; |
| 137 | + } |
|
| 131 | 138 | $errno = curl_errno($ch); |
| 132 | 139 | $info = curl_getinfo($ch); |
| 133 | 140 | curl_setopt($ch, CURLOPT_FILE, STDOUT); |