feat(buffers): use buffer_manager to select most recent files

And remove obsolete file_stack.
This commit is contained in:
CJ van den Berg 2025-01-24 23:22:31 +01:00
parent d7b48b40f1
commit 5e6fc6a932
Signed by: neurocyte
GPG key ID: 8EB1E1BB660E3FB9
2 changed files with 41 additions and 31 deletions

View file

@ -62,17 +62,22 @@ pub fn delete_buffer(self: *Self, file_path: []const u8) bool {
pub fn retire(_: *Self, _: *Buffer) void {}
pub fn list_most_recently_used(self: *Self, allocator: std.mem.Allocator) error{OutOfMemory}![]*Buffer {
var buffers: std.ArrayListUnmanaged(*Buffer) = .{};
var i = self.buffers.iterator();
while (i.next()) |kv|
(try buffers.addOne(allocator)).* = kv.value_ptr.*;
const result = try self.list_unordered(allocator);
std.mem.sort(*Buffer, buffers.items, {}, struct {
std.mem.sort(*Buffer, result, {}, struct {
fn less_fn(_: void, lhs: *Buffer, rhs: *Buffer) bool {
return lhs.utime > rhs.utime;
}
}.less_fn);
return result;
}
pub fn list_unordered(self: *Self, allocator: std.mem.Allocator) error{OutOfMemory}![]*Buffer {
var buffers = try std.ArrayListUnmanaged(*Buffer).initCapacity(allocator, self.buffers.size);
var i = self.buffers.iterator();
while (i.next()) |kv|
(try buffers.addOne(allocator)).* = kv.value_ptr.*;
return buffers.toOwnedSlice(allocator);
}
@ -95,3 +100,12 @@ pub fn save_all(self: *const Self) Buffer.StoreToFileError!void {
try buffer.store_to_file_and_clean(buffer.file_path);
}
}
pub fn delete_all(self: *Self) void {
var i = self.buffers.iterator();
while (i.next()) |p| {
self.allocator.free(p.key_ptr.*);
p.value_ptr.*.deinit();
}
self.buffers.clearRetainingCapacity();
}