Compare commits
	
		
			21 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | a0274bc20e | ||
|  | 5dbcca4926 | ||
|  | d63b9eb902 | ||
|  | 497a756382 | ||
|  | 8c68ec5241 | ||
|  | 5ce9716281 | ||
|  | f20e169a20 | ||
|  | 95f22c5305 | ||
|  | 7473a8d1a5 | ||
|  | a3f7420310 | ||
|  | 9846a56bd7 | ||
|  | 559fdc2786 | ||
|  | 8abe4bcb41 | ||
|  | 2fc7e532b2 | ||
|  | a6bbc0c96b | ||
|  | eb3b894f40 | ||
|  | 3a6d6d7401 | ||
|  | 211964d56e | ||
|  | f17abd25b3 | ||
|  | 7e8050cc62 | ||
|  | e5e959835b | 
							
								
								
									
										10
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Makefile
									
									
									
									
									
								
							| @ -7,13 +7,7 @@ include config.mk | ||||
| SRC = st.c x.c | ||||
| OBJ = $(SRC:.c=.o) | ||||
| 
 | ||||
| all: options st | ||||
| 
 | ||||
| options: | ||||
| 	@echo st build options: | ||||
| 	@echo "CFLAGS  = $(STCFLAGS)" | ||||
| 	@echo "LDFLAGS = $(STLDFLAGS)" | ||||
| 	@echo "CC      = $(CC)" | ||||
| all: st | ||||
| 
 | ||||
| config.h: | ||||
| 	cp config.def.h config.h | ||||
| @ -54,4 +48,4 @@ uninstall: | ||||
| 	rm -f $(DESTDIR)$(PREFIX)/bin/st | ||||
| 	rm -f $(DESTDIR)$(MANPREFIX)/man1/st.1 | ||||
| 
 | ||||
| .PHONY: all options clean dist install uninstall | ||||
| .PHONY: all clean dist install uninstall | ||||
|  | ||||
| @ -53,7 +53,7 @@ int allowwindowops = 0; | ||||
|  * near minlatency, but it waits longer for slow updates to avoid partial draw. | ||||
|  * low minlatency will tear/flicker more, as it can "detect" idle too early. | ||||
|  */ | ||||
| static double minlatency = 8; | ||||
| static double minlatency = 2; | ||||
| static double maxlatency = 33; | ||||
| 
 | ||||
| /*
 | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| # st version
 | ||||
| VERSION = 0.9 | ||||
| VERSION = 0.9.2 | ||||
| 
 | ||||
| # Customize below to fit your system
 | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										40
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								st.c
									
									
									
									
									
								
							| @ -1097,7 +1097,7 @@ tscrollup(int orig, int n) | ||||
| void | ||||
| selscroll(int orig, int n) | ||||
| { | ||||
| 	if (sel.ob.x == -1) | ||||
| 	if (sel.ob.x == -1 || sel.alt != IS_SET(MODE_ALTSCREEN)) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (BETWEEN(sel.nb.y, orig, term.bot) != BETWEEN(sel.ne.y, orig, term.bot)) { | ||||
| @ -1132,6 +1132,7 @@ csiparse(void) | ||||
| { | ||||
| 	char *p = csiescseq.buf, *np; | ||||
| 	long int v; | ||||
| 	int sep = ';'; /* colon or semi-colon, but not both */ | ||||
| 
 | ||||
