/[rdesktop]/sourceforge.net/trunk/rdesktop/xwin.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /sourceforge.net/trunk/rdesktop/xwin.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 253 by matthewc, Tue Nov 5 11:09:26 2002 UTC revision 257 by jsorg71, Mon Nov 11 23:15:27 2002 UTC
# Line 31  extern BOOL fullscreen; Line 31  extern BOOL fullscreen;
31  extern BOOL grab_keyboard;  extern BOOL grab_keyboard;
32  extern char title[];  extern char title[];
33  BOOL enable_compose = False;  BOOL enable_compose = False;
34    BOOL focused;
35    BOOL mouse_in_wnd;
36    
37  Display *display;  Display *display;
38  static int x_socket;  static int x_socket;
# Line 345  ui_create_window(void) Line 347  ui_create_window(void)
347          }          }
348    
349          input_mask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask |          input_mask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask |
350                  VisibilityChangeMask | FocusChangeMask | LeaveWindowMask;                  VisibilityChangeMask | FocusChangeMask;
351    
352          if (sendmotion)          if (sendmotion)
353                  input_mask |= PointerMotionMask;                  input_mask |= PointerMotionMask;
354          if (ownbackstore)          if (ownbackstore)
355                  input_mask |= ExposureMask;                  input_mask |= ExposureMask;
356          if (fullscreen)          if (fullscreen || grab_keyboard)
357                  input_mask |= EnterWindowMask;                  input_mask |= EnterWindowMask;
358            if (grab_keyboard)
359                    input_mask |= LeaveWindowMask;
360    
361          if (IM != NULL)          if (IM != NULL)
362          {          {
# Line 374  ui_create_window(void) Line 378  ui_create_window(void)
378          }          }
379          while (xevent.type != VisibilityNotify);          while (xevent.type != VisibilityNotify);
380    
381            focused = False;
382            mouse_in_wnd = False;
383    
384          return True;          return True;
385  }  }
386    
# Line 518  xwin_process_events(void) Line 525  xwin_process_events(void)
525                                  break;                                  break;
526    
527                          case FocusIn:                          case FocusIn:
528                                    if (xevent.xfocus.mode == NotifyGrab)
529                                            break;
530                                    focused = True;
531                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy, &dummy, &dummy, &state);                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy, &dummy, &dummy, &state);
532                                  reset_modifier_keys(state);                                  reset_modifier_keys(state);
533                                  if (grab_keyboard)                                  if (grab_keyboard && mouse_in_wnd)
534                                          XGrabKeyboard(display, wnd, True,                                          XGrabKeyboard(display, wnd, True,
535                                                        GrabModeAsync, GrabModeAsync, CurrentTime);                                                        GrabModeAsync, GrabModeAsync, CurrentTime);
536                                  break;                                  break;
537    
538                          case FocusOut:                          case FocusOut:
539                                    if (xevent.xfocus.mode == NotifyUngrab)
540                                            break;
541                                    focused = False;
542                                  if (xevent.xfocus.mode == NotifyWhileGrabbed)                                  if (xevent.xfocus.mode == NotifyWhileGrabbed)
543                                          XUngrabKeyboard(display, CurrentTime);                                          XUngrabKeyboard(display, CurrentTime);
544                                  break;                                  break;
545    
546                          case EnterNotify:                          case EnterNotify:
547                                  /* we only register for this event when in fullscreen mode */                                  /* we only register for this event when in fullscreen mode */
548                                  XSetInputFocus(display, wnd, RevertToPointerRoot, CurrentTime);                                  /* or grab_keyboard */
549                                    mouse_in_wnd = True;
550                                    if (fullscreen)
551                                    {
552                                            XSetInputFocus(display, wnd, RevertToPointerRoot, CurrentTime);
553                                            break;
554                                    }
555                                    if (focused)
556                                            XGrabKeyboard(display, wnd, True,
557                                                          GrabModeAsync, GrabModeAsync, CurrentTime);
558                                  break;                                  break;
559    
560                          case LeaveNotify:                          case LeaveNotify:
561                                    /* we only register for this event when grab_keyboard */
562                                    mouse_in_wnd = False;
563                                  XUngrabKeyboard(display, CurrentTime);                                  XUngrabKeyboard(display, CurrentTime);
564                                  break;                                  break;
565    

Legend:
Removed from v.253  
changed lines
  Added in v.257

  ViewVC Help
Powered by ViewVC 1.1.26