Browse Source

file: Fallback to stat() based file_check() when access() or its named flags are unavailable.

Should fix compilation on native windows
We could also use _access() and literal numbers as flags but i cant test it
and the compilation failure should be fixed ASAP

Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
tags/n1.1
Michael Niedermayer 13 years ago
parent
commit
16ef48c37f
1 changed files with 10 additions and 0 deletions
  1. +10
    -0
      libavformat/file.c

+ 10
- 0
libavformat/file.c View File

@@ -85,6 +85,7 @@ static int file_get_handle(URLContext *h)

static int file_check(URLContext *h, int mask)
{
#if defined(HAVE_ACCESS) && defined(R_OK)
int ret = 0;
if (access(h->filename, F_OK) < 0)
return AVERROR(errno);
@@ -94,6 +95,15 @@ static int file_check(URLContext *h, int mask)
if (mask&AVIO_FLAG_WRITE)
if (access(h->filename, W_OK) >= 0)
ret |= AVIO_FLAG_WRITE;
#else
struct stat st;
int ret = stat(h->filename, &st);
if (ret < 0)
return AVERROR(errno);

ret |= st.st_mode&S_IRUSR ? mask&AVIO_FLAG_READ : 0;
ret |= st.st_mode&S_IWUSR ? mask&AVIO_FLAG_WRITE : 0;
#endif
return ret;
}



Loading…
Cancel
Save