diff options
author | Wez Furlong <wez@php.net> | 2002-08-25 11:23:19 +0000 |
---|---|---|
committer | Wez Furlong <wez@php.net> | 2002-08-25 11:23:19 +0000 |
commit | e286b286aea230a512ff0a3d3efd6e28da9b5da1 (patch) | |
tree | 022a4fc4a49df959a3e3ff84681f3d9b4bbdcca2 | |
parent | 6d2fb453287cd128ed1592931ba46ca5070594a9 (diff) | |
download | php-git-e286b286aea230a512ff0a3d3efd6e28da9b5da1.tar.gz |
Hopefully really fix #18022 this time.
-rwxr-xr-x | main/streams.c | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/main/streams.c b/main/streams.c index 71d823df81..53206246f3 100755 --- a/main/streams.c +++ b/main/streams.c @@ -703,7 +703,8 @@ PHPAPI size_t _php_stream_copy_to_stream(php_stream *src, php_stream *dest, size typedef struct { FILE *file; - int is_pipe; /* use pclose */ + int is_process_pipe; /* use pclose instead of fclose */ + int is_pipe; /* don't try and seek */ #if HAVE_FLUSHIO char last_op; #endif @@ -751,10 +752,24 @@ PHPAPI php_stream *_php_stream_fopen_tmpfile(int dummy STREAMS_DC TSRMLS_DC) PHPAPI php_stream *_php_stream_fopen_from_file(FILE *file, const char *mode STREAMS_DC TSRMLS_DC) { php_stdio_stream_data *self; - +#ifdef S_ISFIFO + int fd; +#endif + self = emalloc_rel_orig(sizeof(*self)); self->file = file; self->is_pipe = 0; + self->is_process_pipe = 0; + +#ifdef S_ISFIFO + /* detect if this is a pipe */ + fd = fileno(file); + if (fd >= 0) { + struct stat sb; + self->is_pipe = (fstat(fd, &sb) == 0 && S_ISFIFO(sb.st_mode)) ? 1 : 0; + } +#endif + return php_stream_alloc_rel(&php_stream_stdio_ops, self, 0, mode); } @@ -765,8 +780,10 @@ PHPAPI php_stream *_php_stream_fopen_from_pipe(FILE *file, const char *mode STRE self = emalloc_rel_orig(sizeof(*self)); self->file = file; self->is_pipe = 1; + self->is_process_pipe = 1; return php_stream_alloc_rel(&php_stream_stdio_ops, self, 0, mode); } + static size_t php_stdiop_write(php_stream *stream, const char *buf, size_t count TSRMLS_DC) { php_stdio_stream_data *data = (php_stdio_stream_data*)stream->abstract; @@ -814,7 +831,7 @@ static int php_stdiop_close(php_stream *stream, int close_handle TSRMLS_DC) assert(data != NULL); if (close_handle) { - if (data->is_pipe) { + if (data->is_process_pipe) { ret = pclose(data->file); } else { ret = fclose(data->file); @@ -844,6 +861,11 @@ static int php_stdiop_seek(php_stream *stream, off_t offset, int whence TSRMLS_D assert(data != NULL); + if (data->is_pipe) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "cannot seek on a pipe"); + return -1; + } + if (offset == 0 && whence == SEEK_CUR) return ftell(data->file); |