X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Fclient%2Fcontrol.c;h=1961334c0015064f103b825f64aaf89651652000;hb=84bac26d9f4c37599fa0ad2a51d729480fccbadf;hp=ad94ea10c11c0e02d51de6ad188964704e9e777d;hpb=f9d5829b125ef2df8d63bc08761be33f93c65691;p=plomrogue
diff --git a/src/client/control.c b/src/client/control.c
index ad94ea1..1961334 100644
--- a/src/client/control.c
+++ b/src/client/control.c
@@ -4,14 +4,12 @@
#include /* uint8_t, uint16_t */
#include /* sprintf() */
#include /* strlen() */
+#include "interface_conf.h" /* reload_interface_conf(), save_interface_conf() */
#include "io.h" /* send() */
#include "keybindings.h" /* get_command_to_keycode(), get_keycode_to_command(),
* mod_selected_keyb(), move_keyb_selection()
*/
#include "map.h" /* for map_scroll(), map_center() */
-#include "misc.h" /* reload_interface_conf(), save_interface_conf(),
- * nav_inventory()
- */
#include "wincontrol.h" /* shift_active_win(), resize_active_win(),
* toggle_win_size_type(), toggle_window(),
* cycle_active_win(), scroll_v_screen(),
@@ -22,6 +20,9 @@
+/* Move world.inventory_sel up ("dir"="u") or down (else) as far as possible. */
+static void nav_inventory(char dir);
+
/* If "command"'s .dsc_short fits "match", apply "f" with provided char
* arguments and return 1; else, return 0.
*/
@@ -44,6 +45,26 @@ static uint8_t try_server_commands(struct Command * command);
+static void nav_inventory(char dir)
+{
+ if ('u' == dir)
+ {
+ world.player_inventory_select = world.player_inventory_select
+ - (world.player_inventory_select > 0);
+ return;
+ }
+ uint8_t n_elems = 0;
+ uint8_t i;
+ for (i = 0; '\0' != world.player_inventory[i]; i++)
+ {
+ n_elems = n_elems + ('\n' == world.player_inventory[i]);
+ }
+ world.player_inventory_select = world.player_inventory_select
+ + (world.player_inventory_select < n_elems);
+}
+
+
+
static uint8_t try_0args(struct Command * command, char * match, void (* f) ())
{
if (!strcmp(command->dsc_short, match))