summaryrefslogtreecommitdiffstats
path: root/term.h
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2011-05-15 00:58:48 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2011-05-15 00:58:48 +0000
commit5163e512d087eaac01dd7f4eea9a4f376a52af49 (patch)
tree77cb53c343827d79d82b3523b2be394e803a0c2f /term.h
parentb9fae52570dbdf98723ee107cf23726cbf5e3449 (diff)
downloadmandoc-5163e512d087eaac01dd7f4eea9a4f376a52af49.tar.gz
Move struct termp_ps into term_ps.c; remove the engine union in struct termp,
which only held one entry; finally (as per the first), make "ps" member into a pointer managed by term_ps.c. This frees up a nice chunk of memory during run-time and in the binary.
Diffstat (limited to 'term.h')
-rw-r--r--term.h33
1 files changed, 1 insertions, 32 deletions
diff --git a/term.h b/term.h
index c98b1bfe..5bdcd3ba 100644
--- a/term.h
+++ b/term.h
@@ -42,35 +42,6 @@ enum termfont {
typedef void (*term_margin)(struct termp *, const void *);
-struct termp_ps {
- int flags;
-#define PS_INLINE (1 << 0) /* we're in a word */
-#define PS_MARGINS (1 << 1) /* we're in the margins */
-#define PS_NEWPAGE (1 << 2) /* new page, no words yet */
- size_t pscol; /* visible column (AFM units) */
- size_t psrow; /* visible row (AFM units) */
- char *psmarg; /* margin buf */
- size_t psmargsz; /* margin buf size */
- size_t psmargcur; /* cur index in margin buf */
- char last; /* character buffer */
- enum termfont lastf; /* last set font */
- size_t scale; /* font scaling factor */
- size_t pages; /* number of pages shown */
- size_t lineheight; /* line height (AFM units) */
- size_t top; /* body top (AFM units) */
- size_t bottom; /* body bottom (AFM units) */
- size_t height; /* page height (AFM units */
- size_t width; /* page width (AFM units) */
- size_t left; /* body left (AFM units) */
- size_t header; /* header pos (AFM units) */
- size_t footer; /* footer pos (AFM units) */
- size_t pdfbytes; /* current output byte */
- size_t pdflastpg; /* byte of last page mark */
- size_t pdfbody; /* start of body object */
- size_t *pdfobjs; /* table of object offsets */
- size_t pdfobjsz; /* size of pdfobjs */
-};
-
struct termp_tbl {
int width; /* width in fixed chars */
int decimal; /* decimal point position */
@@ -120,9 +91,7 @@ struct termp {
double (*hspan)(const struct termp *,
const struct roffsu *);
const void *argf; /* arg for headf/footf */
- union {
- struct termp_ps ps;
- } engine;
+ struct termp_ps *ps;
};
struct termp *term_alloc(enum termenc);