shithub: neatroff

Download patch

ref: 5bbd5fb88a804ccbf9d642d5f68be4acd74e9eaa
parent: 781e4139f4c6ff4606c131fbc9649108862041b2
author: Ali Gholami Rudi <ali@rudi.ir>
date: Tue Aug 5 13:07:45 EDT 2014

font: allocate rule->pats from the heap

--- a/font.c
+++ b/font.c
@@ -47,8 +47,6 @@
 	int feat_set[NFEATS];		/* feature enabled */
 	int feat_n;
 	/* glyph substitution and positioning */
-	struct gpat pats[NGPATS];	/* glyph pattern space */
-	int pats_pos;			/* current position in pats[] */
 	struct grule gsub[NGRULES];	/* glyph substitution rules */
 	int gsub_n;
 	struct grule gpos[NGRULES];	/* glyph positioning rules */
@@ -316,14 +314,9 @@
 
 static struct gpat *font_gpat(struct font *fn, int len)
 {
-	int pos = fn->pats_pos;
-	if (pos < LEN(fn->pats) - 10 && pos + len > LEN(fn->pats) - 10)
-		errmsg("neatroff: NGPATS too low\n");
-	if (pos + len > LEN(fn->pats))
-		return NULL;
-	memset(fn->pats + pos, 0, sizeof(fn->pats[0]) * len);
-	fn->pats_pos += len;
-	return fn->pats + pos;
+	struct gpat *pats = xmalloc(len * sizeof(pats[0]));
+	memset(pats, 0, len * sizeof(pats[0]));
+	return pats;
 }
 
 static struct grule *font_gsub(struct font *fn, char *feat, int len)
@@ -529,6 +522,11 @@
 
 void font_close(struct font *fn)
 {
+	int i;
+	for (i = 0; i < fn->gsub_n; i++)
+		free(fn->gsub[i].pats);
+	for (i = 0; i < fn->gpos_n; i++)
+		free(fn->gpos[i].pats);
 	dict_done(&fn->gdict);
 	dict_done(&fn->cdict);
 	free(fn);
--- a/roff.h
+++ b/roff.h
@@ -50,8 +50,7 @@
 #define NHCODES		512	/* number of .hcode characters */
 #define WORDLEN		256	/* word length (for hyph.c) */
 #define NFEATS		128	/* number of features per font */
-#define NGRULES		1024	/* number of gsub/gpos rules per font */
-#define NGPATS		4096	/* number of gsub/gpos pattern glyphs */
+#define NGRULES		4096	/* number of gsub/gpos rules per font */
 
 /* converting scales */
 #define SC_IN		(dev_res)	/* inch in units */