=================================================================== RCS file: /cvs/mandoc/term.h,v retrieving revision 1.23 retrieving revision 1.26 diff -u -p -r1.23 -r1.26 --- mandoc/term.h 2009/03/15 07:08:53 1.23 +++ mandoc/term.h 2009/03/17 13:35:46 1.26 @@ -1,4 +1,4 @@ -/* $Id: term.h,v 1.23 2009/03/15 07:08:53 kristaps Exp $ */ +/* $Id: term.h,v 1.26 2009/03/17 13:35:46 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -21,65 +21,12 @@ #include "mdoc.h" +/* XXX - clean up tabs. */ + #define INDENT 6 __BEGIN_DECLS -enum tsym { - TERMSYM_RBRACK = 0, - TERMSYM_LBRACK = 1, - TERMSYM_LARROW = 2, - TERMSYM_RARROW = 3, - TERMSYM_UARROW = 4, - TERMSYM_DARROW = 5, - TERMSYM_LSQUOTE = 6, - TERMSYM_RSQUOTE = 7, - TERMSYM_SQUOTE = 8, - TERMSYM_LDQUOTE = 9, - TERMSYM_RDQUOTE = 10, - TERMSYM_DQUOTE = 11, - TERMSYM_LT = 12, - TERMSYM_GT = 13, - TERMSYM_LE = 14, - TERMSYM_GE = 15, - TERMSYM_EQ = 16, - TERMSYM_NEQ = 17, - TERMSYM_ACUTE = 18, - TERMSYM_GRAVE = 19, - TERMSYM_PI = 20, - TERMSYM_PLUSMINUS = 21, - TERMSYM_INF = 22, - TERMSYM_INF2 = 23, - TERMSYM_NAN = 24, - TERMSYM_BAR = 25, - TERMSYM_BULLET = 26, - TERMSYM_AMP = 27, - TERMSYM_EM = 28, - TERMSYM_EN = 29, - TERMSYM_COPY = 30, - TERMSYM_ASTERISK = 31, - TERMSYM_SLASH = 32, - TERMSYM_HYPHEN = 33, - TERMSYM_SPACE = 34, - TERMSYM_PERIOD = 35, - TERMSYM_BREAK = 36, - TERMSYM_LANGLE = 37, - TERMSYM_RANGLE = 38, - TERMSYM_LBRACE = 39, - TERMSYM_RBRACE = 40, - TERMSYM_MAX = 41 -}; - -enum termenc { - TERMENC_ANSI, - TERMENC_NROFF -}; - -struct termsym { - const char *sym; - size_t sz; -}; - struct termp { size_t rmargin; size_t maxrmargin; @@ -96,20 +43,15 @@ struct termp { #define TERMP_IGNDELIM (1 << 4) /* Delims like regulars. */ #define TERMP_NONOSPACE (1 << 5) /* No space (no autounset). */ #define TERMP_NONOBREAK (1 << 7) /* Don't newln NOBREAK. */ -#define TERMP_STYLE 0xff00 /* Style mask. */ +#define TERMP_STYLE 0x0300 /* Style mask. */ #define TERMP_BOLD (1 << 8) /* Styles... */ #define TERMP_UNDER (1 << 9) -#define TERMP_BLUE (1 << 10) -#define TERMP_RED (1 << 11) -#define TERMP_YELLOW (1 << 12) -#define TERMP_MAGENTA (1 << 13) -#define TERMP_CYAN (1 << 14) -#define TERMP_GREEN (1 << 15) char *buf; - struct termsym *symtab; /* Special-symbol table. */ - enum termenc enc; /* Encoding. */ + void *symtab; }; +/* XXX - clean this up. */ + struct termpair { struct termpair *ppair; int type; @@ -129,26 +71,25 @@ struct termpair { } 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 *); + 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 *); }; -void newln(struct termp *); -void vspace(struct termp *); -void word(struct termp *, const char *); -void flushln(struct termp *); -void transcode(struct termp *, - const char *, size_t); -void subtree(struct termp *, - const struct mdoc_meta *, - const struct mdoc_node *); +void *ascii2htab(void); +const char *a2ascii(void *, const char *, size_t, size_t *); +void asciifree(void *); +void newln(struct termp *); +void vspace(struct termp *); +void word(struct termp *, const char *); +void flushln(struct termp *); +void transcode(struct termp *, const char *, size_t); +void subtree(struct termp *, const struct mdoc_meta *, + const struct mdoc_node *); const struct termact *termacts;