Start over to clear my head
This commit is contained in:
@@ -1,81 +0,0 @@
|
||||
const std = @import("std");
|
||||
|
||||
const CompressionType = @import("decompress.zig").CompressionType;
|
||||
|
||||
const DirHeader = packed struct {
|
||||
count: u32,
|
||||
inode_block_start: u32,
|
||||
inode_num: u32,
|
||||
};
|
||||
|
||||
const RawDirEntry = struct {
|
||||
inode_offset: u16,
|
||||
inode_num_difference: i16,
|
||||
inode_type: u16,
|
||||
name_size: u16,
|
||||
name: []u8,
|
||||
|
||||
fn init(rdr: std.io.AnyReader, alloc: std.mem.Allocator) !RawDirEntry {
|
||||
var out: RawDirEntry = .{
|
||||
.inode_offset = try rdr.readInt(u16, std.builtin.Endian.little),
|
||||
.inode_num_difference = try rdr.readInt(i16, std.builtin.Endian.little),
|
||||
.inode_type = try rdr.readInt(u16, std.builtin.Endian.little),
|
||||
.name_size = try rdr.readInt(u16, std.builtin.Endian.little),
|
||||
.name = undefined,
|
||||
};
|
||||
out.name = try alloc.alloc(u8, out.name_size);
|
||||
_ = try rdr.readAll(out.name);
|
||||
return out;
|
||||
}
|
||||
};
|
||||
|
||||
pub const DirEntry = struct {
|
||||
inode_offset: u16,
|
||||
inode_block_start: u32,
|
||||
inode_num: u32,
|
||||
name: []u8,
|
||||
|
||||
fn init(raw: RawDirEntry, hdr: DirHeader) DirEntry {
|
||||
return .{
|
||||
.inode_offset = raw.inode_offset,
|
||||
.inode_block_start = hdr.inode_block_start,
|
||||
.inode_num = hdr.inode_num + @as(u32, @intCast(raw.inode_num_difference)),
|
||||
.name = raw.name,
|
||||
};
|
||||
}
|
||||
};
|
||||
|
||||
const MetadataHeader = @import("metadata_reader.zig").MetadataHeader;
|
||||
|
||||
pub fn readDirEntries(alloc: std.mem.Allocator, comp: CompressionType, rdr: std.io.AnyReader, size: u32) ![]DirEntry {
|
||||
var total_size: u32 = 3;
|
||||
var meta_hdr: MetadataHeader = undefined;
|
||||
var dir_hdr: DirHeader = undefined;
|
||||
var buf: []u8 = undefined;
|
||||
defer alloc.free(buf);
|
||||
var buf_rdr: std.io.FixedBufferStream([]u8) = undefined;
|
||||
var i: u32 = 0;
|
||||
var entries: std.ArrayList(DirEntry) = .init(alloc);
|
||||
var raw: RawDirEntry = undefined;
|
||||
while (total_size < size) {
|
||||
meta_hdr = try rdr.readStruct(MetadataHeader);
|
||||
if (meta_hdr.not_compressed) {
|
||||
buf = try alloc.realloc(buf, meta_hdr.size);
|
||||
_ = try rdr.readAll(buf);
|
||||
} else {
|
||||
alloc.free(buf);
|
||||
var limit = std.io.limitedReader(rdr, meta_hdr.size);
|
||||
buf = try comp.decompress(alloc, limit.reader().any());
|
||||
}
|
||||
buf_rdr = std.io.fixedBufferStream(buf);
|
||||
dir_hdr = try buf_rdr.reader().readStruct(DirHeader);
|
||||
total_size += 12;
|
||||
i = 0;
|
||||
while (i < dir_hdr.count) : (i += 1) {
|
||||
raw = try .init(buf_rdr.reader().any(), alloc);
|
||||
total_size += @sizeOf(RawDirEntry);
|
||||
try entries.append(.init(raw, dir_hdr));
|
||||
}
|
||||
}
|
||||
return try entries.toOwnedSlice();
|
||||
}
|
||||
Reference in New Issue
Block a user