diff --git a/src/archive.cpp b/src/archive.cpp index 24071ec4a..17f33157d 100644 --- a/src/archive.cpp +++ b/src/archive.cpp @@ -85,14 +85,19 @@ namespace zim entry_index_type Archive::getMediaCount() const { - return countMimeType( - getMetadata("Counter"), - [](const std::string& mimetype) { - return mimetype.find("image/") == 0 || - mimetype.find("video/") == 0 || - mimetype.find("audio/") == 0; - } - ); + try { + return countMimeType( + getMetadata("Counter"), + [](const std::string& mimetype) { + return mimetype.find("image/") == 0 || + mimetype.find("video/") == 0 || + mimetype.find("audio/") == 0; + } + ); + } catch(const EntryNotFound& e) { + return (m_impl->getNamespaceEntryCount('I').v + + m_impl->getNamespaceEntryCount('J').v); + } } Uuid Archive::getUuid() const diff --git a/src/dirent_lookup.h b/src/dirent_lookup.h index 5daefa414..ffb76efaa 100644 --- a/src/dirent_lookup.h +++ b/src/dirent_lookup.h @@ -131,6 +131,10 @@ entry_index_t getNamespaceBeginOffset(TDirentAccessor& direntAccessor, char ch) ASSERT(ch, >=, 32); ASSERT(ch, <=, 127); + if (direntAccessor.getDirentCount().v == 0) { + return entry_index_t(0); + } + entry_index_type lower = 0; entry_index_type upper = entry_index_type(direntAccessor.getDirentCount()); auto d = direntAccessor.getDirent(entry_index_t(0)); diff --git a/test/archive.cpp b/test/archive.cpp index ee6eee983..55e520e14 100644 --- a/test/archive.cpp +++ b/test/archive.cpp @@ -105,6 +105,9 @@ TEST(ZimArchive, openingAnEmptyZimArchiveSucceeds) zim::Archive archive(tmpfile->path()); ASSERT_TRUE(archive.check()); + + ASSERT_EQ(archive.getMediaCount(), 0); + ASSERT_EQ(archive.getArticleCount(), 0); } bool isNastyOffset(int offset) {