shithub: neatroff

Download patch

ref: 399a4936bad90998d119f25431889b25a3b03f5f
parent: 78c8c41519032385bda232d10bf1043600de98ed
author: Ali Gholami Rudi <ali@rudi.ir>
date: Mon Feb 17 11:58:50 EST 2014

wb: zero-width break point (\:)

--- a/out.c
+++ b/out.c
@@ -152,7 +152,8 @@
 				c[0] = c[1];
 				c[1] = '\0';
 			}
-			if (c[0] == '\t' || c[0] == '' || !strcmp(c_hc, c))
+			if (c[0] == '\t' || c[0] == '' ||
+					!strcmp(c_hc, c) || !strcmp(c_bp, c))
 				continue;
 			outc(cmap_map(c));
 			continue;
--- a/roff.h
+++ b/roff.h
@@ -71,6 +71,7 @@
 #define c_mc	env_mc()/* margin character (.mc) */
 #define c_tc	env_tc()
 #define c_lc	env_lc()
+#define c_bp	"\\:"	/* zero-width word break point */
 
 /* number registers */
 int num_get(int id, int inc);
--- a/wb.c
+++ b/wb.c
@@ -157,7 +157,7 @@
 		else
 			sbuf_printf(&wb->sbuf, "%cC'%s'", c_ec, c);
 	}
-	if (strcmp(c_hc, c)) {
+	if (strcmp(c_hc, c) && strcmp(c_bp, c)) {
 		wb_prevput(wb, c, ll);
 		wb->h += charwid(R_F(wb), R_S(wb), g ? g->wid : SC_DW);
 		wb->ct |= g ? g->type : 0;
@@ -366,7 +366,8 @@
 	return 0;
 }
 
-static char *dashpos(char *s, int w, struct wb *w1, int flg)
+/* the position marked with hyphens or \: */
+static char *bp_pos(char *s, int w, struct wb *w1, int flg)
 {
 	char d[ILNLEN];
 	char *r = NULL;
@@ -376,7 +377,8 @@
 		wb_putc(w1, c, d);
 		if (wb_wid(w1) > w && (!(flg & HY_ANY) || r))
 			continue;
-		if (!c && (!strcmp("-", d) || (!strcmp("em", d) || !strcmp("hy", d))))
+		if (!c && (!strcmp("-", d) || (!strcmp("em", d) ||
+					!strcmp("hy", d)) || !strcmp(c_bp, d)))
 			r = s;
 	}
 	return r;
@@ -388,7 +390,8 @@
 	return charwid(R_F(wb), R_S(wb), g ? g->wid : SC_DW);
 }
 
-static char *indicatorpos(char *s, int w, struct wb *w1, int flg)
+/* the position marked with \% */
+static char *hc_pos(char *s, int w, struct wb *w1, int flg)
 {
 	char d[ILNLEN];
 	char *r = NULL;
@@ -466,8 +469,8 @@
 	char *dp, *hp, *p;
 	if (skipreqs(&s, w1))
 		return 1;
-	dp = dashpos(sbuf_buf(&wb->sbuf), w, w1, flg);
-	hp = indicatorpos(sbuf_buf(&wb->sbuf), w, w1, flg);
+	dp = bp_pos(sbuf_buf(&wb->sbuf), w, w1, flg);
+	hp = hc_pos(sbuf_buf(&wb->sbuf), w, w1, flg);
 	if (hp && dp)
 		p = flg & HY_ANY ? MIN(dp, hp) : MAX(dp, hp);
 	else