diff options
author | Lukas Fleischer <calcurse@cryptocrack.de> | 2012-12-05 15:51:01 +0100 |
---|---|---|
committer | Lukas Fleischer <calcurse@cryptocrack.de> | 2012-12-05 15:57:29 +0100 |
commit | db8886a34cfc026b7a95ab0256317e5ec7ce728a (patch) | |
tree | 4deced811b31a4ef9c1f4223a233140b6ee7ae4d /src | |
parent | a9cbf27536b2f9b8c16055b35b851b9f2caf4f4a (diff) | |
download | calcurse-db8886a34cfc026b7a95ab0256317e5ec7ce728a.tar.gz calcurse-db8886a34cfc026b7a95ab0256317e5ec7ce728a.zip |
keys_save_bindings(): Skip unset key bindings
Saving unset key bindings currently results in a segmentation fault or
invalid key specifiers being stored. Skip these entries to avoid this.
Signed-off-by: Lukas Fleischer <calcurse@cryptocrack.de>
Diffstat (limited to 'src')
-rw-r--r-- | src/keys.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -547,11 +547,15 @@ void keys_popup_info(enum key key) void keys_save_bindings(FILE * fd) { int i; + char *action; EXIT_IF(fd == NULL, _("FATAL ERROR: null file pointer.")); dump_intro(fd); - for (i = 0; i < NBKEYS; i++) - fprintf(fd, "%s %s\n", keydef[i].label, keys_action_allkeys(i)); + for (i = 0; i < NBKEYS; i++) { + action = keys_action_allkeys(i); + if (action) + fprintf(fd, "%s %s\n", keydef[i].label, action); + } } int keys_check_missing_bindings(void) |