From 9eda570311ffd292d333f7687074403ff46cc838 Mon Sep 17 00:00:00 2001 From: Albert Cervin Date: Mon, 23 Jan 2023 21:56:39 +0100 Subject: Implement some more commands - More bug fixes for keys: You can now have mod-less keys in keymaps as binds. - Fix calculation bug with space fillouts. --- src/buffer.h | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'src/buffer.h') diff --git a/src/buffer.h b/src/buffer.h index cf9c269..dcc4a8c 100644 --- a/src/buffer.h +++ b/src/buffer.h @@ -4,6 +4,7 @@ #include "command.h" #include "text.h" +#include "window.h" struct keymap; struct reactor; @@ -48,8 +49,8 @@ struct modeline { }; struct buffer { - const char *name; - const char *filename; + char *name; + char *filename; struct text *text; @@ -67,7 +68,7 @@ struct buffer { struct update_hooks update_hooks; }; -struct buffer buffer_create(const char *name, bool modeline); +struct buffer buffer_create(char *name, bool modeline); void buffer_destroy(struct buffer *buffer); uint32_t buffer_keymaps(struct buffer *buffer, struct keymap **keymaps_out); @@ -89,10 +90,12 @@ void buffer_beginning_of_line(struct buffer *buffer); void buffer_newline(struct buffer *buffer); void buffer_indent(struct buffer *buffer); +struct text_chunk buffer_get_line(struct buffer *buffer, uint32_t line); + uint32_t buffer_add_update_hook(struct buffer *buffer, update_hook_cb hook, void *userdata); -struct buffer buffer_from_file(const char *filename, struct reactor *reactor); +struct buffer buffer_from_file(char *filename); void buffer_to_file(struct buffer *buffer); void buffer_update(struct buffer *buffer, uint32_t width, uint32_t height, @@ -103,7 +106,7 @@ void buffer_update(struct buffer *buffer, uint32_t width, uint32_t height, #define BUFFER_WRAPCMD(fn) \ static int32_t fn##_cmd(struct command_ctx ctx, int argc, \ const char *argv[]) { \ - fn(ctx.current_buffer); \ + fn(ctx.active_window->buffer); \ return 0; \ } -- cgit v1.2.3