… | |
… | |
302 | |
302 | |
303 | void |
303 | void |
304 | rxvt_term::key_press (XKeyEvent &ev) |
304 | rxvt_term::key_press (XKeyEvent &ev) |
305 | { |
305 | { |
306 | int ctrl, meta, shft, len; |
306 | int ctrl, meta, shft, len; |
307 | unsigned int newlen; |
|
|
308 | KeySym keysym; |
307 | KeySym keysym; |
309 | int valid_keysym; |
308 | int valid_keysym; |
310 | char kbuf[KBUFSZ]; |
309 | char kbuf[KBUFSZ]; |
311 | |
310 | |
312 | #if ISO_14755 |
311 | #if ISO_14755 |
… | |
… | |
549 | |
548 | |
550 | if (keysym >= 0xFF00 && keysym <= 0xFFFF) |
549 | if (keysym >= 0xFF00 && keysym <= 0xFFFF) |
551 | { |
550 | { |
552 | { |
551 | { |
553 | bool kp = priv_modes & PrivMode_aplKP ? !shft : shft; |
552 | bool kp = priv_modes & PrivMode_aplKP ? !shft : shft; |
554 | newlen = 1; |
553 | unsigned int newlen = 1; |
555 | #ifdef XK_KP_Home |
554 | #ifdef XK_KP_Home |
556 | static const KeySym keypadtrans[] = { |
555 | static const KeySym keypadtrans[] = { |
557 | XK_KP_7, // XK_KP_Home |
556 | XK_KP_7, // XK_KP_Home |
558 | XK_KP_4, // XK_KP_Left |
557 | XK_KP_4, // XK_KP_Left |
559 | XK_KP_8, // XK_KP_Up |
558 | XK_KP_8, // XK_KP_Up |
… | |
… | |
1947 | /* |
1946 | /* |
1948 | * Scrollbar window processing of button press |
1947 | * Scrollbar window processing of button press |
1949 | */ |
1948 | */ |
1950 | if (scrollBar.state && ev.window == scrollBar.win) |
1949 | if (scrollBar.state && ev.window == scrollBar.win) |
1951 | { |
1950 | { |
1952 | int upordown = 0; |
1951 | page_dirn direction = NO_DIR; |
1953 | |
1952 | |
1954 | if (scrollBar.upButton (ev.y)) |
1953 | if (scrollBar.upButton (ev.y)) |
1955 | upordown = -1; /* up */ |
1954 | direction = UP; /* up */ |
1956 | else if (scrollBar.dnButton (ev.y)) |
1955 | else if (scrollBar.dnButton (ev.y)) |
1957 | upordown = 1; /* down */ |
1956 | direction = DN; /* down */ |
1958 | |
1957 | |
1959 | scrollBar.state = STATE_IDLE; |
1958 | scrollBar.state = STATE_IDLE; |
1960 | /* |
1959 | /* |
1961 | * Rxvt-style scrollbar: |
1960 | * Rxvt-style scrollbar: |
1962 | * move up if mouse is above slider |
1961 | * move up if mouse is above slider |
… | |
… | |
1973 | /* |
1972 | /* |
1974 | * Mouse report disabled scrollbar: |
1973 | * Mouse report disabled scrollbar: |
1975 | * arrow buttons - send up/down |
1974 | * arrow buttons - send up/down |
1976 | * click on scrollbar - send pageup/down |
1975 | * click on scrollbar - send pageup/down |
1977 | */ |
1976 | */ |
1978 | if (upordown < 0) |
1977 | if (direction == UP) |
1979 | tt_printf ("\033[A"); |
1978 | tt_printf ("\033[A"); |
1980 | else if (upordown > 0) |
1979 | else if (direction == DN) |
1981 | tt_printf ("\033[B"); |
1980 | tt_printf ("\033[B"); |
1982 | else |
1981 | else |
1983 | switch (ev.button) |
1982 | switch (ev.button) |
1984 | { |
1983 | { |
1985 | case Button2: |
1984 | case Button2: |
… | |
… | |
1993 | break; |
1992 | break; |
1994 | } |
1993 | } |
1995 | } |
1994 | } |
1996 | else |
1995 | else |
1997 | #endif /* NO_SCROLLBAR_REPORT */ |
1996 | #endif /* NO_SCROLLBAR_REPORT */ |
1998 | |
|
|
1999 | { |
1997 | { |
2000 | if (upordown) |
1998 | if (direction != NO_DIR) |
2001 | { |
1999 | { |
2002 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
2000 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
2003 | if (!cont_scroll_ev.is_active ()) |
2001 | if (!cont_scroll_ev.is_active ()) |
2004 | cont_scroll_ev.start (SCROLLBAR_INITIAL_DELAY, SCROLLBAR_CONTINUOUS_DELAY); |
2002 | cont_scroll_ev.start (SCROLLBAR_INITIAL_DELAY, SCROLLBAR_CONTINUOUS_DELAY); |
2005 | #endif |
2003 | #endif |
2006 | if (scr_page (upordown < 0 ? UP : DN, 1)) |
2004 | if (scr_page (direction, 1)) |
2007 | { |
2005 | { |
2008 | if (upordown < 0) |
2006 | if (direction == UP) |
2009 | scrollBar.state = STATE_UP; |
2007 | scrollBar.state = STATE_UP; |
2010 | else |
2008 | else |
2011 | scrollBar.state = STATE_DOWN; |
2009 | scrollBar.state = STATE_DOWN; |
2012 | } |
2010 | } |
2013 | } |
2011 | } |