fix: re-write save_as to work properly with multiple buffers

This commit is contained in:
CJ van den Berg 2025-08-05 13:42:19 +02:00
parent 3cace58049
commit 886a2582a3
Signed by: neurocyte
GPG key ID: 8EB1E1BB660E3FB9
2 changed files with 42 additions and 17 deletions

View file

@ -722,15 +722,6 @@ pub const Editor = struct {
self.update_event() catch {};
}
fn save_as(self: *Self, file_path: []const u8) !void {
if (self.buffer) |b_mut| try b_mut.store_to_file_and_clean(file_path);
if (self.file_path) |old_file_path| self.allocator.free(old_file_path);
self.file_path = try self.allocator.dupe(u8, file_path);
try self.send_editor_save(self.file_path.?);
self.last.dirty = false;
self.update_event() catch {};
}
pub fn push_cursor(self: *Self) !void {
const primary = self.cursels.getLastOrNull() orelse CurSel{} orelse CurSel{};
(try self.cursels.addOne(self.allocator)).* = primary;
@ -4950,14 +4941,6 @@ pub const Editor = struct {
}
pub const save_file_without_formatting_meta: Meta = .{ .description = "Save file without formatting" };
pub fn save_file_as(self: *Self, ctx: Context) Result {
var file_path: []const u8 = undefined;
if (ctx.args.match(.{tp.extract(&file_path)}) catch false) {
try self.save_as(file_path);
} else return error.InvalidSafeFileAsArgument;
}
pub const save_file_as_meta: Meta = .{ .arguments = &.{.string} };
pub fn close_file(self: *Self, _: Context) Result {
const buffer_ = self.buffer;
if (buffer_) |buffer| if (buffer.is_dirty())