summaryrefslogtreecommitdiff
path: root/src/buffers.c
diff options
context:
space:
mode:
authorAlbert Cervin <albert@acervin.com>2023-01-23 21:56:39 +0100
committerAlbert Cervin <albert@acervin.com>2023-01-23 21:56:39 +0100
commit9eda570311ffd292d333f7687074403ff46cc838 (patch)
tree40265e3d2c23831afaf352bb64b8d6634bae9730 /src/buffers.c
parent385c9d62a5507d901ff7e54d7a4c0342cf3aff43 (diff)
downloaddged-9eda570311ffd292d333f7687074403ff46cc838.tar.gz
dged-9eda570311ffd292d333f7687074403ff46cc838.tar.xz
dged-9eda570311ffd292d333f7687074403ff46cc838.zip
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.
Diffstat (limited to 'src/buffers.c')
-rw-r--r--src/buffers.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/buffers.c b/src/buffers.c
new file mode 100644
index 0000000..479caa5
--- /dev/null
+++ b/src/buffers.c
@@ -0,0 +1,42 @@
+#include "buffers.h"
+#include "buffer.h"
+
+#include <stdlib.h>
+#include <string.h>
+
+void buffers_init(struct buffers *buffers, uint32_t initial_capacity) {
+ buffers->buffers = calloc(initial_capacity, sizeof(struct buffer));
+ buffers->nbuffers = 0;
+ buffers->capacity = initial_capacity;
+}
+
+struct buffer *buffers_add(struct buffers *buffers, struct buffer buffer) {
+ if (buffers->nbuffers == buffers->capacity) {
+ buffers->capacity *= 2;
+ buffers->buffers =
+ realloc(buffers->buffers, sizeof(struct buffer) * buffers->capacity);
+ }
+
+ buffers->buffers[buffers->nbuffers] = buffer;
+ ++buffers->nbuffers;
+
+ return &buffers->buffers[buffers->nbuffers - 1];
+}
+
+struct buffer *buffers_find(struct buffers *buffers, const char *name) {
+ for (uint32_t bufi = 0; bufi < buffers->nbuffers; ++bufi) {
+ if (strcmp(name, buffers->buffers[bufi].name) == 0) {
+ return &buffers->buffers[bufi];
+ }
+ }
+
+ return NULL;
+}
+
+void buffers_destroy(struct buffers *buffers) {
+ for (uint32_t bufi = 0; bufi < buffers->nbuffers; ++bufi) {
+ buffer_destroy(&buffers->buffers[bufi]);
+ }
+
+ buffers->nbuffers = 0;
+}