]> git.eshelyaron.com Git - emacs.git/commitdiff
Implement numeric values of `mouse-highlight' on Haiku
authorPo Lu <luangruo@yahoo.com>
Sat, 1 Jan 2022 06:16:59 +0000 (06:16 +0000)
committerPo Lu <luangruo@yahoo.com>
Sat, 1 Jan 2022 06:17:51 +0000 (06:17 +0000)
* src/haikuterm.c (haiku_read_socket): Clear mouse face on
keyboard input if `mouse-highlight' is a fixnum.

src/haikuterm.c

index 574bf40f7b6a40f3a406d250991c6659ec04c27c..676c2e214863c0e1c6f9f53c310f4b782cc55a61 100644 (file)
@@ -2693,11 +2693,24 @@ haiku_read_socket (struct terminal *terminal, struct input_event *hold_quit)
        case KEY_DOWN:
          {
            struct haiku_key_event *b = buf;
+           Mouse_HLInfo *hlinfo = &x_display_list->mouse_highlight;
            struct frame *f = haiku_window_to_frame (b->window);
            int non_ascii_p;
            if (!f)
              continue;
 
+           /* If mouse-highlight is an integer, input clears out
+              mouse highlighting.  */
+           if (!hlinfo->mouse_face_hidden && FIXNUMP (Vmouse_highlight)
+               && (f == 0
+                   || !EQ (f->tool_bar_window, hlinfo->mouse_face_window)
+                   || !EQ (f->tab_bar_window, hlinfo->mouse_face_window)))
+             {
+               clear_mouse_face (hlinfo);
+               hlinfo->mouse_face_hidden = true;
+               need_flush = 1;
+             }
+
            inev.code = b->unraw_mb_char;
 
            BMapKey (b->kc, &non_ascii_p, &inev.code);
@@ -2738,6 +2751,7 @@ haiku_read_socket (struct terminal *terminal, struct input_event *hold_quit)
          {
            struct haiku_mouse_motion_event *b = buf;
            struct frame *f = haiku_window_to_frame (b->window);
+           Mouse_HLInfo *hlinfo = &x_display_list->mouse_highlight;
 
            if (!f)
              continue;
@@ -2748,6 +2762,13 @@ haiku_read_socket (struct terminal *terminal, struct input_event *hold_quit)
            x_display_list->last_mouse_movement_time = time (NULL);
            button_or_motion_p = 1;
 
+           if (hlinfo->mouse_face_hidden)
+             {
+               hlinfo->mouse_face_hidden = false;
+               clear_mouse_face (hlinfo);
+               need_flush = 1;
+             }
+
            if (b->just_exited_p)
              {
                Mouse_HLInfo *hlinfo = MOUSE_HL_INFO (f);