JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
merge.
authorAurélien Aptel <aurelien.aptel@gmail.com>
Fri, 26 Nov 2010 21:12:54 +0000 (22:12 +0100)
committerAurélien Aptel <aurelien.aptel@gmail.com>
Fri, 26 Nov 2010 21:12:54 +0000 (22:12 +0100)
1  2 
st.c

diff --combined st.c
--- 1/st.c
--- 2/st.c
+++ b/st.c
@@@ -23,7 -23,7 +23,7 @@@
  
  #if   defined(__linux)
   #include <pty.h>
- #elif defined(__OpenBSD__) || defined(__NetBSD__)
+ #elif defined(__OpenBSD__) || defined(__NetBSD__) || defined(__APPLE__)
   #include <util.h>
  #elif defined(__FreeBSD__) || defined(__DragonFly__)
   #include <libutil.h>
@@@ -110,7 -110,7 +110,7 @@@ typedef struct 
  
  /* Purely graphic info */
  typedef struct {
 -      Display* dis;
 +      Display* dpy;
        Colormap cmap;
        Window win;
        Pixmap buf;
@@@ -405,7 -405,7 +405,7 @@@ bpress(XEvent *e) 
  void
  selcopy(void) {
        char *str, *ptr;
-       int ls, x, y, sz, sl;
+       int x, y, sz, sl, ls = 0;
  
        if(sel.bx == -1)
                str = NULL;
@@@ -437,7 -437,7 +437,7 @@@ selnotify(XEvent *e) 
  
        ofs = 0;
        do {
 -              if(XGetWindowProperty(xw.dis, xw.win, XA_PRIMARY, ofs, BUFSIZ/4,
 +              if(XGetWindowProperty(xw.dpy, xw.win, XA_PRIMARY, ofs, BUFSIZ/4,
                                        False, AnyPropertyType, &type, &format,
                                        &nitems, &rem, &data)) {
                        fprintf(stderr, "Clipboard allocation failed\n");
  
  void
  selpaste() {
 -      XConvertSelection(xw.dis, XA_PRIMARY, XA_STRING, XA_PRIMARY, xw.win, CurrentTime);
 +      XConvertSelection(xw.dpy, XA_PRIMARY, XA_STRING, XA_PRIMARY, xw.win, CurrentTime);
  }
  
  void
@@@ -470,7 -470,7 +470,7 @@@ selrequest(XEvent *e) 
        /* reject */
        xev.property = None;
  
 -      xa_targets = XInternAtom(xw.dis, "TARGETS", 0);
 +      xa_targets = XInternAtom(xw.dpy, "TARGETS", 0);
        if(xsre->target == xa_targets) {
                /* respond with the supported type */
                Atom string = XA_STRING;
@@@ -498,12 -498,12 +498,12 @@@ xsetsel(char *str) 
        free(sel.clip);
        sel.clip = str;
  
 -      XSetSelectionOwner(xw.dis, XA_PRIMARY, xw.win, CurrentTime);
 +      XSetSelectionOwner(xw.dpy, XA_PRIMARY, xw.win, CurrentTime);
  
 -      clipboard = XInternAtom(xw.dis, "CLIPBOARD", 0);
 -      XSetSelectionOwner(xw.dis, clipboard, xw.win, CurrentTime);
 +      clipboard = XInternAtom(xw.dpy, "CLIPBOARD", 0);
 +      XSetSelectionOwner(xw.dpy, clipboard, xw.win, CurrentTime);
  
 -      XFlush(xw.dis);
 +      XFlush(xw.dpy);
  }
  
  /* TODO: doubleclick to select word */
@@@ -1185,7 -1185,7 +1185,7 @@@ tputc(char *c) 
                        if(ascii == '\a' || term.titlelen+1 >= ESC_TITLE_SIZ) {
                                term.esc = 0;
                                term.title[term.titlelen] = '\0';
 -                              XStoreName(xw.dis, xw.win, term.title);
 +                              XStoreName(xw.dpy, xw.win, term.title);
                        } else {
                                term.title[term.titlelen++] = ascii;
                        }
@@@ -1360,22 -1360,22 +1360,22 @@@ xresize(int col, int row) 
        oldh = xw.bufh;
        xw.bufw = MAX(1, col * xw.cw);
        xw.bufh = MAX(1, row * xw.ch);
 -      newbuf = XCreatePixmap(xw.dis, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dis, xw.scr));
 -      XCopyArea(xw.dis, xw.buf, newbuf, dc.gc, 0, 0, xw.bufw, xw.bufh, 0, 0);
 -      XFreePixmap(xw.dis, xw.buf);
 -      XSetForeground(xw.dis, dc.gc, dc.col[DefaultBG]);
 +      newbuf = XCreatePixmap(xw.dpy, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dpy, xw.scr));
 +      XCopyArea(xw.dpy, xw.buf, newbuf, dc.gc, 0, 0, xw.bufw, xw.bufh, 0, 0);
 +      XFreePixmap(xw.dpy, xw.buf);
 +      XSetForeground(xw.dpy, dc.gc, dc.col[DefaultBG]);
        if(xw.bufw > oldw)
 -              XFillRectangle(xw.dis, newbuf, dc.gc, oldw, 0,
 +              XFillRectangle(xw.dpy, newbuf, dc.gc, oldw, 0,
                                xw.bufw-oldw, MIN(xw.bufh, oldh));
        else if(xw.bufw < oldw && (BORDER > 0 || xw.w > xw.bufw))
 -              XClearArea(xw.dis, xw.win, BORDER+xw.bufw, BORDER,
 +              XClearArea(xw.dpy, xw.win, BORDER+xw.bufw, BORDER,
                                xw.w-xw.bufh-BORDER, BORDER+MIN(xw.bufh, oldh),
                                False);
        if(xw.bufh > oldh)
 -              XFillRectangle(xw.dis, newbuf, dc.gc, 0, oldh,
 +              XFillRectangle(xw.dpy, newbuf, dc.gc, 0, oldh,
                                xw.bufw, xw.bufh-oldh);
        else if(xw.bufh < oldh && (BORDER > 0 || xw.h > xw.bufh))
 -              XClearArea(xw.dis, xw.win, BORDER, BORDER+xw.bufh,
 +              XClearArea(xw.dpy, xw.win, BORDER, BORDER+xw.bufh,
                                xw.w-2*BORDER, xw.h-xw.bufh-BORDER,
                                False);
        xw.buf = newbuf;
  xloadcols(void) {
        int i, r, g, b;
        XColor color;
 -      unsigned long white = WhitePixel(xw.dis, xw.scr);
 +      unsigned long white = WhitePixel(xw.dpy, xw.scr);
  
        for(i = 0; i < 16; i++) {
 -              if (!XAllocNamedColor(xw.dis, xw.cmap, colorname[i], &color, &color)) {
 +              if (!XAllocNamedColor(xw.dpy, xw.cmap, colorname[i], &color, &color)) {
                        dc.col[i] = white;
                        fprintf(stderr, "Could not allocate color '%s'\n", colorname[i]);
                } else
                                color.red = r == 0 ? 0 : 0x3737 + 0x2828 * r;
                                color.green = g == 0 ? 0 : 0x3737 + 0x2828 * g;
                                color.blue = b == 0 ? 0 : 0x3737 + 0x2828 * b;
 -                              if (!XAllocColor(xw.dis, xw.cmap, &color)) {
 +                              if (!XAllocColor(xw.dpy, xw.cmap, &color)) {
                                        dc.col[i] = white;
                                        fprintf(stderr, "Could not allocate color %d\n", i);
                                } else
  
        for(r = 0; r < 24; r++, i++) {
                color.red = color.green = color.blue = 0x0808 + 0x0a0a * r;
 -              if (!XAllocColor(xw.dis, xw.cmap, &color)) {
 +              if (!XAllocColor(xw.dpy, xw.cmap, &color)) {
                        dc.col[i] = white;
                        fprintf(stderr, "Could not allocate color %d\n", i);
                } else
  
  void
  xclear(int x1, int y1, int x2, int y2) {
 -      XSetForeground(xw.dis, dc.gc, dc.col[DefaultBG]);
 -      XFillRectangle(xw.dis, xw.buf, dc.gc,
 +      XSetForeground(xw.dpy, dc.gc, dc.col[DefaultBG]);
 +      XFillRectangle(xw.dpy, xw.buf, dc.gc,
                       x1 * xw.cw, y1 * xw.ch,
                       (x2-x1+1) * xw.cw, (y2-y1+1) * xw.ch);
  }
@@@ -1442,7 -1442,7 +1442,7 @@@ xhints(void
                .base_height = 2*BORDER,
                .base_width = 2*BORDER,
        };
 -      XSetWMProperties(xw.dis, xw.win, NULL, NULL, NULL, 0, &size, &wm, &class);
 +      XSetWMProperties(xw.dpy, xw.win, NULL, NULL, NULL, 0, &size, &wm, &class);
  }
  
  XFontSet
@@@ -1453,7 -1453,7 +1453,7 @@@ xinitfont(char *fontstr
        int n;
  
        missing = NULL;
 -      set = XCreateFontSet(xw.dis, fontstr, &missing, &n, &def);
 +      set = XCreateFontSet(xw.dpy, fontstr, &missing, &n, &def);
        if(missing) {
                while(n--)
                        fprintf(stderr, "st: missing fontset: %s\n", missing[n]);
@@@ -1496,9 -1496,9 +1496,9 @@@ voi
  xinit(void) {
        XSetWindowAttributes attrs;
  
 -      if(!(xw.dis = XOpenDisplay(NULL)))
 +      if(!(xw.dpy = XOpenDisplay(NULL)))
                die("Can't open display\n");
 -      xw.scr = XDefaultScreen(xw.dis);
 +      xw.scr = XDefaultScreen(xw.dpy);
        
        /* font */
        initfonts(FONT, BOLDFONT);
        xw.ch = dc.font.ascent + dc.font.descent;
  
        /* colors */
 -      xw.cmap = XDefaultColormap(xw.dis, xw.scr);
 +      xw.cmap = XDefaultColormap(xw.dpy, xw.scr);
        xloadcols();
  
        /* window - default size */
                | PointerMotionMask | ButtonPressMask | ButtonReleaseMask;
        attrs.colormap = xw.cmap;
  
 -      xw.win = XCreateWindow(xw.dis, XRootWindow(xw.dis, xw.scr), 0, 0,
 -                      xw.w, xw.h, 0, XDefaultDepth(xw.dis, xw.scr), InputOutput,
 -                      XDefaultVisual(xw.dis, xw.scr),
 +      xw.win = XCreateWindow(xw.dpy, XRootWindow(xw.dpy, xw.scr), 0, 0,
 +                      xw.w, xw.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput,
 +                      XDefaultVisual(xw.dpy, xw.scr),
                        CWBackPixel | CWBorderPixel | CWBitGravity | CWEventMask
                        | CWColormap,
                        &attrs);
 -      xw.buf = XCreatePixmap(xw.dis, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dis, xw.scr));
 +      xw.buf = XCreatePixmap(xw.dpy, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dpy, xw.scr));
  
  
        /* input methods */
 -      xw.xim = XOpenIM(xw.dis, NULL, NULL, NULL);
 +      xw.xim = XOpenIM(xw.dpy, NULL, NULL, NULL);
        xw.xic = XCreateIC(xw.xim, XNInputStyle, XIMPreeditNothing 
                                           | XIMStatusNothing, XNClientWindow, xw.win, 
                                           XNFocusWindow, xw.win, NULL);
        /* gc */
 -      dc.gc = XCreateGC(xw.dis, xw.win, 0, NULL);
 +      dc.gc = XCreateGC(xw.dpy, xw.win, 0, NULL);
        
 -      XMapWindow(xw.dis, xw.win);
 +      XMapWindow(xw.dpy, xw.win);
        xhints();
 -      XStoreName(xw.dis, xw.win, opt_title ? opt_title : "st");
 -      XSync(xw.dis, 0);
 +      XStoreName(xw.dpy, xw.win, opt_title ? opt_title : "st");
 +      XSync(xw.dpy, 0);
  }
  
  void
@@@ -1559,10 -1559,10 +1559,10 @@@ xdraws(char *s, Glyph base, int x, int 
        else
                xfg = dc.col[base.fg], xbg = dc.col[base.bg];
  
 -      XSetBackground(xw.dis, dc.gc, xbg);
 -      XSetForeground(xw.dis, dc.gc, xfg);
 +      XSetBackground(xw.dpy, dc.gc, xbg);
 +      XSetForeground(xw.dpy, dc.gc, xfg);
  
 -      if(base.mode & ATTR_GFX)
 +      if(base.mode & ATTR_GFX) {
                for(i = 0; i < bytelen; i++) {
                        char c = gfx[(unsigned int)s[i] % 256];
                        if(c)
                        else if(s[i] > 0x5f)
                                s[i] -= 0x5f;
                }
 +      }
  
 -      XmbDrawImageString(xw.dis, xw.buf, base.mode & ATTR_BOLD ? dc.bfont.set : dc.font.set,
 +      XmbDrawImageString(xw.dpy, xw.buf, base.mode & ATTR_BOLD ? dc.bfont.set : dc.font.set,
            dc.gc, winx, winy, s, bytelen);
        
        if(base.mode & ATTR_UNDERLINE)
 -              XDrawLine(xw.dis, xw.buf, dc.gc, winx, winy+1, winx+width-1, winy+1);
 +              XDrawLine(xw.dpy, xw.buf, dc.gc, winx, winy+1, winx+width-1, winy+1);
  }
  
  void
@@@ -1613,9 -1612,9 +1613,9 @@@ voi
  xdrawc(int x, int y, Glyph g) {
        int sl = utf8size(g.c);
        XRectangle r = { x * xw.cw, y * xw.ch, xw.cw, xw.ch };
 -      XSetBackground(xw.dis, dc.gc, dc.col[g.bg]);
 -      XSetForeground(xw.dis, dc.gc, dc.col[g.fg]);
 -      XmbDrawImageString(xw.dis, xw.buf, g.mode&ATTR_BOLD?dc.bfont.fs:dc.font.fs,
 +      XSetBackground(xw.dpy, dc.gc, dc.col[g.bg]);
 +      XSetForeground(xw.dpy, dc.gc, dc.col[g.fg]);
 +      XmbDrawImageString(xw.dpy, xw.buf, g.mode&ATTR_BOLD?dc.bfont.fs:dc.font.fs,
            dc.gc, r.x, r.y+dc.font.ascent, g.c, sl);
  }
  
@@@ -1630,8 -1629,8 +1630,8 @@@ draw(int dummy) 
                                xdrawc(x, y, term.line[y][x]);
  
        xdrawcursor();
 -      XCopyArea(xw.dis, xw.buf, xw.win, dc.gc, 0, 0, xw.bufw, xw.bufh, BORDER, BORDER);
 -      XFlush(xw.dis);
 +      XCopyArea(xw.dpy, xw.buf, xw.win, dc.gc, 0, 0, xw.bufw, xw.bufh, BORDER, BORDER);
 +      XFlush(xw.dpy);
  }
  
  #else
@@@ -1673,7 -1672,7 +1673,7 @@@ draw(int redraw_all) 
                        xdraws(buf, base, ox, y, ic, ib);
        }
        xdrawcursor();
 -      XCopyArea(xw.dis, xw.buf, xw.win, dc.gc, 0, 0, xw.bufw, xw.bufh, BORDER, BORDER);
 +      XCopyArea(xw.dpy, xw.buf, xw.win, dc.gc, 0, 0, xw.bufw, xw.bufh, BORDER, BORDER);
  }
  
  #endif
@@@ -1687,7 -1686,7 +1687,7 @@@ expose(XEvent *ev) 
                        draw(SCREEN_REDRAW);
                }
        } else
 -              XCopyArea(xw.dis, xw.buf, xw.win, dc.gc, e->x-BORDER, e->y-BORDER,
 +              XCopyArea(xw.dpy, xw.buf, xw.win, dc.gc, e->x-BORDER, e->y-BORDER,
                                e->width, e->height, e->x, e->y);
  }
  
@@@ -1708,9 -1707,9 +1708,9 @@@ unmap(XEvent *ev) 
  
  void
  xseturgency(int add) {
 -      XWMHints *h = XGetWMHints(xw.dis, xw.win);
 +      XWMHints *h = XGetWMHints(xw.dpy, xw.win);
        h->flags = add ? (h->flags | XUrgencyHint) : (h->flags & ~XUrgencyHint);
 -      XSetWMHints(xw.dis, xw.win, h);
 +      XSetWMHints(xw.dpy, xw.win, h);
        XFree(h);
  }
  
@@@ -1807,7 -1806,7 +1807,7 @@@ voi
  run(void) {
        XEvent ev;
        fd_set rfd;
 -      int xfd = XConnectionNumber(xw.dis);
 +      int xfd = XConnectionNumber(xw.dpy);
  
        for(;;) {
                FD_ZERO(&rfd);
                        ttyread();
                        draw(SCREEN_UPDATE); 
                }
 -              while(XPending(xw.dis)) {
 -                      XNextEvent(xw.dis, &ev);
 +              while(XPending(xw.dpy)) {
 +                      XNextEvent(xw.dpy, &ev);
                        if (XFilterEvent(&ev, xw.win))
                                continue;
                        if(handler[ev.type])