Merge
This commit is contained in:
		
						commit
						a882648624
					
				
					 5 changed files with 63 additions and 31 deletions
				
			
		
							
								
								
									
										1
									
								
								LICENSE
									
										
									
									
									
								
							
							
						
						
									
										1
									
								
								LICENSE
									
										
									
									
									
								
							| 
						 | 
					@ -18,6 +18,7 @@ MIT/X Consortium License
 | 
				
			||||||
© 2015-2016 Quentin Rameau <quinq@fifth.space>
 | 
					© 2015-2016 Quentin Rameau <quinq@fifth.space>
 | 
				
			||||||
© 2015-2016 Eric Pruitt <eric.pruitt@gmail.com>
 | 
					© 2015-2016 Eric Pruitt <eric.pruitt@gmail.com>
 | 
				
			||||||
© 2016-2017 Markus Teich <markus.teich@stusta.mhn.de>
 | 
					© 2016-2017 Markus Teich <markus.teich@stusta.mhn.de>
 | 
				
			||||||
 | 
					© 2020-2022 Chris Down <chris@chrisdown.name>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Permission is hereby granted, free of charge, to any person obtaining a
 | 
					Permission is hereby granted, free of charge, to any person obtaining a
 | 
				
			||||||
copy of this software and associated documentation files (the "Software"),
 | 
					copy of this software and associated documentation files (the "Software"),
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -19,6 +19,7 @@ FREETYPELIBS = -lfontconfig -lXft
 | 
				
			||||||
FREETYPEINC = /usr/include/freetype2
 | 
					FREETYPEINC = /usr/include/freetype2
 | 
				
			||||||
# OpenBSD (uncomment)
 | 
					# OpenBSD (uncomment)
 | 
				
			||||||
#FREETYPEINC = ${X11INC}/freetype2
 | 
					#FREETYPEINC = ${X11INC}/freetype2
 | 
				
			||||||
 | 
					#MANPREFIX = ${PREFIX}/man
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# includes and libs
 | 
					# includes and libs
 | 
				
			||||||
INCS = -I${X11INC} -I${FREETYPEINC}
 | 
					INCS = -I${X11INC} -I${FREETYPEINC}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										88
									
								
								drw.c
									
										
									
									
									
								
							
							
						
						
									
										88
									
								
								drw.c
									
										
									
									
									
								
							| 
						 | 
					@ -238,12 +238,10 @@ drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lpad, const char *text, int invert)
 | 
					drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lpad, const char *text, int invert)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	char buf[1024];
 | 
						int i, ty, ellipsis_x = 0;
 | 
				
			||||||
	int ty;
 | 
						unsigned int tmpw, ew, ellipsis_w = 0, ellipsis_len;
 | 
				
			||||||
	unsigned int ew;
 | 
					 | 
				
			||||||
	XftDraw *d = NULL;
 | 
						XftDraw *d = NULL;
 | 
				
			||||||
	Fnt *usedfont, *curfont, *nextfont;
 | 
						Fnt *usedfont, *curfont, *nextfont;
 | 
				
			||||||
	size_t i, len;
 | 
					 | 
				
			||||||
	int utf8strlen, utf8charlen, render = x || y || w || h;
 | 
						int utf8strlen, utf8charlen, render = x || y || w || h;
 | 
				
			||||||
	long utf8codepoint = 0;
 | 
						long utf8codepoint = 0;
 | 
				
			||||||
	const char *utf8str;
 | 
						const char *utf8str;
 | 
				
			||||||
