input/file: export function OpenFileInputStream()

This commit is contained in:
Max Kellermann 2014-10-02 18:38:33 +02:00
parent 2f02e49b9f
commit 0d38bd9b3b
2 changed files with 37 additions and 13 deletions

View File

@ -23,7 +23,8 @@
#include "../InputPlugin.hxx" #include "../InputPlugin.hxx"
#include "util/Error.hxx" #include "util/Error.hxx"
#include "util/Domain.hxx" #include "util/Domain.hxx"
#include "fs/Traits.hxx" #include "fs/FileSystem.hxx"
#include "fs/Path.hxx"
#include "system/fd_util.h" #include "system/fd_util.h"
#include "open.h" #include "open.h"
@ -60,31 +61,29 @@ public:
bool Seek(offset_type offset, Error &error) override; bool Seek(offset_type offset, Error &error) override;
}; };
static InputStream * InputStream *
input_file_open(const char *filename, OpenFileInputStream(Path path,
Mutex &mutex, Cond &cond, Mutex &mutex, Cond &cond,
Error &error) Error &error)
{ {
if (!PathTraitsFS::IsAbsolute(filename)) const int fd = OpenFile(path, O_RDONLY|O_BINARY, 0);
return nullptr;
const int fd = open_cloexec(filename, O_RDONLY|O_BINARY, 0);
if (fd < 0) { if (fd < 0) {
if (errno != ENOTDIR) if (errno != ENOTDIR)
error.FormatErrno("Failed to open \"%s\"", error.FormatErrno("Failed to open \"%s\"",
filename); path.c_str());
return nullptr; return nullptr;
} }
struct stat st; struct stat st;
if (fstat(fd, &st) < 0) { if (fstat(fd, &st) < 0) {
error.FormatErrno("Failed to stat \"%s\"", filename); error.FormatErrno("Failed to stat \"%s\"", path.c_str());
close(fd); close(fd);
return nullptr; return nullptr;
} }
if (!S_ISREG(st.st_mode)) { if (!S_ISREG(st.st_mode)) {
error.Format(file_domain, "Not a regular file: %s", filename); error.Format(file_domain, "Not a regular file: %s",
path.c_str());
close(fd); close(fd);
return nullptr; return nullptr;
} }
@ -93,7 +92,21 @@ input_file_open(const char *filename,
posix_fadvise(fd, (off_t)0, st.st_size, POSIX_FADV_SEQUENTIAL); posix_fadvise(fd, (off_t)0, st.st_size, POSIX_FADV_SEQUENTIAL);
#endif #endif
return new FileInputStream(filename, fd, st.st_size, mutex, cond); return new FileInputStream(path.c_str(), fd, st.st_size, mutex, cond);
}
static InputStream *
input_file_open(const char *filename,
Mutex &mutex, Cond &cond,
Error &error)
{
if (!PathTraitsFS::IsAbsolute(filename))
return nullptr;
/* TODO: the parameter is UTF-8, not filesystem charset */
const Path path = Path::FromFS(filename);
return OpenFileInputStream(path, mutex, cond, error);
} }
bool bool

View File

@ -20,6 +20,17 @@
#ifndef MPD_INPUT_FILE_HXX #ifndef MPD_INPUT_FILE_HXX
#define MPD_INPUT_FILE_HXX #define MPD_INPUT_FILE_HXX
class InputStream;
class Path;
class Mutex;
class Cond;
class Error;
extern const struct InputPlugin input_plugin_file; extern const struct InputPlugin input_plugin_file;
InputStream *
OpenFileInputStream(Path path,
Mutex &mutex, Cond &cond,
Error &error);
#endif #endif