1*99db7d0eSSascha Wildner /* $OpenBSD: roff_int.h,v 1.16 2019/01/05 00:36:46 schwarze Exp $ */ 254ba9607SSascha Wildner /* 3*99db7d0eSSascha Wildner * Copyright (c) 2013-2015, 2017-2020 Ingo Schwarze <schwarze@openbsd.org> 454ba9607SSascha Wildner * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv> 554ba9607SSascha Wildner * 654ba9607SSascha Wildner * Permission to use, copy, modify, and distribute this software for any 754ba9607SSascha Wildner * purpose with or without fee is hereby granted, provided that the above 854ba9607SSascha Wildner * copyright notice and this permission notice appear in all copies. 954ba9607SSascha Wildner * 1054ba9607SSascha Wildner * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHORS DISCLAIM ALL WARRANTIES 1154ba9607SSascha Wildner * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 1254ba9607SSascha Wildner * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR 1354ba9607SSascha Wildner * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 1454ba9607SSascha Wildner * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 1554ba9607SSascha Wildner * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 1654ba9607SSascha Wildner * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 1754ba9607SSascha Wildner * 1854ba9607SSascha Wildner * Parser internals shared by multiple parsers. 1954ba9607SSascha Wildner */ 2054ba9607SSascha Wildner 2154ba9607SSascha Wildner struct ohash; 2254ba9607SSascha Wildner struct roff_node; 2354ba9607SSascha Wildner struct roff_meta; 2454ba9607SSascha Wildner struct roff; 2554ba9607SSascha Wildner struct mdoc_arg; 2654ba9607SSascha Wildner 2754ba9607SSascha Wildner enum roff_next { 2854ba9607SSascha Wildner ROFF_NEXT_SIBLING = 0, 2954ba9607SSascha Wildner ROFF_NEXT_CHILD 3054ba9607SSascha Wildner }; 3154ba9607SSascha Wildner 3254ba9607SSascha Wildner struct roff_man { 3354ba9607SSascha Wildner struct roff_meta meta; /* Public parse results. */ 3454ba9607SSascha Wildner struct roff *roff; /* Roff parser state data. */ 3554ba9607SSascha Wildner struct ohash *mdocmac; /* Mdoc macro lookup table. */ 3654ba9607SSascha Wildner struct ohash *manmac; /* Man macro lookup table. */ 3754ba9607SSascha Wildner const char *os_s; /* Default operating system. */ 3854ba9607SSascha Wildner struct roff_node *last; /* The last node parsed. */ 3954ba9607SSascha Wildner struct roff_node *last_es; /* The most recent Es node. */ 4054ba9607SSascha Wildner int quick; /* Abort parse early. */ 4154ba9607SSascha Wildner int flags; /* Parse flags. */ 4254ba9607SSascha Wildner #define ROFF_NOFILL (1 << 1) /* Fill mode switched off. */ 4354ba9607SSascha Wildner #define MDOC_PBODY (1 << 2) /* In the document body. */ 4454ba9607SSascha Wildner #define MDOC_NEWLINE (1 << 3) /* First macro/text in a line. */ 4554ba9607SSascha Wildner #define MDOC_PHRASE (1 << 4) /* In a Bl -column phrase. */ 4654ba9607SSascha Wildner #define MDOC_PHRASELIT (1 << 5) /* Literal within a phrase. */ 4754ba9607SSascha Wildner #define MDOC_FREECOL (1 << 6) /* `It' invocation should close. */ 4854ba9607SSascha Wildner #define MDOC_SYNOPSIS (1 << 7) /* SYNOPSIS-style formatting. */ 4954ba9607SSascha Wildner #define MDOC_KEEP (1 << 8) /* In a word keep. */ 5054ba9607SSascha Wildner #define MDOC_SMOFF (1 << 9) /* Spacing is off. */ 5154ba9607SSascha Wildner #define MDOC_NODELIMC (1 << 10) /* Disable closing delimiter handling. */ 5254ba9607SSascha Wildner #define MAN_ELINE (1 << 11) /* Next-line element scope. */ 5354ba9607SSascha Wildner #define MAN_BLINE (1 << 12) /* Next-line block scope. */ 5454ba9607SSascha Wildner #define MDOC_PHRASEQF (1 << 13) /* Quote first word encountered. */ 5554ba9607SSascha Wildner #define MDOC_PHRASEQL (1 << 14) /* Quote last word of this phrase. */ 5654ba9607SSascha Wildner #define MDOC_PHRASEQN (1 << 15) /* Quote first word of the next phrase. */ 5754ba9607SSascha Wildner #define ROFF_NONOFILL (1 << 16) /* Temporarily suspend no-fill mode. */ 5854ba9607SSascha Wildner #define MAN_NEWLINE MDOC_NEWLINE 5954ba9607SSascha Wildner enum roff_sec lastsec; /* Last section seen. */ 6054ba9607SSascha Wildner enum roff_sec lastnamed; /* Last standard section seen. */ 6154ba9607SSascha Wildner enum roff_next next; /* Where to put the next node. */ 62*99db7d0eSSascha Wildner char filesec; /* Section digit in the file name. */ 6354ba9607SSascha Wildner }; 6454ba9607SSascha Wildner 6554ba9607SSascha Wildner 6654ba9607SSascha Wildner struct roff_node *roff_node_alloc(struct roff_man *, int, int, 6754ba9607SSascha Wildner enum roff_type, int); 6854ba9607SSascha Wildner void roff_node_append(struct roff_man *, struct roff_node *); 6954ba9607SSascha Wildner void roff_word_alloc(struct roff_man *, int, int, const char *); 7054ba9607SSascha Wildner void roff_word_append(struct roff_man *, const char *); 7154ba9607SSascha Wildner void roff_elem_alloc(struct roff_man *, int, int, int); 7254ba9607SSascha Wildner struct roff_node *roff_block_alloc(struct roff_man *, int, int, int); 7354ba9607SSascha Wildner struct roff_node *roff_head_alloc(struct roff_man *, int, int, int); 7454ba9607SSascha Wildner struct roff_node *roff_body_alloc(struct roff_man *, int, int, int); 7554ba9607SSascha Wildner void roff_node_unlink(struct roff_man *, struct roff_node *); 7654ba9607SSascha Wildner void roff_node_relink(struct roff_man *, struct roff_node *); 7754ba9607SSascha Wildner void roff_node_free(struct roff_node *); 7854ba9607SSascha Wildner void roff_node_delete(struct roff_man *, struct roff_node *); 7954ba9607SSascha Wildner 8054ba9607SSascha Wildner struct ohash *roffhash_alloc(enum roff_tok, enum roff_tok); 8154ba9607SSascha Wildner enum roff_tok roffhash_find(struct ohash *, const char *, size_t); 8254ba9607SSascha Wildner void roffhash_free(struct ohash *); 8354ba9607SSascha Wildner 8454ba9607SSascha Wildner void roff_state_reset(struct roff_man *); 8554ba9607SSascha Wildner void roff_validate(struct roff_man *); 8654ba9607SSascha Wildner 8754ba9607SSascha Wildner /* 8854ba9607SSascha Wildner * Functions called from roff.c need to be declared here, 8954ba9607SSascha Wildner * not in libmdoc.h or libman.h, even if they are specific 9054ba9607SSascha Wildner * to either the mdoc(7) or the man(7) parser. 9154ba9607SSascha Wildner */ 9254ba9607SSascha Wildner 9354ba9607SSascha Wildner void man_breakscope(struct roff_man *, int); 9454ba9607SSascha Wildner void mdoc_argv_free(struct mdoc_arg *); 95