| 
						 | 
					@ -251,13 +249,17 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
	FcPattern *fcpattern;
 | 
						FcPattern *fcpattern;
 | 
				
			||||||
	FcPattern *match;
 | 
						FcPattern *match;
 | 
				
			||||||
	XftResult result;
 | 
						XftResult result;
 | 
				
			||||||
	int charexists = 0;
 | 
						int charexists = 0, overflow = 0;
 | 
				
			||||||
 | 
						/* keep track of a couple codepoints for which we have no match. */
 | 
				
			||||||
 | 
						enum { nomatches_len = 64 };
 | 
				
			||||||
 | 
						static struct { long codepoint[nomatches_len]; unsigned int idx; } nomatches;
 | 
				
			||||||
 | 
						static unsigned int ellipsis_width = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!drw || (render && !drw->scheme) || !text || !drw->fonts)
 | 
						if (!drw || (render && (!drw->scheme || !w)) || !text || !drw->fonts)
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!render) {
 | 
						if (!render) {
 | 
				
			||||||
		w = ~w;
 | 
							w = invert ? invert : ~invert;
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		XSetForeground(drw->dpy, drw->gc, drw->scheme[invert ? ColFg : ColBg].pixel);
 | 
							XSetForeground(drw->dpy, drw->gc, drw->scheme[invert ? ColFg : ColBg].pixel);
 | 
				
			||||||
		XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
							XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
 | 
				
			||||||
| 
						 | 
					@ -269,8 +271,10 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	usedfont = drw->fonts;
 | 
						usedfont = drw->fonts;
 | 
				
			||||||
 | 
						if (!ellipsis_width && render)
 | 
				
			||||||
 | 
							ellipsis_width = drw_fontset_getwidth(drw, "...");
 | 
				
			||||||
	while (1) {
 | 
						while (1) {
 | 
				
			||||||
		utf8strlen = 0;
 | 
							ew = ellipsis_len = utf8strlen = 0;
 | 
				
			||||||
		utf8str = text;
 | 
							utf8str = text;
 | 
				
			||||||
		nextfont = NULL;
 | 
							nextfont = NULL;
 | 
				
			||||||
		while (*text) {
 | 
							while (*text) {
 | 
				
			||||||
| 
						 | 
					@ -278,9 +282,27 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
			for (curfont = drw->fonts; curfont; curfont = curfont->next) {
 | 
								for (curfont = drw->fonts; curfont; curfont = curfont->next) {
 | 
				
			||||||
				charexists = charexists || XftCharExists(drw->dpy, curfont->xfont, utf8codepoint);
 | 
									charexists = charexists || XftCharExists(drw->dpy, curfont->xfont, utf8codepoint);
 | 
				
			||||||
				if (charexists) {
 | 
									if (charexists) {
 | 
				
			||||||
					if (curfont == usedfont) {
 | 
										drw_font_getexts(curfont, text, utf8charlen, &tmpw, NULL);
 | 
				
			||||||
 | 
										if (ew + ellipsis_width <= w) {
 | 
				
			||||||
 | 
											/* keep track where the ellipsis still fits */
 | 
				
			||||||
 | 
											ellipsis_x = x + ew;
 | 
				
			||||||
 | 
											ellipsis_w = w - ew;
 | 
				
			||||||
 | 
											ellipsis_len = utf8strlen;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										if (ew + tmpw > w) {
 | 
				
			||||||
 | 
											overflow = 1;
 | 
				
			||||||
 | 
											/* called from drw_fontset_getwidth_clamp():
 | 
				
			||||||
 | 
											 * it wants the width AFTER the overflow
 | 
				
			||||||
 | 
											 */
 | 
				
			||||||
 | 
											if (!render)
 | 
				
			||||||
 | 
												x += tmpw;
 | 
				
			||||||
 | 
											else
 | 
				
			||||||
 | 
												utf8strlen = ellipsis_len;
 | 
				
			||||||
 | 
										} else if (curfont == usedfont) {
 | 
				
			||||||
						utf8strlen += utf8charlen;
 | 
											utf8strlen += utf8charlen;
 | 
				
			||||||
						text += utf8charlen;
 | 
											text += utf8charlen;
 | 
				
			||||||
 | 
											ew += tmpw;
 | 
				
			||||||
					} else {
 | 
										} else {
 | 
				
			||||||
						nextfont = curfont;
 | 
											nextfont = curfont;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
| 
						 | 
					@ -288,36 +310,25 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!charexists || nextfont)
 | 
								if (overflow || !charexists || nextfont)
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				charexists = 0;
 | 
									charexists = 0;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (utf8strlen) {
 | 
							if (utf8strlen) {
 | 
				
			||||||
			drw_font_getexts(usedfont, utf8str, utf8strlen, &ew, NULL);
 | 
								if (render) {
 | 
				
			||||||
			/* shorten text if necessary */
 | 
									ty = y + (h - usedfont->h) / 2 + usedfont->xfont->ascent;
 | 
				
			||||||
			for (len = MIN(utf8strlen, sizeof(buf) - 1); len && ew > w; len--)
 | 
									XftDrawStringUtf8(d, &drw->scheme[invert ? ColBg : ColFg],
 | 
				
			||||||
				drw_font_getexts(usedfont, utf8str, len, &ew, NULL);
 | 
									                  usedfont->xfont, x, ty, (XftChar8 *)utf8str, utf8strlen);
 | 
				
			||||||
 | 
					 | 
				
			||||||
			if (len) {
 | 
					 | 
				
			||||||
				memcpy(buf, utf8str, len);
 | 
					 | 
				
			||||||
				buf[len] = '\0';
 | 
					 | 
				
			||||||
				if (len < utf8strlen)
 | 
					 | 
				
			||||||
					for (i = len; i && i > len - 3; buf[--i] = '.')
 | 
					 | 
				
			||||||
						; /* NOP */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				if (render) {
 | 
					 | 
				
			||||||
					ty = y + (h - usedfont->h) / 2 + usedfont->xfont->ascent;
 | 
					 | 
				
			||||||
					XftDrawStringUtf8(d, &drw->scheme[invert ? ColBg : ColFg],
 | 
					 | 
				
			||||||
					                  usedfont->xfont, x, ty, (XftChar8 *)buf, len);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
				x += ew;
 | 
					 | 
				
			||||||
				w -= ew;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
								x += ew;
 | 
				
			||||||
 | 
								w -= ew;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
							if (render && overflow)
 | 
				
			||||||
 | 
								drw_text(drw, ellipsis_x, y, ellipsis_w, h, 0, "...", invert);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!*text) {
 | 
							if (!*text || overflow) {
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		} else if (nextfont) {
 | 
							} else if (nextfont) {
 | 
				
			||||||
			charexists = 0;
 | 
								charexists = 0;
 | 
				
			||||||
| 
						 | 
					@ -327,6 +338,12 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
			 * character must be drawn. */
 | 
								 * character must be drawn. */
 | 
				
			||||||
			charexists = 1;
 | 
								charexists = 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								for (i = 0; i < nomatches_len; ++i) {
 | 
				
			||||||
 | 
									/* avoid calling XftFontMatch if we know we won't find a match */
 | 
				
			||||||
 | 
									if (utf8codepoint == nomatches.codepoint[i])
 | 
				
			||||||
 | 
										goto no_match;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			fccharset = FcCharSetCreate();
 | 
								fccharset = FcCharSetCreate();
 | 
				
			||||||
			FcCharSetAddChar(fccharset, utf8codepoint);
 | 
								FcCharSetAddChar(fccharset, utf8codepoint);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -355,6 +372,8 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
				
			||||||
					curfont->next = usedfont;
 | 
										curfont->next = usedfont;
 | 
				
			||||||
				} else {
 | 
									} else {
 | 
				
			||||||
					xfont_free(usedfont);
 | 
										xfont_free(usedfont);
 | 
				
			||||||
 | 
										nomatches.codepoint[++nomatches.idx % nomatches_len] = utf8codepoint;
 | 
				
			||||||
 | 
					no_match:
 | 
				
			||||||
					usedfont = drw->fonts;
 | 
										usedfont = drw->fonts;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
| 
						 | 
					@ -384,6 +403,15 @@ drw_fontset_getwidth(Drw *drw, const char *text)
 | 
				
			||||||
	return drw_text(drw, 0, 0, 0, 0, 0, text, 0);
 | 
						return drw_text(drw, 0, 0, 0, 0, 0, text, 0);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					unsigned int
 | 
				
			||||||
 | 
					drw_fontset_getwidth_clamp(Drw *drw, const char *text, unsigned int n)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned int tmp = 0;
 | 
				
			||||||
 | 
						if (drw && drw->fonts && text && n)
 | 
				
			||||||
 | 
							tmp = drw_text(drw, 0, 0, 0, 0, 0, text, n);
 | 
				
			||||||
 | 
						return MIN(n, tmp);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h)
 | 
					drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								drw.h
									
										
									
									
									
								
							
							
						
						
									
										1
									
								
								drw.h
									
										
									
									
									
								
							| 
						 | 
					@ -35,6 +35,7 @@ void drw_free(Drw *drw);
 | 
				
			||||||
Fnt *drw_fontset_create(Drw* drw, const char *fonts[], size_t fontcount);
 | 
					Fnt *drw_fontset_create(Drw* drw, const char *fonts[], size_t fontcount);
 | 
				
			||||||
void drw_fontset_free(Fnt* set);
 | 
					void drw_fontset_free(Fnt* set);
 | 
				
			||||||
unsigned int drw_fontset_getwidth(Drw *drw, const char *text);
 | 
					unsigned int drw_fontset_getwidth(Drw *drw, const char *text);
 | 
				
			||||||
 | 
					unsigned int drw_fontset_getwidth_clamp(Drw *drw, const char *text, unsigned int n);
 | 
				
			||||||
void drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h);
 | 
					void drw_font_getexts(Fnt *font, const char *text, unsigned int len, unsigned int *w, unsigned int *h);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Colorscheme abstraction */
 | 
					/* Colorscheme abstraction */
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										3
									
								
								dwm.c
									
										
									
									
									
								
							
							
						
						
									
										3
									
								
								dwm.c
									
										
									
									
									
								
							| 
						 | 
					@ -1274,13 +1274,14 @@ manage(Window w, XWindowAttributes *wa)
 | 
				
			||||||
	XSetWindowBorder(dpy, w, scheme[SchemeNorm][ColBorder].pixel);
 | 
						XSetWindowBorder(dpy, w, scheme[SchemeNorm][ColBorder].pixel);
 | 
				
			||||||
	configure(c); /* propagates border_width, if size doesn't change */
 | 
						configure(c); /* propagates border_width, if size doesn't change */
 | 
				
			||||||
	updatewindowtype(c);
 | 
						updatewindowtype(c);
 | 
				
			||||||
 | 
						updatesizehints(c);
 | 
				
			||||||
	updatewmhints(c);
 | 
						updatewmhints(c);
 | 
				
			||||||
	c->x = c->mon->mx + (c->mon->mw - WIDTH(c)) / 2;
 | 
						c->x = c->mon->mx + (c->mon->mw - WIDTH(c)) / 2;
 | 
				
			||||||
	c->y = c->mon->my + (c->mon->mh - HEIGHT(c)) / 2;
 | 
						c->y = c->mon->my + (c->mon->mh - HEIGHT(c)) / 2;
 | 
				
			||||||
	XSelectInput(dpy, w, EnterWindowMask|FocusChangeMask|PropertyChangeMask|StructureNotifyMask);
 | 
						XSelectInput(dpy, w, EnterWindowMask|FocusChangeMask|PropertyChangeMask|StructureNotifyMask);
 | 
				
			||||||
	grabbuttons(c, 0);
 | 
						grabbuttons(c, 0);
 | 
				
			||||||
	if (!c->isfloating)
 | 
						if (!c->isfloating)
 | 
				
			||||||
		c->isfloating = c->oldstate = t || c->isfixed;
 | 
							c->isfloating = c->oldstate = trans != None || c->isfixed;
 | 
				
			||||||
	if (c->isfloating)
 | 
						if (c->isfloating)
 | 
				
			||||||
		XRaiseWindow(dpy, c->win);
 | 
							XRaiseWindow(dpy, c->win);
 | 
				
			||||||
	attach(c);
 | 
						attach(c);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue