mirror of
https://github.com/davatorium/rofi.git
synced 2025-02-03 15:34:54 -05:00
Possible fix issue #175
This commit is contained in:
parent
95beb58730
commit
e5caaf9d1a
2 changed files with 25 additions and 24 deletions
|
@ -25,13 +25,13 @@ typedef struct
|
|||
|
||||
typedef enum
|
||||
{
|
||||
TB_AUTOHEIGHT = 1 << 0,
|
||||
TB_AUTOWIDTH = 1 << 1,
|
||||
TB_LEFT = 1 << 16,
|
||||
TB_RIGHT = 1 << 17,
|
||||
TB_CENTER = 1 << 18,
|
||||
TB_EDITABLE = 1 << 19,
|
||||
TB_MARKUP = 1 << 20,
|
||||
TB_AUTOHEIGHT = 1 << 0,
|
||||
TB_AUTOWIDTH = 1 << 1,
|
||||
TB_LEFT = 1 << 16,
|
||||
TB_RIGHT = 1 << 17,
|
||||
TB_CENTER = 1 << 18,
|
||||
TB_EDITABLE = 1 << 19,
|
||||
TB_MARKUP = 1 << 20,
|
||||
} TextboxFlags;
|
||||
|
||||
|
||||
|
|
|
@ -262,30 +262,31 @@ int dmenu_switcher_dialog ( char **input )
|
|||
}
|
||||
// We normally do not want to restart the loop.
|
||||
restart = FALSE;
|
||||
if ( ( mretv & ( MENU_OK | MENU_CUSTOM_INPUT ) ) && list[selected_line] != NULL ) {
|
||||
if ( ( mretv & MENU_CUSTOM_INPUT ) ) {
|
||||
dmenu_output_formatted_line ( format, *input, -1, *input );
|
||||
}
|
||||
else{
|
||||
dmenu_output_formatted_line ( format, list[selected_line], selected_line, *input );
|
||||
}
|
||||
// Normal mode
|
||||
if ( ( mretv & MENU_OK ) && list[selected_line] != NULL ) {
|
||||
dmenu_output_formatted_line ( format, list[selected_line], selected_line, *input );
|
||||
if ( ( mretv & MENU_SHIFT ) ) {
|
||||
restart = TRUE;
|
||||
// Move to next line.
|
||||
selected_line = MIN ( next_pos, length - 1 );
|
||||
}
|
||||
retv = TRUE;
|
||||
if ( ( mretv & MENU_QUICK_SWITCH ) ) {
|
||||
retv = 10 + ( mretv & MENU_LOWER_MASK );
|
||||
}
|
||||
// Custom input
|
||||
}
|
||||
else if ( ( mretv & MENU_QUICK_SWITCH ) ) {
|
||||
if ( ( mretv & MENU_CUSTOM_INPUT ) ) {
|
||||
dmenu_output_formatted_line ( format, *input, -1, *input );
|
||||
}
|
||||
else{
|
||||
dmenu_output_formatted_line ( format, list[selected_line], selected_line, *input );
|
||||
}
|
||||
else if ( ( mretv & ( MENU_CUSTOM_INPUT ) ) ) {
|
||||
dmenu_output_formatted_line ( format, *input, -1, *input );
|
||||
retv = TRUE;
|
||||
}
|
||||
// Quick switch with entry selected.
|
||||
else if ( ( mretv & MENU_QUICK_SWITCH ) && selected_line > 0 ) {
|
||||
dmenu_output_formatted_line ( format, list[selected_line], selected_line, *input );
|
||||
|
||||
restart = FALSE;
|
||||
retv = 10 + ( mretv & MENU_LOWER_MASK );
|
||||
}
|
||||
// Quick switch without entry selected.
|
||||
else if ( ( mretv & MENU_QUICK_SWITCH ) && selected_line == -1 ) {
|
||||
dmenu_output_formatted_line ( format, *input, -1, *input );
|
||||
|
||||
restart = FALSE;
|
||||
retv = 10 + ( mretv & MENU_LOWER_MASK );
|
||||
|
|
Loading…
Add table
Reference in a new issue