#include "chrome/utility/safe_browsing/mac/dmg_iterator.h"
#include <memory>
#include "base/metrics/histogram_functions.h"
#include "chrome/utility/safe_browsing/mac/hfs.h"
#include "chrome/utility/safe_browsing/mac/read_stream.h"
namespace safe_browsing {
namespace dmg {
DMGIterator::DMGIterator(ReadStream* stream)
: udif_(stream),
partitions_(),
current_partition_(0),
hfs_() {
}
DMGIterator::~DMGIterator() = default;
bool DMGIterator::Open() {
if (!udif_.Parse()) {
return false;
}
for (size_t i = 0; i < udif_.GetNumberOfPartitions(); ++i) {
std::unique_ptr<ReadStream> partition = udif_.GetPartitionReadStream(i);
HFSIterator hfs(partition.get());
if (hfs.Open()) {
partitions_.push_back(std::move(partition));
}
}
return true;
}
const std::vector<uint8_t>& DMGIterator::GetCodeSignature() {
return udif_.GetCodeSignature();
}
bool DMGIterator::Next() {
for (; current_partition_ < partitions_.size(); ++current_partition_) {
if (!hfs_) {
hfs_ =
std::make_unique<HFSIterator>(partitions_[current_partition_].get());
if (!hfs_->Open())
continue;
}
while (true) {
if (!hfs_->Next())
break;
if (hfs_->IsDirectory() || hfs_->IsSymbolicLink())
continue;
if (hfs_->IsHardLink())
continue;
if (hfs_->IsDecmpfsCompressed())
continue;
return true;
}
hfs_.reset();
}
return false;
}
std::u16string DMGIterator::GetPath() {
return hfs_->GetPath();
}
std::unique_ptr<ReadStream> DMGIterator::GetReadStream() {
return hfs_->GetReadStream();
}
bool DMGIterator::IsEmpty() {
return partitions_.empty();
}
}
}