Compare commits
	
		
			8 Commits
		
	
	
		
			9c30066e73
			...
			xresources
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | eba5410764 | ||
|  | ab5128a96e | ||
|  | a7ec4edb9d | ||
|  | 475a0a36cb | ||
|  | e8392b282c | ||
|  | f8afebdfa0 | ||
|  | bda9c9ffa6 | ||
|  | 045a0fab4f | 
							
								
								
									
										36
									
								
								config.def.h
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								config.def.h
									
									
									
									
									
								
							| @@ -157,6 +157,40 @@ static unsigned int mousebg = 0; | |||||||
|  */ |  */ | ||||||
| static unsigned int defaultattr = 11; | static unsigned int defaultattr = 11; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Xresources preferences to load at startup | ||||||
|  |  */ | ||||||
|  | ResourcePref resources[] = { | ||||||
|  | 		{ "font",         STRING,  &font }, | ||||||
|  | 		{ "color0",       STRING,  &colorname[0] }, | ||||||
|  | 		{ "color1",       STRING,  &colorname[1] }, | ||||||
|  | 		{ "color2",       STRING,  &colorname[2] }, | ||||||
|  | 		{ "color3",       STRING,  &colorname[3] }, | ||||||
|  | 		{ "color4",       STRING,  &colorname[4] }, | ||||||
|  | 		{ "color5",       STRING,  &colorname[5] }, | ||||||
|  | 		{ "color6",       STRING,  &colorname[6] }, | ||||||
|  | 		{ "color7",       STRING,  &colorname[7] }, | ||||||
|  | 		{ "color8",       STRING,  &colorname[8] }, | ||||||
|  | 		{ "color9",       STRING,  &colorname[9] }, | ||||||
|  | 		{ "color10",      STRING,  &colorname[10] }, | ||||||
|  | 		{ "color11",      STRING,  &colorname[11] }, | ||||||
|  | 		{ "color12",      STRING,  &colorname[12] }, | ||||||
|  | 		{ "color13",      STRING,  &colorname[13] }, | ||||||
|  | 		{ "color14",      STRING,  &colorname[14] }, | ||||||
|  | 		{ "color15",      STRING,  &colorname[15] }, | ||||||
|  | 		{ "background",   STRING,  &colorname[256] }, | ||||||
|  | 		{ "foreground",   STRING,  &colorname[257] }, | ||||||
|  | 		{ "cursorColor",  STRING,  &colorname[258] }, | ||||||
|  | 		{ "termname",     STRING,  &termname }, | ||||||
|  | 		{ "shell",        STRING,  &shell }, | ||||||
|  | 		{ "blinktimeout", INTEGER, &blinktimeout }, | ||||||
|  | 		{ "bellvolume",   INTEGER, &bellvolume }, | ||||||
|  | 		{ "tabspaces",    INTEGER, &tabspaces }, | ||||||
|  | 		{ "borderpx",     INTEGER, &borderpx }, | ||||||
|  | 		{ "cwscale",      FLOAT,   &cwscale }, | ||||||
|  | 		{ "chscale",      FLOAT,   &chscale }, | ||||||
|  | }; | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Force mouse select/shortcuts while mask is active (when MODE_MOUSE is set). |  * Force mouse select/shortcuts while mask is active (when MODE_MOUSE is set). | ||||||
|  * Note that if you want to use ShiftMask with selmasks, set this to an other |  * Note that if you want to use ShiftMask with selmasks, set this to an other | ||||||
| @@ -171,7 +205,9 @@ static uint forcemousemod = ShiftMask; | |||||||
| static MouseShortcut mshortcuts[] = { | static MouseShortcut mshortcuts[] = { | ||||||
| 	/* mask                 button   function        argument       release */ | 	/* mask                 button   function        argument       release */ | ||||||
| 	{ XK_ANY_MOD,           Button2, selpaste,       {.i = 0},      1 }, | 	{ XK_ANY_MOD,           Button2, selpaste,       {.i = 0},      1 }, | ||||||
|  | 	{ ShiftMask,            Button4, ttysend,        {.s = "\033[5;2~"} }, | ||||||
| 	{ XK_ANY_MOD,           Button4, ttysend,        {.s = "\031"} }, | 	{ XK_ANY_MOD,           Button4, ttysend,        {.s = "\031"} }, | ||||||
|  | 	{ ShiftMask,            Button5, ttysend,        {.s = "\033[6;2~"} }, | ||||||
| 	{ XK_ANY_MOD,           Button5, ttysend,        {.s = "\005"} }, | 	{ XK_ANY_MOD,           Button5, ttysend,        {.s = "\005"} }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										26
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								st.c
									
									
									
									
									
								
							| @@ -1106,29 +1106,19 @@ selscroll(int orig, int n) | |||||||
| 	if (sel.ob.x == -1) | 	if (sel.ob.x == -1) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
| 	if (BETWEEN(sel.ob.y, orig, term.bot) || BETWEEN(sel.oe.y, orig, term.bot)) { | 	if (BETWEEN(sel.nb.y, orig, term.bot) != BETWEEN(sel.ne.y, orig, term.bot)) { | ||||||
| 		if ((sel.ob.y += n) > term.bot || (sel.oe.y += n) < term.top) { | 		selclear(); | ||||||
|  | 	} else if (BETWEEN(sel.nb.y, orig, term.bot)) { | ||||||
|  | 		sel.ob.y += n; | ||||||
|  | 		sel.oe.y += n; | ||||||
|  | 		if (sel.ob.y < term.top || sel.ob.y > term.bot || | ||||||
|  | 		    sel.oe.y < term.top || sel.oe.y > term.bot) { | ||||||
| 			selclear(); | 			selclear(); | ||||||
| 			return; |  | ||||||
| 		} |  | ||||||
| 		if (sel.type == SEL_RECTANGULAR) { |  | ||||||
| 			if (sel.ob.y < term.top) |  | ||||||
| 				sel.ob.y = term.top; |  | ||||||
| 			if (sel.oe.y > term.bot) |  | ||||||
| 				sel.oe.y = term.bot; |  | ||||||
| 		} else { | 		} else { | ||||||
| 			if (sel.ob.y < term.top) { |  | ||||||
| 				sel.ob.y = term.top; |  | ||||||
| 				sel.ob.x = 0; |  | ||||||
| 			} |  | ||||||
| 			if (sel.oe.y > term.bot) { |  | ||||||
| 				sel.oe.y = term.bot; |  | ||||||
| 				sel.oe.x = term.col; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 			selnormalize(); | 			selnormalize(); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| void | void | ||||||
| tnewline(int first_col) | tnewline(int first_col) | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								st.info
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								st.info
									
									
									
									
									
								
							| @@ -158,6 +158,7 @@ st-mono| simpleterm monocolor, | |||||||
| 	rc=\E8, | 	rc=\E8, | ||||||
| 	rev=\E[7m, | 	rev=\E[7m, | ||||||
| 	ri=\EM, | 	ri=\EM, | ||||||
|  | 	rin=\E[%p1%dT, | ||||||
| 	ritm=\E[23m, | 	ritm=\E[23m, | ||||||
| 	rmacs=\E(B, | 	rmacs=\E(B, | ||||||
| 	rmcup=\E[?1049l, | 	rmcup=\E[?1049l, | ||||||
|   | |||||||
							
								
								
									
										79
									
								
								x.c
									
									
									
									
									
								
							
							
						
						
									
										79
									
								
								x.c
									
									
									
									
									
								
							| @@ -14,6 +14,7 @@ | |||||||
| #include <X11/keysym.h> | #include <X11/keysym.h> | ||||||
| #include <X11/Xft/Xft.h> | #include <X11/Xft/Xft.h> | ||||||
| #include <X11/XKBlib.h> | #include <X11/XKBlib.h> | ||||||
|  | #include <X11/Xresource.h> | ||||||
|  |  | ||||||
| char *argv0; | char *argv0; | ||||||
| #include "arg.h" | #include "arg.h" | ||||||
| @@ -45,6 +46,20 @@ typedef struct { | |||||||
| 	signed char appcursor; /* application cursor */ | 	signed char appcursor; /* application cursor */ | ||||||
| } Key; | } Key; | ||||||
|  |  | ||||||
|  | /* Xresources preferences */ | ||||||
|  | enum resource_type { | ||||||
|  | 	STRING = 0, | ||||||
|  | 	INTEGER = 1, | ||||||
|  | 	FLOAT = 2 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef struct { | ||||||
|  | 	char *name; | ||||||
|  | 	enum resource_type type; | ||||||
|  | 	void *dst; | ||||||
|  | } ResourcePref; | ||||||
|  |  | ||||||
|  |  | ||||||
| /* X modifiers */ | /* X modifiers */ | ||||||
| #define XK_ANY_MOD    UINT_MAX | #define XK_ANY_MOD    UINT_MAX | ||||||
| #define XK_NO_MOD     0 | #define XK_NO_MOD     0 | ||||||
| @@ -828,8 +843,8 @@ xclear(int x1, int y1, int x2, int y2) | |||||||
| void | void | ||||||
| xhints(void) | xhints(void) | ||||||
| { | { | ||||||
| 	XClassHint class = {opt_name ? opt_name : termname, | 	XClassHint class = {opt_name ? opt_name : "st", | ||||||
| 	                    opt_class ? opt_class : termname}; | 	                    opt_class ? opt_class : "St"}; | ||||||
| 	XWMHints wm = {.flags = InputHint, .input = 1}; | 	XWMHints wm = {.flags = InputHint, .input = 1}; | ||||||
| 	XSizeHints *sizeh; | 	XSizeHints *sizeh; | ||||||
|  |  | ||||||
| @@ -1104,8 +1119,6 @@ xinit(int cols, int rows) | |||||||
| 	pid_t thispid = getpid(); | 	pid_t thispid = getpid(); | ||||||
| 	XColor xmousefg, xmousebg; | 	XColor xmousefg, xmousebg; | ||||||
|  |  | ||||||
| 	if (!(xw.dpy = XOpenDisplay(NULL))) |  | ||||||
| 		die("can't open display\n"); |  | ||||||
| 	xw.scr = XDefaultScreen(xw.dpy); | 	xw.scr = XDefaultScreen(xw.dpy); | ||||||
| 	xw.vis = XDefaultVisual(xw.dpy, xw.scr); | 	xw.vis = XDefaultVisual(xw.dpy, xw.scr); | ||||||
|  |  | ||||||
| @@ -1965,6 +1978,60 @@ run(void) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int | ||||||
|  | resource_load(XrmDatabase db, char *name, enum resource_type rtype, void *dst) | ||||||
|  | { | ||||||
|  | 	char **sdst = dst; | ||||||
|  | 	int *idst = dst; | ||||||
|  | 	float *fdst = dst; | ||||||
|  |  | ||||||
|  | 	char fullname[256]; | ||||||
|  | 	char fullclass[256]; | ||||||
|  | 	char *type; | ||||||
|  | 	XrmValue ret; | ||||||
|  |  | ||||||
|  | 	snprintf(fullname, sizeof(fullname), "%s.%s", | ||||||
|  | 			opt_name ? opt_name : "st", name); | ||||||
|  | 	snprintf(fullclass, sizeof(fullclass), "%s.%s", | ||||||
|  | 			opt_class ? opt_class : "St", name); | ||||||
|  | 	fullname[sizeof(fullname) - 1] = fullclass[sizeof(fullclass) - 1] = '\0'; | ||||||
|  |  | ||||||
|  | 	XrmGetResource(db, fullname, fullclass, &type, &ret); | ||||||
|  | 	if (ret.addr == NULL || strncmp("String", type, 64)) | ||||||
|  | 		return 1; | ||||||
|  |  | ||||||
|  | 	switch (rtype) { | ||||||
|  | 	case STRING: | ||||||
|  | 		*sdst = ret.addr; | ||||||
|  | 		break; | ||||||
|  | 	case INTEGER: | ||||||
|  | 		*idst = strtoul(ret.addr, NULL, 10); | ||||||
|  | 		break; | ||||||
|  | 	case FLOAT: | ||||||
|  | 		*fdst = strtof(ret.addr, NULL); | ||||||
|  | 		break; | ||||||
|  | 	} | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | config_init(void) | ||||||
|  | { | ||||||
|  | 	char *resm; | ||||||
|  | 	XrmDatabase db; | ||||||
|  | 	ResourcePref *p; | ||||||
|  |  | ||||||
|  | 	XrmInitialize(); | ||||||
|  | 	resm = XResourceManagerString(xw.dpy); | ||||||
|  | 	if (!resm) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
|  | 	db = XrmGetStringDatabase(resm); | ||||||
|  | 	for (p = resources; p < resources + LEN(resources); p++) | ||||||
|  | 		resource_load(db, p->name, p->type, p->dst); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void | void | ||||||
| usage(void) | usage(void) | ||||||
| { | { | ||||||
| @@ -2038,6 +2105,10 @@ run: | |||||||
|  |  | ||||||
| 	setlocale(LC_CTYPE, ""); | 	setlocale(LC_CTYPE, ""); | ||||||
| 	XSetLocaleModifiers(""); | 	XSetLocaleModifiers(""); | ||||||
|  | 	if(!(xw.dpy = XOpenDisplay(NULL))) | ||||||
|  | 		die("Can't open display\n"); | ||||||
|  |  | ||||||
|  | 	config_init(); | ||||||
| 	cols = MAX(cols, 1); | 	cols = MAX(cols, 1); | ||||||
| 	rows = MAX(rows, 1); | 	rows = MAX(rows, 1); | ||||||
| 	tnew(cols, rows); | 	tnew(cols, rows); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user