Skip to content

Commit

Permalink
getMediaCount do not fail if M/Counter is missing.
Browse files Browse the repository at this point in the history
- `M/Counter` is not mandatory.
- zimcheck doesn't check for it.
- we already accept a missing `M/Counter` in `getArticleCount`.

No reason to fail in `getMediaCount` if `M/Counter` is missing.

We test it by reading an empty zim file.
This reveal a bug in `getNamespaceBeginOffset` when there is no dirent
in the direntAccessor.
  • Loading branch information
mgautierfr committed Oct 10, 2023
1 parent bd8f79c commit 167be70
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 8 deletions.
21 changes: 13 additions & 8 deletions src/archive.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
4 changes: 4 additions & 0 deletions src/dirent_lookup.h
Original file line number Diff line number Diff line change
Expand Up @@ -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));
Expand Down
3 changes: 3 additions & 0 deletions test/archive.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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) {
Expand Down

0 comments on commit 167be70

Please sign in to comment.