| 	csiescseq.narg = 0; | ||||
| 	if (*p == '?') { | ||||
| @ -1149,7 +1150,9 @@ csiparse(void) | ||||
| 			v = -1; | ||||
| 		csiescseq.arg[csiescseq.narg++] = v; | ||||
| 		p = np; | ||||
| 		if (*p != ';' || csiescseq.narg == ESC_ARG_SIZ) | ||||
| 		if (sep == ';' && *p == ':') | ||||
| 			sep = ':'; /* allow override to colon once */ | ||||
| 		if (*p != sep || csiescseq.narg == ESC_ARG_SIZ) | ||||
| 			break; | ||||
| 		p++; | ||||
| 	} | ||||
| @ -1643,7 +1646,7 @@ csihandle(void) | ||||
| 			ttywrite(vtiden, strlen(vtiden), 0); | ||||
| 		break; | ||||
| 	case 'b': /* REP -- if last char is printable print it <n> more times */ | ||||
| 		DEFAULT(csiescseq.arg[0], 1); | ||||
| 		LIMIT(csiescseq.arg[0], 1, 65535); | ||||
| 		if (term.lastc) | ||||
| 			while (csiescseq.arg[0]-- > 0) | ||||
| 				tputc(term.lastc); | ||||
| @ -1728,6 +1731,7 @@ csihandle(void) | ||||
| 		} | ||||
| 		break; | ||||
| 	case 'S': /* SU -- Scroll <n> line up */ | ||||
| 		if (csiescseq.priv) break; | ||||
| 		DEFAULT(csiescseq.arg[0], 1); | ||||
| 		tscrollup(term.top, csiescseq.arg[0]); | ||||
| 		break; | ||||
| @ -1769,11 +1773,18 @@ csihandle(void) | ||||
| 	case 'm': /* SGR -- Terminal attribute (color) */ | ||||
| 		tsetattr(csiescseq.arg, csiescseq.narg); | ||||
| 		break; | ||||
| 	case 'n': /* DSR – Device Status Report (cursor position) */ | ||||
| 		if (csiescseq.arg[0] == 6) { | ||||
| 	case 'n': /* DSR -- Device Status Report */ | ||||
| 		switch (csiescseq.arg[0]) { | ||||
| 		case 5: /* Status Report "OK" `0n` */ | ||||
| 			ttywrite("\033[0n", sizeof("\033[0n") - 1, 0); | ||||
| 			break; | ||||
| 		case 6: /* Report Cursor Position (CPR) "<row>;<column>R" */ | ||||
| 			len = snprintf(buf, sizeof(buf), "\033[%i;%iR", | ||||
| 					term.c.y+1, term.c.x+1); | ||||
| 			               term.c.y+1, term.c.x+1); | ||||
| 			ttywrite(buf, len, 0); | ||||
| 			break; | ||||
| 		default: | ||||
| 			goto unknown; | ||||
| 		} | ||||
| 		break; | ||||
| 	case 'r': /* DECSTBM -- Set Scrolling Region */ | ||||
| @ -1932,8 +1943,10 @@ strhandle(void) | ||||
| 			if (p && !strcmp(p, "?")) { | ||||
| 				osc_color_response(j, 0, 1); | ||||
| 			} else if (xsetcolorname(j, p)) { | ||||
| 				if (par == 104 && narg <= 1) | ||||
| 				if (par == 104 && narg <= 1) { | ||||
| 					xloadcols(); | ||||
| 					return; /* color reset without parameter */ | ||||
| 				} | ||||
| 				fprintf(stderr, "erresc: invalid color j=%d, p=%s\n", | ||||
| 				        j, p ? p : "(null)"); | ||||
| 			} else { | ||||
| @ -2321,6 +2334,7 @@ eschandle(uchar ascii) | ||||
| 		treset(); | ||||
| 		resettitle(); | ||||
| 		xloadcols(); | ||||
| 		xsetmode(0, MODE_HIDE); | ||||
| 		break; | ||||
| 	case '=': /* DECPAM -- Application keypad */ | ||||
| 		xsetmode(1, MODE_APPKEYPAD); | ||||
| @ -2413,6 +2427,9 @@ check_control_code: | ||||
| 	 * they must not cause conflicts with sequences. | ||||
| 	 */ | ||||
| 	if (control) { | ||||
| 		/* in UTF-8 mode ignore handling C1 control characters */ | ||||
| 		if (IS_SET(MODE_UTF8) && ISCONTROLC1(u)) | ||||
| 			return; | ||||
| 		tcontrolcode(u); | ||||
| 		/*
 | ||||
| 		 * control codes are not shown ever | ||||
| @ -2459,11 +2476,16 @@ check_control_code: | ||||
| 		gp = &term.line[term.c.y][term.c.x]; | ||||
| 	} | ||||
| 
 | ||||
| 	if (IS_SET(MODE_INSERT) && term.c.x+width < term.col) | ||||
| 	if (IS_SET(MODE_INSERT) && term.c.x+width < term.col) { | ||||
| 		memmove(gp+width, gp, (term.col - term.c.x - width) * sizeof(Glyph)); | ||||
| 		gp->mode &= ~ATTR_WIDE; | ||||
| 	} | ||||
| 
 | ||||
| 	if (term.c.x+width > term.col) { | ||||
| 		tnewline(1); | ||||
| 		if (IS_SET(MODE_WRAP)) | ||||
| 			tnewline(1); | ||||
| 		else | ||||
| 			tmoveto(term.col - width, term.c.y); | ||||
| 		gp = &term.line[term.c.y][term.c.x]; | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										4
									
								
								st.info
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								st.info
									
									
									
									
									
								
							| @ -184,6 +184,10 @@ st-mono| simpleterm monocolor, | ||||
| # XTerm extensions | ||||
| 	rmxx=\E[29m, | ||||
| 	smxx=\E[9m, | ||||
| 	BE=\E[?2004h, | ||||
| 	BD=\E[?2004l, | ||||
| 	PS=\E[200~, | ||||
| 	PE=\E[201~, | ||||
| # disabled rep for now: causes some issues with older ncurses versions. | ||||
| #	rep=%p1%c\E[%p2%{1}%-%db, | ||||
| # tmux extensions, see TERMINFO EXTENSIONS in tmux(1) | ||||
|  | ||||
							
								
								
									
										30
									
								
								x.c
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								x.c
									
									
									
									
									
								
							| @ -818,7 +818,7 @@ xloadcols(void) | ||||
| int | ||||
| xgetcolor(int x, unsigned char *r, unsigned char *g, unsigned char *b) | ||||
| { | ||||
| 	if (!BETWEEN(x, 0, dc.collen)) | ||||
| 	if (!BETWEEN(x, 0, dc.collen - 1)) | ||||
| 		return 1; | ||||
| 
 | ||||
| 	*r = dc.col[x].color.red >> 8; | ||||
| @ -833,7 +833,7 @@ xsetcolorname(int x, const char *name) | ||||
| { | ||||
| 	Color ncolor; | ||||
| 
 | ||||
| 	if (!BETWEEN(x, 0, dc.collen)) | ||||
| 	if (!BETWEEN(x, 0, dc.collen - 1)) | ||||
| 		return 1; | ||||
| 
 | ||||
| 	if (!xloadcolor(x, name, &ncolor)) | ||||
| @ -1131,7 +1131,7 @@ xinit(int cols, int rows) | ||||
| { | ||||
| 	XGCValues gcvalues; | ||||
| 	Cursor cursor; | ||||
| 	Window parent; | ||||
| 	Window parent, root; | ||||
| 	pid_t thispid = getpid(); | ||||
| 	XColor xmousefg, xmousebg; | ||||
| 
 | ||||
| @ -1168,16 +1168,19 @@ xinit(int cols, int rows) | ||||
| 		| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask; | ||||
| 	xw.attrs.colormap = xw.cmap; | ||||
| 
 | ||||
| 	root = XRootWindow(xw.dpy, xw.scr); | ||||
| 	if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) | ||||
| 		parent = XRootWindow(xw.dpy, xw.scr); | ||||
| 	xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t, | ||||
| 		parent = root; | ||||
| 	xw.win = XCreateWindow(xw.dpy, root, xw.l, xw.t, | ||||
| 			win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput, | ||||
| 			xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity | ||||
| 			| CWEventMask | CWColormap, &xw.attrs); | ||||
| 	if (parent != root) | ||||
| 		XReparentWindow(xw.dpy, xw.win, parent, xw.l, xw.t); | ||||
| 
 | ||||
| 	memset(&gcvalues, 0, sizeof(gcvalues)); | ||||
| 	gcvalues.graphics_exposures = False; | ||||
| 	dc.gc = XCreateGC(xw.dpy, parent, GCGraphicsExposures, | ||||
| 	dc.gc = XCreateGC(xw.dpy, xw.win, GCGraphicsExposures, | ||||
| 			&gcvalues); | ||||
| 	xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | ||||
| 			DefaultDepth(xw.dpy, xw.scr)); | ||||
| @ -1617,6 +1620,9 @@ xseticontitle(char *p) | ||||
| 	XTextProperty prop; | ||||
| 	DEFAULT(p, opt_title); | ||||
| 
 | ||||
| 	if (p[0] == '\0') | ||||
| 		p = opt_title; | ||||
| 
 | ||||
| 	if (Xutf8TextListToTextProperty(xw.dpy, &p, 1, XUTF8StringStyle, | ||||
| 	                                &prop) != Success) | ||||
| 		return; | ||||
| @ -1631,6 +1637,9 @@ xsettitle(char *p) | ||||
| 	XTextProperty prop; | ||||
| 	DEFAULT(p, opt_title); | ||||
| 
 | ||||
| 	if (p[0] == '\0') | ||||
| 		p = opt_title; | ||||
| 
 | ||||
| 	if (Xutf8TextListToTextProperty(xw.dpy, &p, 1, XUTF8StringStyle, | ||||
| 	                                &prop) != Success) | ||||
| 		return; | ||||
| @ -1833,7 +1842,7 @@ void | ||||
| kpress(XEvent *ev) | ||||
| { | ||||
| 	XKeyEvent *e = &ev->xkey; | ||||
| 	KeySym ksym; | ||||
| 	KeySym ksym = NoSymbol; | ||||
| 	char buf[64], *customkey; | ||||
| 	int len; | ||||
| 	Rune c; | ||||
| @ -1843,10 +1852,13 @@ kpress(XEvent *ev) | ||||
| 	if (IS_SET(MODE_KBDLOCK)) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (xw.ime.xic) | ||||
| 	if (xw.ime.xic) { | ||||
| 		len = XmbLookupString(xw.ime.xic, e, buf, sizeof buf, &ksym, &status); | ||||
| 	else | ||||
| 		if (status == XBufferOverflow) | ||||
| 			return; | ||||
| 	} else { | ||||
| 		len = XLookupString(e, buf, sizeof buf, &ksym, NULL); | ||||
| 	} | ||||
| 	/* 1. shortcuts */ | ||||
| 	for (bp = shortcuts; bp < shortcuts + LEN(shortcuts); bp++) { | ||||
| 		if (ksym == bp->keysym && match(bp->mod, e->state)) { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user