X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=src%2Fclient%2Fdraw_wins.c;h=5c35dd6cc2939e5f2176b1a6aec3e9cbb08b14c3;hb=91b0bb33921c0990fbd07e15049e48643f26d7b2;hp=590d8c53cd49aa90afbc531c499fd05033a7d851;hpb=29dd705d21a373c5bd011abfa6f55243b0d8d8a1;p=plomrogue diff --git a/src/client/draw_wins.c b/src/client/draw_wins.c index 590d8c5..5c35dd6 100644 --- a/src/client/draw_wins.c +++ b/src/client/draw_wins.c @@ -1,5 +1,6 @@ /* src/client/draw_wins.c */ +#define _POSIX_C_SOURCE 200809L /* strdup() */ #include "draw_wins.h" #include /* typedefs attr_t, chtype, define A_REVERSE */ #include /* NULL */ @@ -52,7 +53,7 @@ static void add_text_with_linebreaks(struct Win * win, char * text); static void draw_text_from_bottom(struct Win * win, char * text); /* Return a properly formatted keybinding list line for "kb". */ -static char * get_kb_line(struct KeyBinding * kb, uint8_t linebreak_type); +static char * get_kb_line(struct KeyBinding * kb); /* Draw from line "start" on config view for keybindings defined at "kb". */ static void draw_keybinding_config(struct Win * win, struct KeyBindingDB * kbdb, @@ -185,7 +186,8 @@ static void add_line_compact(struct Win * win, char * line, attr_t attri, uint32_t len_line_new = len_line + strlen(separator); char line_new[len_line_new]; sprintf(line_new, "%s%s", line, separator); - uint16_t x, y; + uint16_t x = 0; + uint16_t y; uint32_t z; for (z = 0, y = y_start; z < len_line_new; y++) { @@ -203,7 +205,7 @@ static void add_line_compact(struct Win * win, char * line, attr_t attri, try_resize_winmap(win, y + 1 + 1, win->winmap_size.x); } } - * offset = x; + *offset = x; } @@ -254,20 +256,13 @@ static void draw_text_from_bottom(struct Win * win, char * text) -static char * get_kb_line(struct KeyBinding * kb, uint8_t linebreak_type) +static char * get_kb_line(struct KeyBinding * kb) { char * f_name = "get_kb_line()"; char * keyname = get_keyname_to_keycode(kb->keycode); - char * format = "%-9s %s"; - uint16_t first_size = 9; - if (1 != linebreak_type) - { - format = "%s: %s"; - first_size = strlen(keyname) + 1; - } - uint16_t size = first_size + 1 + strlen(kb->command->dsc_long) + 1; + uint16_t size = strlen(keyname) + 3 + strlen(kb->command->dsc_long) + 1; char * kb_line = try_malloc(size, f_name); - sprintf(kb_line, format, keyname, kb->command->dsc_long); + sprintf(kb_line, "%s - %s", keyname, kb->command->dsc_long); free(keyname); return kb_line; } @@ -282,7 +277,7 @@ static void draw_keybinding_config(struct Win * win, struct KeyBindingDB * kbdb, add_line(win, "(none)", 0, &offset, 0); return; } - uint16_t kb_n; + uint8_t kb_n; for (kb_n = 0; kb_n < kbdb->n_of_kbs; kb_n++) { attr_t attri = 0; @@ -295,7 +290,7 @@ static void draw_keybinding_config(struct Win * win, struct KeyBindingDB * kbdb, } win->center.y = win->winmap_size.y; } - char * kb_line = get_kb_line(&kbdb->kbs[kb_n], win->linebreak); + char * kb_line = get_kb_line(&kbdb->kbs[kb_n]); add_line(win, kb_line, attri, &offset, (kbdb->n_of_kbs == kb_n + 1)); free(kb_line); } @@ -308,7 +303,7 @@ static void draw_titled_keybinding_list(char * title, struct Win * win, struct KeyBindingDB * kbdb) { uint8_t state = 0; - uint16_t kb_n = 0; + uint8_t kb_n = 0; while (0 == state || kb_n < kbdb->n_of_kbs) { if (0 == state) @@ -318,7 +313,7 @@ static void draw_titled_keybinding_list(char * title, struct Win * win, state = 1 + (0 == kbdb->n_of_kbs); continue; } - char * kb_line = get_kb_line(&kbdb->kbs[kb_n], win->linebreak); + char * kb_line = get_kb_line(&kbdb->kbs[kb_n]); add_line(win, kb_line, 0, offset, (last * kbdb->n_of_kbs == kb_n + 1)); free(kb_line); kb_n++; @@ -344,14 +339,14 @@ extern void draw_win_log(struct Win * win) extern void draw_win_map(struct Win * win) { - try_resize_winmap(win, world.map.size.y, world.map.size.x); + try_resize_winmap(win, world.map.size.y, world.map.size.x * 2); uint16_t z = 0; uint16_t x, y; for (y = 0; y < world.map.size.y; y++) { for (x = 0; x < world.map.size.x; x++) { - set_ch_on_yx(win, y, x, world.map.cells[z]); + set_ch_on_yx(win, y, x * 2 + (y % 2), world.map.cells[z]); z++; } } @@ -403,14 +398,10 @@ extern void draw_win_inventory(struct Win * win) extern void draw_win_available_keybindings(struct Win * win) { - char * title = "Active window's keybindings:"; - struct KeyBindingDB * kbdb; + char * title = "Active window's keys:"; struct Win * win_active = get_win_by_id(world.winDB.active); - if (0 == win_active->view) - { - kbdb = &win_active->kb; - } - else if (1 == win_active->view) + struct KeyBindingDB * kbdb = &win_active->kb; + if (1 == win_active->view) { kbdb = &world.kb_wingeom; } @@ -421,7 +412,7 @@ extern void draw_win_available_keybindings(struct Win * win) uint16_t offset = 0; draw_titled_keybinding_list(title, win, &offset, 0, kbdb); add_line(win, " ", 0, &offset, 0); - title = "Global keybindings:"; + title = "Global keys:"; draw_titled_keybinding_list(title, win, &offset, 1, &world.kb_global); } @@ -454,7 +445,7 @@ extern void draw_win_keybindings_winconf_keybindings(struct Win * win) extern void draw_winconf_keybindings(struct Win * win) { - char * title = "Window's keybindings:"; + char * title = "Window's keys:"; uint16_t offset = 0; add_line(win, title, 0, &offset, 0); add_line(win, " ", 0, &offset, 0);