From d31053f96fbeff2ade5da79162736bd1bb0f4ea6 Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Mon, 5 Nov 2001 04:20:14 +0000 Subject: [PATCH] (read_char): Use Fcar and Fcdr, not Fnth. (record_char): Likewise. (make_lispy_event): Don't insist a drag event must move to a different buffer position. Instead, check for moving at least double_click_fuzz. --- src/ChangeLog | 14 +++++++++++++ src/keyboard.c | 57 +++++++++++++++++++++++++------------------------- 2 files changed, 43 insertions(+), 28 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index 7a63543d60b..102a1481af7 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,19 @@ 2001-11-04 Richard M. Stallman + * buffer.c (Fbuffer_local_value): Remove extra args from CHECK_SYMBOL + and CHECK_BUFFER. + + * keyboard.c (read_char): Use Fcar and Fcdr, not Fnth. + (record_char): Likewise. + + * keyboard.c (make_lispy_event): Don't insist a drag event must + move to a different buffer position. Instead, check for moving at + least double_click_fuzz. + + * fns.c (Fmake_hash_table): Use XCAR and XCDR, not Fnth and Flength. + + * keyboard.c (echo-area-clear-hook): Undo Oct 29 change. + * indent.c (current_column_1, Fmove_to_column): Separate the code for display-table glyphs from the code buffer text, to fix bugs in the former. diff --git a/src/keyboard.c b/src/keyboard.c index 4557b596dd7..ff430fddde7 100644 --- a/src/keyboard.c +++ b/src/keyboard.c @@ -2847,11 +2847,17 @@ read_char (commandflag, nmaps, maps, prev_event, used_mouse_menu) if (CONSP (c) && EQ (XCAR (c), Qhelp_echo)) { /* (help-echo FRAME HELP WINDOW OBJECT POS). */ - Lisp_Object help, object, position, window; - help = Fnth (make_number (2), c); - window = Fnth (make_number (3), c); - object = Fnth (make_number (4), c); - position = Fnth (make_number (5), c); + Lisp_Object help, object, position, window, tem; + + tem = Fcdr (XCDR (c)); + help = Fcar (tem); + tem = Fcdr (tem); + window = Fcar (tem); + tem = Fcdr (tem); + object = Fcar (tem); + tem = Fcdr (tem); + position = Fcar (tem); + show_help_echo (help, window, object, position, 0); /* We stopped being idle for this event; undo that. */ @@ -2983,7 +2989,7 @@ record_char (c) { Lisp_Object help; - help = Fnth (make_number (2), c); + help = Fcar (Fcdr (XCDR (c))); if (STRINGP (help)) { int last_idx; @@ -2996,7 +3002,7 @@ record_char (c) if (!CONSP (last_c) || !EQ (XCAR (last_c), Qhelp_echo) - || (last_help = Fnth (make_number (2), last_c), + || (last_help = Fcar (Fcdr (XCDR (last_c))), !EQ (last_help, help))) { total_keys++; @@ -4984,32 +4990,27 @@ make_lispy_event (event) else #endif { - /* The third element of every position should be the (x,y) - pair. */ Lisp_Object down; + EMACS_INT xdiff = double_click_fuzz, ydiff = double_click_fuzz; - down = Fnth (make_number (2), start_pos); - if (EQ (event->x, XCAR (down)) && EQ (event->y, XCDR (down))) - /* Mouse hasn't moved. */ + /* The third element of every position + should be the (x,y) pair. */ + down = Fcar (Fcdr (Fcdr (start_pos))); + if (CONSP (down)) + { + xdiff = event->x - XCAR (down); + ydiff = event->y - XCDR (down); + } + + if (xdiff < double_click_fuzz && xdiff > - double_click_fuzz + && ydiff < double_click_fuzz + && ydiff > - double_click_fuzz) + /* Mouse hasn't moved (much). */ event->modifiers |= click_modifier; else { - Lisp_Object window1, window2, posn1, posn2; - - /* Avoid generating a drag event if the mouse - hasn't actually moved off the buffer position. */ - window1 = Fnth (make_number (0), position); - posn1 = Fnth (make_number (1), position); - window2 = Fnth (make_number (0), start_pos); - posn2 = Fnth (make_number (1), start_pos); - - if (EQ (window1, window2) && EQ (posn1, posn2)) - event->modifiers |= click_modifier; - else - { - button_down_time = 0; - event->modifiers |= drag_modifier; - } + button_down_time = 0; + event->modifiers |= drag_modifier; } /* Don't check is_double; treat this as multiple -- 2.39.5