diff options
author | Tim Keller <tjkeller.xyz> | 2025-01-08 22:42:46 -0600 |
---|---|---|
committer | Tim Keller <tjkeller.xyz> | 2025-01-08 22:42:46 -0600 |
commit | 0e7f14ceaf5ecebf3517af9611276c61db2bc66b (patch) | |
tree | 5f7de768876ca47781e2d986351f605e3bce55a9 | |
parent | d8e0ba487eca7164aed1d1fde1258558a6e44368 (diff) | |
download | st-0e7f14ceaf5ecebf3517af9611276c61db2bc66b.tar.xz st-0e7f14ceaf5ecebf3517af9611276c61db2bc66b.zip |
replace anygeometry with anysize and modify for clean resizing
-rw-r--r-- | PATCHES | 2 | ||||
-rw-r--r-- | config.def.h | 13 | ||||
-rw-r--r-- | x.c | 68 |
3 files changed, 23 insertions, 60 deletions
@@ -1,4 +1,4 @@ -st-anygeometry-0.8.1.diff +st-anysize-20220718-baa9357.diff (modified to so that text does not jitter like st-expected-anysize-0.9.diff but better) st-boxdraw_v2-0.8.5.diff st-clipboard-20180309-c5ba9c0.diff st-csi_22_23-0.8.5.diff diff --git a/config.def.h b/config.def.h index c535ee0..5a1a8ed 100644 --- a/config.def.h +++ b/config.def.h @@ -154,12 +154,6 @@ static unsigned int defaultrcs = 257; static unsigned int cursorshape = 2; /* - * Whether to use pixel geometry or cell geometry - */ - -static Geometry geometry = CellGeometry; - -/* * Default columns and rows numbers */ @@ -167,13 +161,6 @@ static unsigned int cols = 80; static unsigned int rows = 24; /* - * Default width and height (including borders!) - */ - -static unsigned int width = 564; -static unsigned int height = 364; - -/* * Default colour and shape of the mouse cursor */ static unsigned int mouseshape = XC_xterm; @@ -53,11 +53,6 @@ enum undercurl_slope_type { UNDERCURL_SLOPE_BOTTOM_CAP = 3 }; -typedef enum { - PixelGeometry, - CellGeometry -} Geometry; - /* X modifiers */ #define XK_ANY_MOD UINT_MAX #define XK_NO_MOD 0 @@ -97,6 +92,7 @@ typedef XftGlyphFontSpec GlyphFontSpec; typedef struct { int tw, th; /* tty width and height */ int w, h; /* window width and height */ + int hborderpx, vborderpx; int ch; /* char height */ int cw; /* char width */ int mode; /* window state/mode flags */ @@ -349,7 +345,7 @@ ttysend(const Arg *arg) int evcol(XEvent *e) { - int x = e->xbutton.x - borderpx; + int x = e->xbutton.x - win.hborderpx; LIMIT(x, 0, win.tw - 1); return x / win.cw; } @@ -357,7 +353,7 @@ evcol(XEvent *e) int evrow(XEvent *e) { - int y = e->xbutton.y - borderpx; + int y = e->xbutton.y - win.vborderpx; LIMIT(y, 0, win.th - 1); return y / win.ch; } @@ -759,6 +755,9 @@ cresize(int width, int height) col = MAX(1, col); row = MAX(1, row); + win.hborderpx = (win.w - col * win.cw); + win.vborderpx = (win.h - row * win.ch); + tresize(col, row); xresize(col, row); ttyresize(win.tw, win.th); @@ -889,8 +888,8 @@ xhints(void) sizeh->flags = PSize | PResizeInc | PBaseSize | PMinSize; sizeh->height = win.h; sizeh->width = win.w; - sizeh->height_inc = win.ch; - sizeh->width_inc = win.cw; + sizeh->height_inc = 1; + sizeh->width_inc = 1; sizeh->base_height = 2 * borderpx; sizeh->base_width = 2 * borderpx; sizeh->min_height = win.ch + 2 * borderpx; @@ -1147,7 +1146,7 @@ xicdestroy(XIC xim, XPointer client, XPointer call) } void -xinit(int w, int h) +xinit(int cols, int rows) { XGCValues gcvalues; Cursor cursor; @@ -1172,16 +1171,8 @@ xinit(int w, int h) xloadcols(); /* adjust fixed window geometry */ - switch (geometry) { - case CellGeometry: - win.w = 2 * borderpx + w * win.cw; - win.h = 2 * borderpx + h * win.ch; - break; - case PixelGeometry: - win.w = w; - win.h = h; - break; - } + win.w = win.hborderpx + 2 * borderpx + cols * win.cw; + win.h = win.vborderpx + 2 * borderpx + rows * win.ch; if (xw.gm & XNegative) xw.l += DisplayWidth(xw.dpy, xw.scr) - win.w - 2; if (xw.gm & YNegative) @@ -1549,17 +1540,17 @@ xdrawglyphfontspecs(const XftGlyphFontSpec *specs, Glyph base, int len, int x, i /* Intelligent cleaning up of the borders. */ if (x == 0) { - xclear(0, (y == 0)? 0 : winy, borderpx, + xclear(0, (y == 0)? 0 : winy, win.hborderpx, winy + win.ch + - ((winy + win.ch >= borderpx + win.th)? win.h : 0)); + ((winy + win.ch >= win.vborderpx + win.th)? win.h : 0)); } - if (winx + width >= borderpx + win.tw) { + if (winx + width >= win.hborderpx + win.tw) { xclear(winx + width, (y == 0)? 0 : winy, win.w, - ((winy + win.ch >= borderpx + win.th)? win.h : (winy + win.ch))); + ((winy + win.ch >= win.vborderpx + win.th)? win.h : (winy + win.ch))); } if (y == 0) - xclear(winx, 0, winx + width, borderpx); - if (winy + win.ch >= borderpx + win.th) + xclear(winx, 0, winx + width, win.vborderpx); + if (winy + win.ch >= win.vborderpx + win.th) xclear(winx, winy + win.ch, winx + width, win.h); /* Clean up the region we want to draw to. */ @@ -2007,16 +1998,16 @@ xdrawcursor(int cx, int cy, Glyph g, int ox, int oy, Glyph og) case 3: /* Blinking Underline */ case 4: /* Steady Underline */ XftDrawRect(xw.draw, &drawcol, - borderpx + cx * win.cw, - borderpx + (cy + 1) * win.ch - \ +- borderpx + cx * win.cw, +- borderpx + (cy + 1) * win.ch - \ cursorthickness, win.cw, cursorthickness); break; case 5: /* Blinking bar */ case 6: /* Steady bar */ XftDrawRect(xw.draw, &drawcol, - borderpx + cx * win.cw, - borderpx + cy * win.ch, +- borderpx + cx * win.cw, +- borderpx + cy * win.ch, cursorthickness, win.ch); break; } @@ -2525,12 +2516,6 @@ main(int argc, char *argv[]) case 'g': xw.gm = XParseGeometry(EARGF(usage()), &xw.l, &xw.t, &cols, &rows); - geometry = CellGeometry; - break; - case 'G': - xw.gm = XParseGeometry(EARGF(usage()), - &xw.l, &xw.t, &width, &height); - geometry = PixelGeometry; break; case 'i': xw.isfixed = 1; @@ -2567,19 +2552,10 @@ run: setlocale(LC_CTYPE, ""); XSetLocaleModifiers(""); - switch (geometry) { - case CellGeometry: - xinit(cols, rows); - break; - case PixelGeometry: - xinit(width, height); - cols = (win.w - 2 * borderpx) / win.cw; - rows = (win.h - 2 * borderpx) / win.ch; - break; - } cols = MAX(cols, 1); rows = MAX(rows, 1); tnew(cols, rows); + xinit(cols, rows); xsetenv(); selinit(); run(); |