X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Fclient%2Fkeybindings.h;h=c6477c855d4882e38dcb3293712edfc2ea506d4d;hb=862d185c9f3836499717010ea0b1eafd4bfae97b;hp=ea09d6582e5e2ab41a7d1fdedd37928d1c167277;hpb=21cac2d976f806643aee1471bcee7b38597ac121;p=plomrogue
diff --git a/src/client/keybindings.h b/src/client/keybindings.h
index ea09d65..c6477c8 100644
--- a/src/client/keybindings.h
+++ b/src/client/keybindings.h
@@ -7,56 +7,51 @@
#define KEYBINDINGS_H
#include /* uint8_t, uint16_t */
+#include /* FILE */
+struct Command;
struct KeyBinding
{
- struct KeyBinding * next;
- uint16_t key; /* keycode */
- char * command; /* name of command / functionality bound to 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 name of command / functionality bound to keycode; NULL on failure. */
-extern char * get_command_to_keycode(struct KeyBinding * kb_p, uint16_t key);
-
-/* Return keycode bound to "command". */
-extern uint16_t get_keycode_to_command(struct KeyBinding * keybindings,
- char * command);
+/* 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 selected for modification as being edited, get user input to
- * modify it, then unmark it again. Ensure there are max. three digits in the
- * ASCII representation of the keycode read from the user.
+/* 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
+ * there are max. three digits in the ASCII string of the kecode read from user.
*/
-extern void mod_selected_keyb(struct KeyBindingDB * kbd);
+extern void mod_selected_keyb(char kb_c);
-/* Move keybinding modification selection upwards ("dir"=="u") or downwards
- * ("dir"=="d") within the limits of the keybindings chain length.
+/* Move .select in KeybindingDB (char-selected_kb_db()-) selected by "kb_c"
+ * upwards ("dir"=="u") or downwards ("dir"=="d") within KeyBindingDB limits.
*/
-extern void move_keyb_mod_selection(struct KeyBindingDB * kbd, char dir);
+extern void move_keyb_selection(char kb_c, char dir);