Commit fa13648f authored by Max Kellermann's avatar Max Kellermann

archive/ArchiveLookup: throw on error

parent 2f83ed90
......@@ -20,6 +20,7 @@
#include "ArchiveLookup.hxx"
#include "ArchiveDomain.hxx"
#include "Log.hxx"
#include "system/Error.hxx"
#include <string.h>
#include <sys/stat.h>
......@@ -60,11 +61,9 @@ archive_lookup(char *pathname, const char **archive,
//try to stat if its real directory
struct stat st_info;
if (stat(pathname, &st_info) == -1) {
if (errno != ENOTDIR) {
FormatErrno(archive_domain,
"Failed to stat %s", pathname);
return false;
}
int e = errno;
if (e != ENOTDIR)
throw FormatErrno(e, "Failed to stat %s", pathname);
} else {
//is something found ins original path (is not an archive)
if (slash == nullptr)
......
......@@ -36,6 +36,8 @@
* is split into archive: /music/path/Talco.zip
* inarchive pathname: Talco - Combat Circus/12 - A la pachenka.mp3
* and suffix: zip
*
* Throws on error.
*/
bool
archive_lookup(char *pathname, const char **archive,
......
......@@ -45,9 +45,15 @@ OpenArchiveInputStream(Path path, Mutex &mutex)
// archive_lookup will modify pname when true is returned
const char *archive, *filename, *suffix;
if (!archive_lookup(pname, &archive, &filename, &suffix)) {
FormatDebug(archive_domain,
"not an archive, lookup %s failed", pname);
try {
if (!archive_lookup(pname, &archive, &filename, &suffix)) {
FormatDebug(archive_domain,
"not an archive, lookup %s failed", pname);
return nullptr;
}
} catch (...) {
LogFormat(LogLevel::DEBUG, std::current_exception(),
"not an archive, lookup %s failed", pname);
return nullptr;
}
......
......@@ -11,7 +11,8 @@ TEST(ArchiveTest, Lookup)
const char *archive, *inpath, *suffix;
char *path = strdup("");
EXPECT_FALSE(archive_lookup(path, &archive, &inpath, &suffix));
EXPECT_THROW(archive_lookup(path, &archive, &inpath, &suffix),
std::system_error);
free(path);
path = strdup(".");
......@@ -23,7 +24,8 @@ TEST(ArchiveTest, Lookup)
free(path);
path = strdup("src/foo/bar");
EXPECT_FALSE(archive_lookup(path, &archive, &inpath, &suffix));
EXPECT_THROW(archive_lookup(path, &archive, &inpath, &suffix),
std::system_error);
free(path);
fclose(fopen("dummy", "w"));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment