/[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 70 by astrand, Sat Jul 27 23:09:32 2002 UTC revision 87 by jsorg71, Sat Aug 3 22:28:05 2002 UTC
# Line 25  Line 25 
25  #define XK_MISCELLANY  #define XK_MISCELLANY
26  #include <X11/keysymdef.h>  #include <X11/keysymdef.h>
27  #include "rdesktop.h"  #include "rdesktop.h"
28    #include "scancodes.h"
29    
30  extern int width;  extern int width;
31  extern int height;  extern int height;
32  extern BOOL sendmotion;  extern BOOL sendmotion;
33  extern BOOL fullscreen;  extern BOOL fullscreen;
34    extern BOOL grab_keyboard;
35    
36  Display *display = NULL;  Display *display = NULL;
37  static int x_socket;  static int x_socket;
# Line 215  init_inputmethod(void) Line 217  init_inputmethod(void)
217             It seems to work alright anyway, though. */             It seems to work alright anyway, though. */
218          if (IC != NULL)          if (IC != NULL)
219          {          {
220                  if (XGetICValues(IC, XNFilterEvents, &filtered_events, NULL)                  if (XGetICValues(IC, XNFilterEvents, &filtered_events, NULL) != NULL)
                     != NULL)  
221                  {                  {
222                          error("Failed to obtain XNFilterEvents value from IC\n");                          error("Failed to obtain XNFilterEvents value from IC\n");
223                          filtered_events = 0;                          filtered_events = 0;
# Line 239  close_inputmethod(void) Line 240  close_inputmethod(void)
240          }          }
241  }  }
242    
243    BOOL
244    ui_init()
245    {
246            Screen *screen;
247            display = XOpenDisplay(NULL);
248            if (display == NULL)
249            {
250                    error("Failed to open display\n");
251                    return False;
252            }
253            if (fullscreen)
254            {
255                    screen = DefaultScreenOfDisplay(display);
256                    width = WidthOfScreen(screen);
257                    height = HeightOfScreen(screen);
258            }
259            return True;
260    }
261    
262  BOOL  BOOL
263  ui_create_window(char *title)  ui_create_window(char *title)
# Line 251  ui_create_window(char *title) Line 270  ui_create_window(char *title)
270          Screen *screen;          Screen *screen;
271          uint16 test;          uint16 test;
272          int i;          int i;
273            XEvent xevent;
         display = XOpenDisplay(NULL);  
   
         if (display == NULL)  
         {  
                 error("Failed to open display\n");  
                 return False;  
         }  
274    
275          x_socket = ConnectionNumber(display);          x_socket = ConnectionNumber(display);
276          screen = DefaultScreenOfDisplay(display);          screen = DefaultScreenOfDisplay(display);
# Line 272  ui_create_window(char *title) Line 284  ui_create_window(char *title)
284                     desirable, e.g. 24 bits->32 bits. */                     desirable, e.g. 24 bits->32 bits. */
285                  while (i--)                  while (i--)
286                  {                  {
287                          if ((pfm[i].depth == depth)                          if ((pfm[i].depth == depth) && (pfm[i].bits_per_pixel > bpp))
                             && (pfm[i].bits_per_pixel > bpp))  
288                          {                          {
289                                  bpp = pfm[i].bits_per_pixel;                                  bpp = pfm[i].bits_per_pixel;
290                          }                          }
# Line 320  ui_create_window(char *title) Line 331  ui_create_window(char *title)
331          wnd = XCreateWindow(display, RootWindowOfScreen(screen),          wnd = XCreateWindow(display, RootWindowOfScreen(screen),
332                              0, 0, width, height, 0, CopyFromParent,                              0, 0, width, height, 0, CopyFromParent,
333                              InputOutput, CopyFromParent,                              InputOutput, CopyFromParent,
334                              CWBackingStore | CWBackPixel | CWOverrideRedirect,                              CWBackingStore | CWBackPixel | CWOverrideRedirect, &attribs);
                             &attribs);  
335    
336          XStoreName(display, wnd, title);          XStoreName(display, wnd, title);
337    
# Line 345  ui_create_window(char *title) Line 355  ui_create_window(char *title)
355    
356          xkeymap_init2();          xkeymap_init2();
357    
358          input_mask =          input_mask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask |
359                  KeyPressMask | KeyReleaseMask | ButtonPressMask |                          VisibilityChangeMask;
360                  ButtonReleaseMask | EnterWindowMask | LeaveWindowMask;          if (grab_keyboard)
361                    input_mask |= EnterWindowMask | LeaveWindowMask;
362          if (sendmotion)          if (sendmotion)
363                  input_mask |= PointerMotionMask;                  input_mask |= PointerMotionMask;
364    
# Line 366  ui_create_window(char *title) Line 377  ui_create_window(char *title)
377    
378          XMapWindow(display, wnd);          XMapWindow(display, wnd);
379    
380            /* Wait for VisibilityNotify Event */
381            for (;;) {
382                    XNextEvent(display, &xevent);
383                    if (xevent.type == VisibilityNotify)
384                            break;
385            }
386    
387            /* clear the window so that cached data is not viewed upon start... */
388            XSetBackground(display, gc, 0);
389            XSetForeground(display, gc, 0);
390            FILL_RECTANGLE(0, 0, width, height);
391    
392          return True;          return True;
393  }  }
394    
# Line 410  xwin_process_events() Line 433  xwin_process_events()
433          {          {
434                  if (enable_compose && (XFilterEvent(&xevent, None) == True))                  if (enable_compose && (XFilterEvent(&xevent, None) == True))
435                  {                  {
436                          DEBUG_KBD("Filtering event\n");                          DEBUG_KBD(("Filtering event\n"));
437                          continue;                          continue;
438                  }                  }
439    
# Line 425  xwin_process_events() Line 448  xwin_process_events()
448                                  {                                  {
449                                          XmbLookupString(IC,                                          XmbLookupString(IC,
450                                                          (XKeyPressedEvent *) &                                                          (XKeyPressedEvent *) &
451                                                          xevent, str,                                                          xevent, str, sizeof(str), &keysym, &status);
452                                                          sizeof(str), &keysym,                                          if (!((status == XLookupKeySym) || (status == XLookupBoth)))
                                                         &status);  
                                         if (!  
                                             ((status == XLookupKeySym)  
                                              || (status == XLookupBoth)))  
453                                          {                                          {
454                                                  error("XmbLookupString failed with status 0x%x\n", status);                                                  error("XmbLookupString failed with status 0x%x\n",
455                                                          status);
456                                                  break;                                                  break;
457                                          }                                          }
458                                  }                                  }
459                                  else                                  else
460                                  {                                  {
461                                          /* Plain old XLookupString */                                          /* Plain old XLookupString */
462                                          DEBUG_KBD                                          DEBUG_KBD(("No input context, using XLookupString\n"));
                                                 ("No input context, using XLookupString\n");  
463                                          XLookupString((XKeyEvent *) & xevent,                                          XLookupString((XKeyEvent *) & xevent,
464                                                        str, sizeof(str),                                                        str, sizeof(str), &keysym, NULL);
                                                       &keysym, NULL);  
465                                  }                                  }
466    
467                                  ksname = get_ksname(keysym);                                  ksname = get_ksname(keysym);
468                                  DEBUG_KBD                                  DEBUG_KBD(("\nKeyPress for (keysym 0x%lx, %s)\n", keysym, ksname));
                                         ("\nKeyPress for (keysym 0x%lx, %s)\n",  
                                          keysym, ksname);  
469    
470                                  if (inhibit_key(keysym))                                  if (inhibit_key(keysym))
471                                  {                                  {
472                                          DEBUG_KBD("Inhibiting key\n");                                          DEBUG_KBD(("Inhibiting key\n"));
473                                          break;                                          break;
474                                  }                                  }
475    
476                                  tr = xkeymap_translate_key(keysym,                                  tr = xkeymap_translate_key(keysym,
477                                                             xevent.xkey.                                                             xevent.xkey.keycode, xevent.xkey.state);
                                                            keycode,  
                                                            xevent.xkey.state);  
478    
479                                  ensure_remote_modifiers(ev_time, tr);                                  ensure_remote_modifiers(ev_time, tr);
480    
481                                  if (tr.scancode == 0)                                  if (tr.scancode == 0)
482                                          break;                                          break;
483    
484                                  rdp_send_scancode(ev_time, RDP_KEYPRESS,                                  rdp_send_scancode(ev_time, RDP_KEYPRESS, tr.scancode);
                                                   tr.scancode);  
485                                  break;                                  break;
486                          case KeyRelease:                          case KeyRelease:
487                                  XLookupString((XKeyEvent *) & xevent, str,                                  XLookupString((XKeyEvent *) & xevent, str,
488                                                sizeof(str), &keysym, NULL);                                                sizeof(str), &keysym, NULL);
489    
490                                  ksname = get_ksname(keysym);                                  ksname = get_ksname(keysym);
491                                  DEBUG_KBD                                  DEBUG_KBD(("\nKeyRelease for (keysym 0x%lx, %s)\n", keysym,
492                                          ("\nKeyRelease for (keysym 0x%lx, %s)\n",                                             ksname));
                                          keysym, ksname);  
493    
494                                  if (inhibit_key(keysym))                                  if (inhibit_key(keysym))
495                                          break;                                          break;
496    
497                                  tr = xkeymap_translate_key(keysym,                                  tr = xkeymap_translate_key(keysym,
498                                                             xevent.xkey.                                                             xevent.xkey.keycode, xevent.xkey.state);
                                                            keycode,  
                                                            xevent.xkey.state);  
499    
500                                  if (tr.scancode == 0)                                  if (tr.scancode == 0)
501                                          break;                                          break;
502    
503                                  rdp_send_scancode(ev_time, RDP_KEYRELEASE,                                  rdp_send_scancode(ev_time, RDP_KEYRELEASE, tr.scancode);
                                                   tr.scancode);  
504                                  break;                                  break;
505    
506                          case ButtonPress:                          case ButtonPress:
# Line 499  xwin_process_events() Line 508  xwin_process_events()
508                                  /* fall through */                                  /* fall through */
509    
510                          case ButtonRelease:                          case ButtonRelease:
511                                  button = xkeymap_translate_button(xevent.                                  button = xkeymap_translate_button(xevent.xbutton.button);
                                                                   xbutton.  
                                                                   button);  
512                                  if (button == 0)                                  if (button == 0)
513                                          break;                                          break;
514    
515                                  rdp_send_input(ev_time, RDP_INPUT_MOUSE,                                  rdp_send_input(ev_time, RDP_INPUT_MOUSE,
516                                                 flags | button,                                                 flags | button, xevent.xbutton.x, xevent.xbutton.y);
                                                xevent.xbutton.x,  
                                                xevent.xbutton.y);  
517                                  break;                                  break;
518    
519                          case MotionNotify:                          case MotionNotify:
520                                  rdp_send_input(ev_time, RDP_INPUT_MOUSE,                                  rdp_send_input(ev_time, RDP_INPUT_MOUSE,
521                                                 MOUSE_FLAG_MOVE,                                                 MOUSE_FLAG_MOVE, xevent.xmotion.x, xevent.xmotion.y);
                                                xevent.xmotion.x,  
                                                xevent.xmotion.y);  
522                                  break;                                  break;
523    
524                            case FocusIn:
525                                    /* fall through */
526                          case EnterNotify:                          case EnterNotify:
527                                  XGrabKeyboard(display, wnd, True,                                  if (grab_keyboard)
528                                                GrabModeAsync, GrabModeAsync,                                          XGrabKeyboard(display, wnd, True,
529                                                CurrentTime);                                                        GrabModeAsync, GrabModeAsync, CurrentTime);
530                                  break;                                  break;
531    
532                            case FocusOut:
533                                    /* reset keys */
534                                    rdp_send_input(ev_time, RDP_INPUT_SCANCODE,
535                                                   KBD_FLAG_DOWN | KBD_FLAG_UP, SCANCODE_CHAR_LCTRL, 0);
536                                    rdp_send_input(ev_time, RDP_INPUT_SCANCODE,
537                                                   KBD_FLAG_DOWN | KBD_FLAG_UP, SCANCODE_CHAR_LALT, 0);
538                                    /* fall through */
539                          case LeaveNotify:                          case LeaveNotify:
540                                  XUngrabKeyboard(display, CurrentTime);                                  if (grab_keyboard)
541                                            XUngrabKeyboard(display, CurrentTime);
542                                  break;                                  break;
543    
544                          case Expose:                          case Expose:
# Line 589  ui_create_bitmap(int width, int height, Line 602  ui_create_bitmap(int width, int height,
602    
603          tdata = (owncolmap ? data : translate_image(width, height, data));          tdata = (owncolmap ? data : translate_image(width, height, data));
604          bitmap = XCreatePixmap(display, wnd, width, height, depth);          bitmap = XCreatePixmap(display, wnd, width, height, depth);
605          image = XCreateImage(display, visual, depth, ZPixmap, 0, tdata, width,          image = XCreateImage(display, visual, depth, ZPixmap, 0,
606                               height, 8, 0);                               (char *) tdata, width, height, 8, 0);
607    
608          XPutImage(display, bitmap, gc, image, 0, 0, 0, 0, width, height);          XPutImage(display, bitmap, gc, image, 0, 0, 0, 0, width, height);
609    
# Line 601  ui_create_bitmap(int width, int height, Line 614  ui_create_bitmap(int width, int height,
614  }  }
615    
616  void  void
617  ui_paint_bitmap(int x, int y, int cx, int cy, int width, int height,  ui_paint_bitmap(int x, int y, int cx, int cy, int width, int height, uint8 * data)
                 uint8 * data)  
618  {  {
619          XImage *image;          XImage *image;
620          uint8 *tdata;          uint8 *tdata;
621    
622          tdata = (owncolmap ? data : translate_image(width, height, data));          tdata = (owncolmap ? data : translate_image(width, height, data));
623          image = XCreateImage(display, visual, depth, ZPixmap, 0, tdata, width,          image = XCreateImage(display, visual, depth, ZPixmap, 0,
624                               height, 8, 0);                               (char *) tdata, width, height, 8, 0);
625    
626          if (ownbackstore)          if (ownbackstore)
627          {          {
# Line 645  ui_create_glyph(int width, int height, u Line 657  ui_create_glyph(int width, int height, u
657          bitmap = XCreatePixmap(display, wnd, width, height, 1);          bitmap = XCreatePixmap(display, wnd, width, height, 1);
658          gc = XCreateGC(display, bitmap, 0, NULL);          gc = XCreateGC(display, bitmap, 0, NULL);
659    
660          image = XCreateImage(display, visual, 1, ZPixmap, 0, data, width,          image = XCreateImage(display, visual, 1, ZPixmap, 0, (char *) data,
661                               height, 8, scanline);                               width, height, 8, scanline);
662          image->byte_order = MSBFirst;          image->byte_order = MSBFirst;
663          image->bitmap_bit_order = MSBFirst;          image->bitmap_bit_order = MSBFirst;
664          XInitImage(image);          XInitImage(image);
# Line 886  ui_patblt(uint8 opcode, Line 898  ui_patblt(uint8 opcode,
898                          SET_BACKGROUND(fgcolour);                          SET_BACKGROUND(fgcolour);
899                          XSetFillStyle(display, gc, FillOpaqueStippled);                          XSetFillStyle(display, gc, FillOpaqueStippled);
900                          XSetStipple(display, gc, fill);                          XSetStipple(display, gc, fill);
901                          XSetTSOrigin(display, gc, brush->xorigin,                          XSetTSOrigin(display, gc, brush->xorigin, brush->yorigin);
                                      brush->yorigin);  
902    
903                          FILL_RECTANGLE(x, y, cx, cy);                          FILL_RECTANGLE(x, y, cx, cy);
904    
905                          XSetFillStyle(display, gc, FillSolid);                          XSetFillStyle(display, gc, FillSolid);
906                            XSetTSOrigin(display, gc, 0, 0);
907                          ui_destroy_glyph((HGLYPH) fill);                          ui_destroy_glyph((HGLYPH) fill);
908                          break;                          break;
909    
# Line 910  ui_screenblt(uint8 opcode, Line 922  ui_screenblt(uint8 opcode,
922          SET_FUNCTION(opcode);          SET_FUNCTION(opcode);
923          XCopyArea(display, wnd, wnd, gc, srcx, srcy, cx, cy, x, y);          XCopyArea(display, wnd, wnd, gc, srcx, srcy, cx, cy, x, y);
924          if (ownbackstore)          if (ownbackstore)
925                  XCopyArea(display, backstore, backstore, gc, srcx, srcy, cx,                  XCopyArea(display, backstore, backstore, gc, srcx, srcy, cx, cy, x, y);
                           cy, x, y);  
926          RESET_FUNCTION(opcode);          RESET_FUNCTION(opcode);
927  }  }
928    
# Line 923  ui_memblt(uint8 opcode, Line 934  ui_memblt(uint8 opcode,
934          SET_FUNCTION(opcode);          SET_FUNCTION(opcode);
935          XCopyArea(display, (Pixmap) src, wnd, gc, srcx, srcy, cx, cy, x, y);          XCopyArea(display, (Pixmap) src, wnd, gc, srcx, srcy, cx, cy, x, y);
936          if (ownbackstore)          if (ownbackstore)
937                  XCopyArea(display, (Pixmap) src, backstore, gc, srcx, srcy,                  XCopyArea(display, (Pixmap) src, backstore, gc, srcx, srcy, cx, cy, x, y);
                           cx, cy, x, y);  
938          RESET_FUNCTION(opcode);          RESET_FUNCTION(opcode);
939  }  }
940    
# Line 941  ui_triblt(uint8 opcode, Line 951  ui_triblt(uint8 opcode,
951          {          {
952                  case 0x69:      /* PDSxxn */                  case 0x69:      /* PDSxxn */
953                          ui_memblt(ROP2_XOR, x, y, cx, cy, src, srcx, srcy);                          ui_memblt(ROP2_XOR, x, y, cx, cy, src, srcx, srcy);
954                          ui_patblt(ROP2_NXOR, x, y, cx, cy, brush, bgcolour,                          ui_patblt(ROP2_NXOR, x, y, cx, cy, brush, bgcolour, fgcolour);
                                   fgcolour);  
955                          break;                          break;
956    
957                  case 0xb8:      /* PSDPxax */                  case 0xb8:      /* PSDPxax */
958                          ui_patblt(ROP2_XOR, x, y, cx, cy, brush, bgcolour,                          ui_patblt(ROP2_XOR, x, y, cx, cy, brush, bgcolour, fgcolour);
                                   fgcolour);  
959                          ui_memblt(ROP2_AND, x, y, cx, cy, src, srcx, srcy);                          ui_memblt(ROP2_AND, x, y, cx, cy, src, srcx, srcy);
960                          ui_patblt(ROP2_XOR, x, y, cx, cy, brush, bgcolour,                          ui_patblt(ROP2_XOR, x, y, cx, cy, brush, bgcolour, fgcolour);
                                   fgcolour);  
961                          break;                          break;
962    
963                  case 0xc0:      /* PSa */                  case 0xc0:      /* PSa */
964                          ui_memblt(ROP2_COPY, x, y, cx, cy, src, srcx, srcy);                          ui_memblt(ROP2_COPY, x, y, cx, cy, src, srcx, srcy);
965                          ui_patblt(ROP2_AND, x, y, cx, cy, brush, bgcolour,                          ui_patblt(ROP2_AND, x, y, cx, cy, brush, bgcolour, fgcolour);
                                   fgcolour);  
966                          break;                          break;
967    
968                  default:                  default:
# Line 997  ui_draw_glyph(int mixmode, Line 1003  ui_draw_glyph(int mixmode,
1003          SET_BACKGROUND(bgcolour);          SET_BACKGROUND(bgcolour);
1004    
1005          XSetFillStyle(display, gc,          XSetFillStyle(display, gc,
1006                        (mixmode ==                        (mixmode == MIX_TRANSPARENT) ? FillStippled : FillOpaqueStippled);
                        MIX_TRANSPARENT) ? FillStippled : FillOpaqueStippled);  
1007          XSetStipple(display, gc, (Pixmap) glyph);          XSetStipple(display, gc, (Pixmap) glyph);
1008          XSetTSOrigin(display, gc, x, y);          XSetTSOrigin(display, gc, x, y);
1009    
# Line 1016  ui_draw_glyph(int mixmode, Line 1021  ui_draw_glyph(int mixmode,
1021        if ((xyoffset & 0x80))\        if ((xyoffset & 0x80))\
1022          {\          {\
1023            if (flags & TEXT2_VERTICAL) \            if (flags & TEXT2_VERTICAL) \
1024              y += ttext[++idx] | (ttext[++idx] << 8);\              y += ttext[idx+1] | (ttext[idx+2] << 8);\
1025            else\            else\
1026              x += ttext[++idx] | (ttext[++idx] << 8);\              x += ttext[idx+1] | (ttext[idx+2] << 8);\
1027              idx += 2;\
1028          }\          }\
1029        else\        else\
1030          {\          {\
# Line 1067  ui_draw_text(uint8 font, uint8 flags, in Line 1073  ui_draw_text(uint8 font, uint8 flags, in
1073                  {                  {
1074                          case 0xff:                          case 0xff:
1075                                  if (i + 2 < length)                                  if (i + 2 < length)
1076                                          cache_put_text(text[i + 1], text,                                          cache_put_text(text[i + 1], text, text[i + 2]);
                                                        text[i + 2]);  
1077                                  else                                  else
1078                                  {                                  {
1079                                          error("this shouldn't be happening\n");                                          error("this shouldn't be happening\n");
# Line 1085  ui_draw_text(uint8 font, uint8 flags, in Line 1090  ui_draw_text(uint8 font, uint8 flags, in
1090                                  if (entry != NULL)                                  if (entry != NULL)
1091                                  {                                  {
1092                                          if ((((uint8 *) (entry->data))[1] ==                                          if ((((uint8 *) (entry->data))[1] ==
1093                                               0)                                               0) && (!(flags & TEXT2_IMPLICIT_X)))
                                             && (!(flags & TEXT2_IMPLICIT_X)))  
1094                                          {                                          {
1095                                                  if (flags & TEXT2_VERTICAL)                                                  if (flags & TEXT2_VERTICAL)
1096                                                          y += text[i + 2];                                                          y += text[i + 2];
# Line 1102  ui_draw_text(uint8 font, uint8 flags, in Line 1106  ui_draw_text(uint8 font, uint8 flags, in
1106                                          text = &(text[i]);                                          text = &(text[i]);
1107                                          i = 0;                                          i = 0;
1108                                          for (j = 0; j < entry->size; j++)                                          for (j = 0; j < entry->size; j++)
1109                                                  DO_GLYPH(((uint8 *) (entry->                                                  DO_GLYPH(((uint8 *) (entry->data)), j);
                                                                      data)),  
                                                          j);  
1110                                  }                                  }
1111                                  break;                                  break;
1112    
# Line 1126  ui_desktop_save(uint32 offset, int x, in Line 1128  ui_desktop_save(uint32 offset, int x, in
1128    
1129          if (ownbackstore)          if (ownbackstore)
1130          {          {
1131                  image = XGetImage(display, backstore, x, y, cx, cy, AllPlanes,                  image = XGetImage(display, backstore, x, y, cx, cy, AllPlanes, ZPixmap);
                                   ZPixmap);  
1132          }          }
1133          else          else
1134          {          {
1135                  pix = XCreatePixmap(display, wnd, cx, cy, depth);                  pix = XCreatePixmap(display, wnd, cx, cy, depth);
1136                  XCopyArea(display, wnd, pix, gc, x, y, cx, cy, 0, 0);                  XCopyArea(display, wnd, pix, gc, x, y, cx, cy, 0, 0);
1137                  image = XGetImage(display, pix, 0, 0, cx, cy, AllPlanes,                  image = XGetImage(display, pix, 0, 0, cx, cy, AllPlanes, ZPixmap);
                                   ZPixmap);  
1138                  XFreePixmap(display, pix);                  XFreePixmap(display, pix);
1139          }          }
1140    
1141          offset *= bpp / 8;          offset *= bpp / 8;
1142          cache_put_desktop(offset, cx, cy, image->bytes_per_line, bpp / 8,          cache_put_desktop(offset, cx, cy, image->bytes_per_line, bpp / 8, (uint8 *) image->data);
                           (uint8 *) image->data);  
1143    
1144          XDestroyImage(image);          XDestroyImage(image);
1145  }  }
# Line 1156  ui_desktop_restore(uint32 offset, int x, Line 1155  ui_desktop_restore(uint32 offset, int x,
1155          if (data == NULL)          if (data == NULL)
1156                  return;                  return;
1157    
1158          image = XCreateImage(display, visual, depth, ZPixmap, 0, data, cx, cy,          image = XCreateImage(display, visual, depth, ZPixmap, 0,
1159                               BitmapPad(display), cx * bpp / 8);                               (char *) data, cx, cy, BitmapPad(display), cx * bpp / 8);
1160    
1161          if (ownbackstore)          if (ownbackstore)
1162          {          {

Legend:
Removed from v.70  
changed lines
  Added in v.87

  ViewVC Help
Powered by ViewVC 1.1.26