|  |  | @ -26,7 +26,6 @@ static const string INVOKE_HOTKEYS_COMMAND = "hotkeys"; | 
			
		
	
		
		
			
				
					
					|  |  |  | static const std::string MENU_SCREEN_FOCUS_STRING = "dfhack/lua/hotkeys/menu"; |  |  |  | static const std::string MENU_SCREEN_FOCUS_STRING = "dfhack/lua/hotkeys/menu"; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | static bool valid = false; // whether the following two vars contain valid data
 |  |  |  | static bool valid = false; // whether the following two vars contain valid data
 | 
			
		
	
		
		
			
				
					
					|  |  |  | static string current_focus; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | static map<string, string> current_bindings; |  |  |  | static map<string, string> current_bindings; | 
			
		
	
		
		
			
				
					
					|  |  |  | static vector<string> sorted_keys; |  |  |  | static vector<string> sorted_keys; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -38,14 +37,13 @@ static bool can_invoke(const string &cmdline, df::viewscreen *screen) { | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | static int cleanupHotkeys(lua_State *) { |  |  |  | static int cleanupHotkeys(lua_State *) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     DEBUG(log).print("cleaning up old stub keybindings for %s\n", current_focus.c_str()); |  |  |  |     DEBUG(log).print("cleaning up old stub keybindings for:\n %s\n", join_strings("\n", Gui::getFocusStrings(Gui::getCurViewscreen(true))).c_str()); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     std::for_each(sorted_keys.begin(), sorted_keys.end(), [](const string &sym) { |  |  |  |     std::for_each(sorted_keys.begin(), sorted_keys.end(), [](const string &sym) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         string keyspec = sym + "@" + MENU_SCREEN_FOCUS_STRING; |  |  |  |         string keyspec = sym + "@" + MENU_SCREEN_FOCUS_STRING; | 
			
		
	
		
		
			
				
					
					|  |  |  |         DEBUG(log).print("clearing keybinding: %s\n", keyspec.c_str()); |  |  |  |         DEBUG(log).print("clearing keybinding: %s\n", keyspec.c_str()); | 
			
		
	
		
		
			
				
					
					|  |  |  |         Core::getInstance().ClearKeyBindings(keyspec); |  |  |  |         Core::getInstance().ClearKeyBindings(keyspec); | 
			
		
	
		
		
			
				
					
					|  |  |  |     }); |  |  |  |     }); | 
			
		
	
		
		
			
				
					
					|  |  |  |     valid = false; |  |  |  |     valid = false; | 
			
		
	
		
		
			
				
					
					|  |  |  |     current_focus = ""; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     sorted_keys.clear(); |  |  |  |     sorted_keys.clear(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     current_bindings.clear(); |  |  |  |     current_bindings.clear(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     return 0; |  |  |  |     return 0; | 
			
		
	
	
		
		
			
				
					|  |  | @ -89,8 +87,7 @@ static void find_active_keybindings(df::viewscreen *screen, bool filtermenu) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     valid_keys.push_back("`"); |  |  |  |     valid_keys.push_back("`"); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |     vector<string> focusStrings = Gui::getFocusStrings(screen); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     current_focus = Gui::getFocusStrings(screen)[0]; |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     for (int shifted = 0; shifted < 2; shifted++) { |  |  |  |     for (int shifted = 0; shifted < 2; shifted++) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         for (int alt = 0; alt < 2; alt++) { |  |  |  |         for (int alt = 0; alt < 2; alt++) { | 
			
		
	
		
		
			
				
					
					|  |  |  |             for (int ctrl = 0; ctrl < 2; ctrl++) { |  |  |  |             for (int ctrl = 0; ctrl < 2; ctrl++) { | 
			
		
	
	
		
		
			
				
					|  |  | @ -112,9 +109,11 @@ static void find_active_keybindings(df::viewscreen *screen, bool filtermenu) { | 
			
		
	
		
		
			
				
					
					|  |  |  |                             vector<string> tokens; |  |  |  |                             vector<string> tokens; | 
			
		
	
		
		
			
				
					
					|  |  |  |                             split_string(&tokens, *invoke_cmd, ":"); |  |  |  |                             split_string(&tokens, *invoke_cmd, ":"); | 
			
		
	
		
		
			
				
					
					|  |  |  |                             string focus = tokens[0].substr(1); |  |  |  |                             string focus = tokens[0].substr(1); | 
			
		
	
		
		
			
				
					
					|  |  |  |                             if (prefix_matches(focus, current_focus)) { |  |  |  |                             for(string focusString : focusStrings) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                                 auto cmdline = trim(tokens[1]); |  |  |  |                                 if (prefix_matches(toLower(focus), toLower(focusString))) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                                 add_binding_if_valid(sym, cmdline, screen, filtermenu); |  |  |  |                                     auto cmdline = trim(tokens[1]); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                                     add_binding_if_valid(sym, cmdline, screen, filtermenu); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                                 } | 
			
		
	
		
		
			
				
					
					|  |  |  |                             } |  |  |  |                             } | 
			
		
	
		
		
			
				
					
					|  |  |  |                         } |  |  |  |                         } | 
			
		
	
		
		
			
				
					
					|  |  |  |                     } |  |  |  |                     } | 
			
		
	
	
		
		
			
				
					|  |  | @ -145,8 +144,8 @@ static void list(color_ostream &out) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (!valid) |  |  |  |     if (!valid) | 
			
		
	
		
		
			
				
					
					|  |  |  |         find_active_keybindings(Gui::getCurViewscreen(true), false); |  |  |  |         find_active_keybindings(Gui::getCurViewscreen(true), false); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     out.print("Valid keybindings for the current screen (%s)\n", |  |  |  |     out.print("Valid keybindings for the current focus:\n %s\n", | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |               current_focus.c_str()); |  |  |  |               join_strings("\n", Gui::getFocusStrings(Gui::getCurViewscreen(true))).c_str()); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     std::for_each(sorted_keys.begin(), sorted_keys.end(), [&](const string &sym) { |  |  |  |     std::for_each(sorted_keys.begin(), sorted_keys.end(), [&](const string &sym) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         out.print("%s: %s\n", sym.c_str(), current_bindings[sym].c_str()); |  |  |  |         out.print("%s: %s\n", sym.c_str(), current_bindings[sym].c_str()); | 
			
		
	
		
		
			
				
					
					|  |  |  |     }); |  |  |  |     }); | 
			
		
	
	
		
		
			
				
					|  |  | 
 |