/[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 274 by astrand, Tue Nov 19 14:45:13 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;
312                            height = 600;
313                    }
314            }
315    
316          if (fullscreen)          if (fullscreen)
317          {          {
318                  width = WidthOfScreen(screen);                  width = WidthOfScreen(screen);
# Line 328  ui_create_window(void) Line 380  ui_create_window(void)
380    
381          XStoreName(display, wnd, title);          XStoreName(display, wnd, title);
382    
383            if (hide_decorations)
384                    mwm_hide_decorations();
385    
386          classhints = XAllocClassHint();          classhints = XAllocClassHint();
387          if (classhints != NULL)          if (classhints != NULL)
388          {          {
# Line 469  xwin_process_events(void) Line 524  xwin_process_events(void)
524                                                        str, sizeof(str), &keysym, NULL);                                                        str, sizeof(str), &keysym, NULL);
525                                  }                                  }
526    
527                                  DEBUG_KBD(("KeyPress for (keysym 0x%lx, %s)\n", keysym, get_ksname(keysym)));                                  DEBUG_KBD(("KeyPress for (keysym 0x%lx, %s)\n", keysym,
528                                               get_ksname(keysym)));
529    
530                                  ev_time = time(NULL);                                  ev_time = time(NULL);
531                                  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 584  xwin_process_events(void)
584                                  if (xevent.xfocus.mode == NotifyGrab)                                  if (xevent.xfocus.mode == NotifyGrab)
585                                          break;                                          break;
586                                  focused = True;                                  focused = True;
587                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy, &dummy, &dummy, &state);                                  XQueryPointer(display, wnd, &wdummy, &wdummy, &dummy, &dummy,
588                                                  &dummy, &dummy, &state);
589                                  reset_modifier_keys(state);                                  reset_modifier_keys(state);
590                                  if (grab_keyboard && mouse_in_wnd)                                  if (grab_keyboard && mouse_in_wnd)
591                                          XGrabKeyboard(display, wnd, True,                                          XGrabKeyboard(display, wnd, True,
# Line 549  xwin_process_events(void) Line 606  xwin_process_events(void)
606                                  mouse_in_wnd = True;                                  mouse_in_wnd = True;
607                                  if (fullscreen)                                  if (fullscreen)
608                                  {                                  {
609                                          XSetInputFocus(display, wnd, RevertToPointerRoot, CurrentTime);                                          XSetInputFocus(display, wnd, RevertToPointerRoot,
610                                                           CurrentTime);
611                                          break;                                          break;
612                                  }                                  }
613                                  if (focused)                                  if (focused)
# Line 1132  ui_draw_text(uint8 font, uint8 flags, in Line 1190  ui_draw_text(uint8 font, uint8 flags, in
1190                                  else                                  else
1191                                  {                                  {
1192                                          error("this shouldn't be happening\n");                                          error("this shouldn't be happening\n");
1193                                          break;                                          exit(1);
1194                                  }                                  }
1195                                  /* this will move pointer from start to first character after FF command */                                  /* this will move pointer from start to first character after FF command */
1196                                  length -= i + 3;                                  length -= i + 3;

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

  ViewVC Help
Powered by ViewVC 1.1.26