/[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 257 by jsorg71, Mon Nov 11 23:15:27 2002 UTC revision 273 by astrand, Tue Nov 19 14:22:47 2002 UTC
# Line 29  extern int height; Line 29  extern int height;
29  extern BOOL sendmotion;  extern BOOL sendmotion;
30  extern BOOL fullscreen;  extern BOOL fullscreen;
31  extern BOOL grab_keyboard;  extern BOOL grab_keyboard;
32    extern BOOL hide_decorations;
33  extern char title[];  extern char title[];
34  BOOL enable_compose = False;  BOOL enable_compose = False;
35  BOOL focused;  BOOL focused;
# Line 55  static BOOL xserver_be; Line 56  static BOOL xserver_be;
56  static BOOL ownbackstore;  static BOOL ownbackstore;
57  static Pixmap backstore;  static Pixmap backstore;
58    
59    /* MWM decorations */
60    #define MWM_HINTS_DECORATIONS   (1L << 1)
61    #define PROP_MOTIF_WM_HINTS_ELEMENTS    5
62    typedef struct
63    {
64            unsigned long flags;
65            unsigned long functions;
66            unsigned long decorations;
67            long inputMode;
68            unsigned long status;
69    }
70    PropMotifWmHints;
71    
72    
73  #define FILL_RECTANGLE(x,y,cx,cy)\  #define FILL_RECTANGLE(x,y,cx,cy)\
74  { \  { \
75          XFillRectangle(display, wnd, gc, x, y, cx, cy); \          XFillRectangle(display, wnd, gc, x, y, cx, cy); \
# Line 91  static int rop2_map[] = { Line 106  static int rop2_map[] = {
106  #define SET_FUNCTION(rop2)      { if (rop2 != ROP2_COPY) XSetFunction(display, gc, rop2_map[rop2]); }  #define SET_FUNCTION(rop2)      { if (rop2 != ROP2_COPY) XSetFunction(display, gc, rop2_map[rop2]); }
107  #define RESET_FUNCTION(rop2)    { if (rop2 != ROP2_COPY) XSetFunction(display, gc, GXcopy); }  #define RESET_FUNCTION(rop2)    { if (rop2 != ROP2_COPY) XSetFunction(display, gc, GXcopy); }
108    
109    void
110    mwm_hide_decorations(void)
111    {
112            PropMotifWmHints motif_hints;
113            Atom hintsatom;
114    
115            /* setup the property */
116            motif_hints.flags = MWM_HINTS_DECORATIONS;
117            motif_hints.decorations = 0;
118    
119            /* get the atom for the property */
120            hintsatom = XInternAtom(display, "_MOTIF_WM_HINTS", False);
121            if (!hintsatom)
122            {
123                    error("Failed to get atom _MOTIF_WM_HINTS\n");
124                    return;
125            }
126    
127            XChangeProperty(display, wnd, hintsatom, hintsatom, 32, PropModeReplace,
128                            (unsigned char *) &motif_hints, PROP_MOTIF_WM_HINTS_ELEMENTS);
129    }
130    
131  static void  static void
132  translate8(uint8 * data, uint8 * out, uint8 * end)  translate8(uint8 * data, uint8 * out, uint8 * end)
133  {  {
# Line 261  ui_init(void) Line 298  ui_init(void)
298          host_be = !(BOOL) (*(uint8 *) (&test));          host_be = !(BOOL) (*(uint8 *) (&test));
299          xserver_be = (ImageByteOrder(display) == MSBFirst);          xserver_be = (ImageByteOrder(display) == MSBFirst);
300    
301            if ((width == 0) || (height == 0))
302            {
303                    /* Fetch geometry from _NET_WORKAREA */
304                    uint32 xpos, ypos;
305    
306                    if (get_current_workarea(&xpos, &ypos, &width, &height) < 0)
307                    {
308                            error("Failed to get workarea.\n");
309                            error("Perhaps your window manager does not support EWMH?\n");
310                            error("Defaulting to geometry 800x600\n");
311                            width = 800; height = 600;
312                    }
313            }
314    
315          if (fullscreen)          if (fullscreen)
316          {          {
317                  width = WidthOfScreen(screen);                  width = WidthOfScreen(screen);
# Line 328  ui_create_window(void) Line 379  ui_create_window(void)
379    
380          XStoreName(display, wnd, title);          XStoreName(display, wnd, title);
381    
382            if (hide_decorations)
383                    mwm_hide_decorations();
384    
385          classhints = XAllocClassHint();          classhints = XAllocClassHint();
386          if (classhints != NULL)          if (classhints != NULL)
387          {          {
# Line 469  xwin_process_events(void) Line 523  xwin_process_events(void)
523                                                        str, sizeof(str), &keysym, NULL);                                                        str, sizeof(str), &keysym, NULL);
524                                  }                                  }
525    
526                                  DEBUG_KBD(("KeyPress for (keysym 0x%lx, %s)\n", keysym, get_ksname(keysym)));                                  DEBUG_KBD(("KeyPress for (keysym 0x%lx, %s)\n", keysym,
527                                               get_ksname(keysym)));
528    
529                                  ev_time = time(NULL);                                  ev_time = time(NULL);
530                                  if (handle_special_keys(keysym, xevent.xkey.state, ev_time, True))                                  if (handle_special_keys(keysym, xevent.xkey.state, ev_time, True))
# Line 528  xwin_process_events(void) Line 583  xwin_process_events(void)
583                                  if (xevent.xfocus.mode == NotifyGrab)                                  if (xevent.xfocus.mode == NotifyGrab)
584                                          break;                                          break;
585                                  focused = True;                                  focused = True;
586                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy, &dummy, &dummy, &state);                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy,
587                                                  &dummy, &dummy, &state);
588                                  reset_modifier_keys(state);                                  reset_modifier_keys(state);
589                                  if (grab_keyboard && mouse_in_wnd)                                  if (grab_keyboard && mouse_in_wnd)
590                                          XGrabKeyboard(display, wnd, True,                                          XGrabKeyboard(display, wnd, True,
# Line 549  xwin_process_events(void) Line 605  xwin_process_events(void)
605                                  mouse_in_wnd = True;                                  mouse_in_wnd = True;
606                                  if (fullscreen)                                  if (fullscreen)
607                                  {                                  {
608                                          XSetInputFocus(display, wnd, RevertToPointerRoot, CurrentTime);                                          XSetInputFocus(display, wnd, RevertToPointerRoot,
609                                                           CurrentTime);
610                                          break;                                          break;
611                                  }                                  }
612                                  if (focused)                                  if (focused)
# Line 1132  ui_draw_text(uint8 font, uint8 flags, in Line 1189  ui_draw_text(uint8 font, uint8 flags, in
1189                                  else                                  else
1190                                  {                                  {
1191                                          error("this shouldn't be happening\n");                                          error("this shouldn't be happening\n");
1192                                          break;                                          exit(1);
1193                                  }                                  }
1194                                  /* this will move pointer from start to first character after FF command */                                  /* this will move pointer from start to first character after FF command */
1195                                  length -= i + 3;                                  length -= i + 3;

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

  ViewVC Help
Powered by ViewVC 1.1.26