summaryrefslogtreecommitdiffstats
path: root/stream/stream_file.c
diff options
context:
space:
mode:
Diffstat (limited to 'stream/stream_file.c')
-rw-r--r--stream/stream_file.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/stream/stream_file.c b/stream/stream_file.c
index 1c5223073b..d649ff4bdf 100644
--- a/stream/stream_file.c
+++ b/stream/stream_file.c
@@ -246,7 +246,7 @@ static bool check_stream_network(int fd)
}
#endif
-static int open_f(stream_t *stream)
+static int open_f(stream_t *stream, struct stream_open_args *args)
{
struct priv *p = talloc_ptrtype(stream, p);
*p = (struct priv) {
@@ -255,18 +255,21 @@ static int open_f(stream_t *stream)
stream->priv = p;
stream->is_local_file = true;
+ bool strict_fs = args->flags & STREAM_LOCAL_FS_ONLY;
bool write = stream->mode == STREAM_WRITE;
int m = O_CLOEXEC | (write ? O_RDWR | O_CREAT | O_TRUNC : O_RDONLY);
- char *filename = mp_file_url_to_filename(stream, bstr0(stream->url));
- if (filename) {
- stream->path = filename;
- } else {
- filename = stream->path;
+ char *filename = stream->path;
+ char *url = "";
+ if (!strict_fs) {
+ char *fn = mp_file_url_to_filename(stream, bstr0(stream->url));
+ if (fn)
+ filename = stream->path = fn;
+ url = stream->url;
}
- bool is_fdclose = strncmp(stream->url, "fdclose://", 10) == 0;
- if (strncmp(stream->url, "fd://", 5) == 0 || is_fdclose) {
+ bool is_fdclose = strncmp(url, "fdclose://", 10) == 0;
+ if (strncmp(url, "fd://", 5) == 0 || is_fdclose) {
char *begin = strstr(stream->url, "://") + 3, *end = NULL;
p->fd = strtol(begin, &end, 0);
if (!end || end == begin || end[0]) {
@@ -275,7 +278,7 @@ static int open_f(stream_t *stream)
}
if (is_fdclose)
p->close = true;
- } else if (!strcmp(filename, "-")) {
+ } else if (!strict_fs && !strcmp(filename, "-")) {
if (!write) {
MP_INFO(stream, "Reading from stdin...\n");
p->fd = 0;
@@ -306,7 +309,8 @@ static int open_f(stream_t *stream)
if (fstat(p->fd, &st) == 0) {
if (S_ISDIR(st.st_mode)) {
stream->is_directory = true;
- MP_INFO(stream, "This is a directory - adding to playlist.\n");
+ if (!(args->flags & STREAM_LESS_NOISE))
+ MP_INFO(stream, "This is a directory - adding to playlist.\n");
} else if (S_ISREG(st.st_mode)) {
p->regular_file = true;
#ifndef __MINGW32__
@@ -350,15 +354,16 @@ static int open_f(stream_t *stream)
const stream_info_t stream_info_file = {
.name = "file",
- .open = open_f,
+ .open2 = open_f,
.protocols = (const char*const[]){ "file", "", "appending", NULL },
.can_write = true,
+ .local_fs = true,
.stream_origin = STREAM_ORIGIN_FS,
};
const stream_info_t stream_info_fd = {
.name = "fd",
- .open = open_f,
+ .open2 = open_f,
.protocols = (const char*const[]){ "fd", "fdclose", NULL },
.can_write = true,
.stream_origin = STREAM_ORIGIN_UNSAFE,