]> git.cameronkatri.com Git - mandoc.git/blobdiff - term.h
White-space churn.
[mandoc.git] / term.h
diff --git a/term.h b/term.h
index 444423ed39bd271c4d1eb882366ef40b333b871a..22fddd18d3407dd5249e21d9f08f44bc2e232649 100644 (file)
--- a/term.h
+++ b/term.h
@@ -1,4 +1,4 @@
-/* $Id: term.h,v 1.5 2009/02/24 16:16:45 kristaps Exp $ */
+/* $Id: term.h,v 1.11 2009/02/25 23:18:50 kristaps Exp $ */
 /*
  * Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
  *
@@ -37,14 +37,35 @@ struct      termp {
 #define        TERMP_NOBREAK    (1 << 4)       /* No break after flush. */
 #define        TERMP_LITERAL    (1 << 5)       /* Literal words. */
 #define        TERMP_IGNDELIM   (1 << 6)       /* Delims like regulars. */
+#define        TERMP_NONOSPACE  (1 << 7)       /* No space (no autounset). */
+#define        TERMP_NORPAD     (1 << 8)       /* No rightpad. */
        char             *buf;
 };
 
+struct termpair {
+       struct termpair  *ppair;
+       int               type;
+#define        TERMPAIR_FLAG    (1 << 0)
+       int               flag;
+       size_t            offset;
+       size_t            rmargin;
+       int               count;
+};
+
+#define        TERMPAIR_SETFLAG(p, fl) \
+       do { \
+               assert(! (TERMPAIR_FLAG & (p)->type)); \
+               (p)->flag = (fl); \
+               (p)->type |= TERMPAIR_FLAG; \
+       } while (0)
+
 struct termact {
        int             (*pre)(struct termp *,
+                               struct termpair *,
                                const struct mdoc_meta *,
                                const struct mdoc_node *);
        void            (*post)(struct termp *,
+                               struct termpair *,
                                const struct mdoc_meta *,
                                const struct mdoc_node *);
 };