summaryrefslogtreecommitdiff
path: root/main
diff options
context:
space:
mode:
authorShane Caraveo <shane@php.net>2003-10-19 20:59:12 +0000
committerShane Caraveo <shane@php.net>2003-10-19 20:59:12 +0000
commit2a41429472dbd9e3423cda24937f69b0ae744668 (patch)
tree5c2f355f4f46076df8ad6a68852efd15623a852e /main
parent0029a45795060391e41d2423d15f5fe76c2fb119 (diff)
downloadphp-git-2a41429472dbd9e3423cda24937f69b0ae744668.tar.gz
A simpler patch to add file uri support
Diffstat (limited to 'main')
-rw-r--r--main/streams/plain_wrapper.c10
-rwxr-xr-xmain/streams/streams.c8
2 files changed, 17 insertions, 1 deletions
diff --git a/main/streams/plain_wrapper.c b/main/streams/plain_wrapper.c
index 1f060ec666..5286f4fcb2 100644
--- a/main/streams/plain_wrapper.c
+++ b/main/streams/plain_wrapper.c
@@ -882,6 +882,16 @@ static php_stream *php_plain_files_dir_opener(php_stream_wrapper *wrapper, char
static php_stream *php_plain_files_stream_opener(php_stream_wrapper *wrapper, char *path, char *mode,
int options, char **opened_path, php_stream_context *context STREAMS_DC TSRMLS_DC)
{
+ char *filename = path;
+ if (!strncasecmp(filename, "file:", sizeof("file:")-1)) {
+ filename += 6;
+ while (*(++filename)=='/');
+#ifdef PHP_WIN32
+ if (*(filename + 1) != ':')
+#endif
+ filename--;
+ }
+
if ((options & USE_PATH) && PG(include_path) != NULL) {
return php_stream_fopen_with_path_rel(path, mode, PG(include_path), opened_path, options);
}
diff --git a/main/streams/streams.c b/main/streams/streams.c
index 49a34cdcdb..d7579378c1 100755
--- a/main/streams/streams.c
+++ b/main/streams/streams.c
@@ -1415,14 +1415,20 @@ PHPAPI php_stream_wrapper *php_stream_locate_url_wrapper(const char *path, char
}
/* TODO: curl based streams probably support file:// properly */
if (!protocol || !strncasecmp(protocol, "file", n)) {
- if (protocol && path[n+1] == '/' && path[n+2] == '/') {
+ if (protocol && path[n+1] == '/' && path[n+2] == '/' && path[n+3] != '/') {
if (options & REPORT_ERRORS) {
php_error_docref(NULL TSRMLS_CC, E_WARNING, "remote host file access not supported, %s", path);
}
return NULL;
}
if (protocol && path_for_open) {
+ /* skip past protocol and :/, but handle windows correctly */
*path_for_open = (char*)path + n + 1;
+ while (*(++*path_for_open)=='/');
+#ifdef PHP_WIN32
+ if (*(*path_for_open + 1) != ':')
+#endif
+ *path_for_open--;
}
/* fall back on regular file access */