]> git.cameronkatri.com Git - mandoc.git/blobdiff - term.h
enclosures sometimes cause bogus end-of-sentence
[mandoc.git] / term.h
diff --git a/term.h b/term.h
index a706ab611350e411ac05598d5d46ec3a6333f03e..dc28d33e9ef42ac550ac989c6ef7be1547566d3c 100644 (file)
--- a/term.h
+++ b/term.h
@@ -1,6 +1,6 @@
-/*     $Id: term.h,v 1.72 2010/06/30 13:00:00 kristaps Exp $ */
+/*     $Id: term.h,v 1.76 2010/07/25 22:15:07 kristaps Exp $ */
 /*
- * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@bsd.lv>
+ * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
@@ -27,7 +27,8 @@ enum  termenc {
 
 enum   termtype {
        TERMTYPE_CHAR,
-       TERMTYPE_PS
+       TERMTYPE_PS,
+       TERMTYPE_PDF
 };
 
 enum   termfont {
@@ -42,9 +43,10 @@ enum termfont {
 typedef void   (*term_margin)(struct termp *, const void *);
 
 struct termp_ps {
-       int               psstate;      /* state of ps output */
+       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 */
@@ -62,6 +64,11 @@ struct       termp_ps {
        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 {