X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Fclient%2Fkeybindings.h;h=c6477c855d4882e38dcb3293712edfc2ea506d4d;hb=ef60270da2acf29953b411632e26503d7787d9d8;hp=b191c59bbbc9e1d160dd5fe2cfa650156804d715;hpb=f118d194b29320b6fbebd254207514aba1241b08;p=plomrogue
diff --git a/src/client/keybindings.h b/src/client/keybindings.h
index b191c59..c6477c8 100644
--- a/src/client/keybindings.h
+++ b/src/client/keybindings.h
@@ -7,43 +7,40 @@
#define KEYBINDINGS_H
#include /* uint8_t, uint16_t */
+#include /* FILE */
struct Command;
struct KeyBinding
{
- struct KeyBinding * next;
- uint16_t key; /* keycode */
+ uint16_t keycode;
struct Command * command; /* command in command DB to which key is bound */
};
struct KeyBindingDB
{
struct KeyBinding * kbs;
+ uint16_t n_of_kbs; /* how many KeyBinding structs are stored below .kbs? */
uint16_t select; /* linear list index of keybinding selected for editing */
uint8_t edit; /* 1 if currently editing a keybinding, else 0 */
};
-/* Return command bound to keycode; NULL on failure. */
-extern struct Command * get_command_to_keycode(struct KeyBinding * kb_p,
- uint16_t key);
+/* Return command bound to "keycode" in "kbdb"; NULL if none found. */
+extern struct Command * get_command_to_keycode(struct KeyBindingDB * kbdb,
+ uint16_t keycode);
/* Return human-readable name (of maximum 9 chars) for "keycode" as matched by
- * ncurses.h; if none is found, return "UNKNOWN".
+ * ncurses.h; if none is found, return "(unknown)".
*/
extern char * get_keyname_to_keycode(uint16_t keycode);
-/* Initialize/save keybindings data from/to file at "path" to/from keybindings
- * data pointer "kbd".
- */
-extern void init_keybindings(char * path, struct KeyBindingDB * kbd);
-extern void save_keybindings(char * path, struct KeyBindingDB * kbd);
-
-/* Free keybinding chain starting at "kb_start". */
-extern void free_keybindings(struct KeyBinding * kb_start);
+/* Read/write from/to "file" "kbd", delimited by world.delim. */
+extern void write_keybindings_to_file(FILE * file, struct KeyBindingDB * kbd);
+extern void read_keybindings_from_file(char * line, uint32_t linemax,
+ FILE * file, struct KeyBindingDB * kbd);
/* Mark keybinding in KeybindingDB (char_selected_kb_db()-) selected by "kb_c"
* as being edited, get user input to modify it, then unmark it again. Ensure