feat(buffers): add delete_buffer command and keybinding for buffer_palette
This commit is contained in:
parent
a4ac3a42fd
commit
0a632416a4
5 changed files with 50 additions and 5 deletions
|
@ -47,10 +47,18 @@ pub fn open_scratch(self: *Self, file_path: []const u8, content: []const u8) Buf
|
||||||
return buffer;
|
return buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn retire(_: *Self, buffer: *Buffer) void {
|
pub fn get_buffer_for_file(self: *Self, file_path: []const u8) ?*Buffer {
|
||||||
buffer.update_last_used_time();
|
return self.buffers.get(file_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn delete_buffer(self: *Self, file_path: []const u8) bool {
|
||||||
|
const buffer = self.buffers.get(file_path) orelse return false;
|
||||||
|
buffer.deinit();
|
||||||
|
return self.buffers.remove(file_path);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn retire(_: *Self, _: *Buffer) void {}
|
||||||
|
|
||||||
pub fn list_most_recently_used(self: *Self, allocator: std.mem.Allocator) error{OutOfMemory}![]*Buffer {
|
pub fn list_most_recently_used(self: *Self, allocator: std.mem.Allocator) error{OutOfMemory}![]*Buffer {
|
||||||
var buffers: std.ArrayListUnmanaged(*Buffer) = .{};
|
var buffers: std.ArrayListUnmanaged(*Buffer) = .{};
|
||||||
var i = self.buffers.iterator();
|
var i = self.buffers.iterator();
|
||||||
|
|
|
@ -285,6 +285,7 @@
|
||||||
["page_up", "palette_menu_pageup"],
|
["page_up", "palette_menu_pageup"],
|
||||||
["page_down", "palette_menu_pagedown"],
|
["page_down", "palette_menu_pagedown"],
|
||||||
["enter", "palette_menu_activate"],
|
["enter", "palette_menu_activate"],
|
||||||
|
["delete", "palette_menu_delete_item"],
|
||||||
["backspace", "overlay_delete_backwards"]
|
["backspace", "overlay_delete_backwards"]
|
||||||
],
|
],
|
||||||
"release": [
|
"release": [
|
||||||
|
|
|
@ -400,6 +400,25 @@ const cmds = struct {
|
||||||
}
|
}
|
||||||
pub const create_scratch_buffer_meta = .{ .arguments = &.{ .string, .string } };
|
pub const create_scratch_buffer_meta = .{ .arguments = &.{ .string, .string } };
|
||||||
|
|
||||||
|
pub fn delete_buffer(self: *Self, ctx: Ctx) Result {
|
||||||
|
var file_path: []const u8 = undefined;
|
||||||
|
if (!(ctx.args.match(.{tp.extract(&file_path)}) catch false))
|
||||||
|
return error.InvalidDeleteBufferArgument;
|
||||||
|
const buffer = self.buffer_manager.get_buffer_for_file(file_path) orelse return;
|
||||||
|
if (buffer.is_dirty())
|
||||||
|
return tp.exit("unsaved changes");
|
||||||
|
if (self.get_active_editor()) |editor| {
|
||||||
|
if (editor.buffer == buffer)
|
||||||
|
editor.close_file(.{}) catch |e| return e;
|
||||||
|
}
|
||||||
|
_ = self.buffer_manager.delete_buffer(file_path);
|
||||||
|
const logger = log.logger("buffer");
|
||||||
|
defer logger.deinit();
|
||||||
|
logger.print("deleted {s}", .{file_path});
|
||||||
|
tui.need_render();
|
||||||
|
}
|
||||||
|
pub const delete_buffer_meta = .{ .arguments = &.{.string} };
|
||||||
|
|
||||||
pub fn restore_session(self: *Self, _: Ctx) Result {
|
pub fn restore_session(self: *Self, _: Ctx) Result {
|
||||||
if (tp.env.get().str("project").len == 0) {
|
if (tp.env.get().str("project").len == 0) {
|
||||||
try open_project_cwd(self, .{});
|
try open_project_cwd(self, .{});
|
||||||
|
|
|
@ -6,6 +6,7 @@ const command = @import("command");
|
||||||
|
|
||||||
const tui = @import("../../tui.zig");
|
const tui = @import("../../tui.zig");
|
||||||
pub const Type = @import("palette.zig").Create(@This());
|
pub const Type = @import("palette.zig").Create(@This());
|
||||||
|
const module_name = @typeName(@This());
|
||||||
|
|
||||||
pub const label = "Switch buffers";
|
pub const label = "Switch buffers";
|
||||||
pub const name = " buffer";
|
pub const name = " buffer";
|
||||||
|
@ -43,7 +44,15 @@ fn select(menu: **Type.MenuState, button: *Type.ButtonState) void {
|
||||||
var file_path: []const u8 = undefined;
|
var file_path: []const u8 = undefined;
|
||||||
var iter = button.opts.label;
|
var iter = button.opts.label;
|
||||||
if (!(cbor.matchString(&iter, &file_path) catch false)) return;
|
if (!(cbor.matchString(&iter, &file_path) catch false)) return;
|
||||||
tp.self_pid().send(.{ "cmd", "exit_overlay_mode" }) catch |e| menu.*.opts.ctx.logger.err("navigate", e);
|
tp.self_pid().send(.{ "cmd", "exit_overlay_mode" }) catch |e| menu.*.opts.ctx.logger.err(module_name, e);
|
||||||
tp.self_pid().send(.{ "cmd", "navigate", .{} }) catch |e| menu.*.opts.ctx.logger.err("navigate", e);
|
tp.self_pid().send(.{ "cmd", "navigate", .{} }) catch |e| menu.*.opts.ctx.logger.err(module_name, e);
|
||||||
tp.self_pid().send(.{ "cmd", "navigate", .{ .file = file_path } }) catch |e| menu.*.opts.ctx.logger.err("navigate", e);
|
tp.self_pid().send(.{ "cmd", "navigate", .{ .file = file_path } }) catch |e| menu.*.opts.ctx.logger.err(module_name, e);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn delete_item(menu: *Type.MenuState, button: *Type.ButtonState) void {
|
||||||
|
var file_path: []const u8 = undefined;
|
||||||
|
var iter = button.opts.label;
|
||||||
|
if (!(cbor.matchString(&iter, &file_path) catch false)) return;
|
||||||
|
tp.self_pid().send(.{ "cmd", "exit_overlay_mode" }) catch |e| menu.*.opts.ctx.logger.err(module_name, e);
|
||||||
|
tp.self_pid().send(.{ "cmd", "delete_buffer", .{file_path} }) catch |e| menu.*.opts.ctx.logger.err(module_name, e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -428,6 +428,14 @@ pub fn Create(options: type) type {
|
||||||
}
|
}
|
||||||
pub const palette_menu_pageup_meta = .{};
|
pub const palette_menu_pageup_meta = .{};
|
||||||
|
|
||||||
|
pub fn palette_menu_delete_item(self: *Self, _: Ctx) Result {
|
||||||
|
if (@hasDecl(options, "delete_item")) {
|
||||||
|
const button = self.menu.get_selected() orelse return;
|
||||||
|
options.delete_item(self.menu, button);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub const palette_menu_delete_item_meta = .{};
|
||||||
|
|
||||||
pub fn palette_menu_activate(self: *Self, _: Ctx) Result {
|
pub fn palette_menu_activate(self: *Self, _: Ctx) Result {
|
||||||
self.menu.activate_selected();
|
self.menu.activate_selected();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue