346 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			346 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*	$Id: mdoc.h,v 1.90 2010/06/19 20:46:28 kristaps Exp $ */
 | |
| /*
 | |
|  * Copyright (c) 2008, 2009 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
 | |
|  * copyright notice and this permission notice appear in all copies.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 | |
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 | |
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 | |
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 | |
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 | |
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 | |
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | |
|  */
 | |
| #ifndef MDOC_H
 | |
| #define MDOC_H
 | |
| 
 | |
| /*
 | |
|  * This library implements a validating scanner/parser for ``mdoc'' roff
 | |
|  * macro documents, a.k.a. BSD manual page documents.  The mdoc.c file
 | |
|  * drives the parser, while macro.c describes the macro ontologies.
 | |
|  * validate.c pre- and post-validates parsed macros, and action.c
 | |
|  * performs actions on parsed and validated macros.
 | |
|  */
 | |
| 
 | |
| /* What follows is a list of ALL possible macros. */
 | |
| 
 | |
| enum	mdoct {
 | |
| 	MDOC_Ap = 0,
 | |
| 	MDOC_Dd,
 | |
| 	MDOC_Dt,
 | |
| 	MDOC_Os,
 | |
| 	MDOC_Sh,
 | |
| 	MDOC_Ss,
 | |
| 	MDOC_Pp,
 | |
| 	MDOC_D1,
 | |
| 	MDOC_Dl,
 | |
| 	MDOC_Bd,
 | |
| 	MDOC_Ed,
 | |
| 	MDOC_Bl,
 | |
| 	MDOC_El,
 | |
| 	MDOC_It,
 | |
| 	MDOC_Ad,
 | |
| 	MDOC_An,
 | |
| 	MDOC_Ar,
 | |
| 	MDOC_Cd,
 | |
| 	MDOC_Cm,
 | |
| 	MDOC_Dv,
 | |
| 	MDOC_Er,
 | |
| 	MDOC_Ev,
 | |
| 	MDOC_Ex,
 | |
| 	MDOC_Fa,
 | |
| 	MDOC_Fd,
 | |
| 	MDOC_Fl,
 | |
| 	MDOC_Fn,
 | |
| 	MDOC_Ft,
 | |
| 	MDOC_Ic,
 | |
| 	MDOC_In,
 | |
| 	MDOC_Li,
 | |
| 	MDOC_Nd,
 | |
| 	MDOC_Nm,
 | |
| 	MDOC_Op,
 | |
| 	MDOC_Ot,
 | |
| 	MDOC_Pa,
 | |
| 	MDOC_Rv,
 | |
| 	MDOC_St,
 | |
| 	MDOC_Va,
 | |
| 	MDOC_Vt,
 | |
| 	MDOC_Xr,
 | |
| 	MDOC__A,
 | |
| 	MDOC__B,
 | |
| 	MDOC__D,
 | |
| 	MDOC__I,
 | |
| 	MDOC__J,
 | |
| 	MDOC__N,
 | |
| 	MDOC__O,
 | |
| 	MDOC__P,
 | |
| 	MDOC__R,
 | |
| 	MDOC__T,
 | |
| 	MDOC__V,
 | |
| 	MDOC_Ac,
 | |
| 	MDOC_Ao,
 | |
| 	MDOC_Aq,
 | |
| 	MDOC_At,
 | |
| 	MDOC_Bc,
 | |
| 	MDOC_Bf,
 | |
| 	MDOC_Bo,
 | |
| 	MDOC_Bq,
 | |
| 	MDOC_Bsx,
 | |
| 	MDOC_Bx,
 | |
| 	MDOC_Db,
 | |
| 	MDOC_Dc,
 | |
| 	MDOC_Do,
 | |
| 	MDOC_Dq,
 | |
| 	MDOC_Ec,
 | |
| 	MDOC_Ef,
 | |
| 	MDOC_Em,
 | |
| 	MDOC_Eo,
 | |
| 	MDOC_Fx,
 | |
| 	MDOC_Ms,
 | |
| 	MDOC_No,
 | |
| 	MDOC_Ns,
 | |
| 	MDOC_Nx,
 | |
| 	MDOC_Ox,
 | |
| 	MDOC_Pc,
 | |
| 	MDOC_Pf,
 | |
| 	MDOC_Po,
 | |
| 	MDOC_Pq,
 | |
| 	MDOC_Qc,
 | |
| 	MDOC_Ql,
 | |
| 	MDOC_Qo,
 | |
| 	MDOC_Qq,
 | |
| 	MDOC_Re,
 | |
| 	MDOC_Rs,
 | |
| 	MDOC_Sc,
 | |
| 	MDOC_So,
 | |
| 	MDOC_Sq,
 | |
| 	MDOC_Sm,
 | |
| 	MDOC_Sx,
 | |
| 	MDOC_Sy,
 | |
| 	MDOC_Tn,
 | |
| 	MDOC_Ux,
 | |
| 	MDOC_Xc,
 | |
| 	MDOC_Xo,
 | |
| 	MDOC_Fo,
 | |
| 	MDOC_Fc,
 | |
| 	MDOC_Oo,
 | |
| 	MDOC_Oc,
 | |
| 	MDOC_Bk,
 | |
| 	MDOC_Ek,
 | |
| 	MDOC_Bt,
 | |
| 	MDOC_Hf,
 | |
| 	MDOC_Fr,
 | |
| 	MDOC_Ud,
 | |
| 	MDOC_Lb,
 | |
| 	MDOC_Lp,
 | |
| 	MDOC_Lk,
 | |
| 	MDOC_Mt,
 | |
| 	MDOC_Brq,
 | |
| 	MDOC_Bro,
 | |
| 	MDOC_Brc,
 | |
| 	MDOC__C,
 | |
| 	MDOC_Es,
 | |
| 	MDOC_En,
 | |
| 	MDOC_Dx,
 | |
| 	MDOC__Q,
 | |
| 	MDOC_br,
 | |
| 	MDOC_sp,
 | |
| 	MDOC__U,
 | |
| 	MDOC_Ta,
 | |
| 	MDOC_MAX
 | |
| };
 | |
| 
 | |
| /* What follows is a list of ALL possible macro arguments. */
 | |
| 
 | |
| #define	MDOC_Split	 0
 | |
| #define	MDOC_Nosplit	 1
 | |
| #define	MDOC_Ragged	 2
 | |
| #define	MDOC_Unfilled	 3
 | |
| #define	MDOC_Literal	 4
 | |
| #define	MDOC_File	 5
 | |
| #define	MDOC_Offset	 6
 | |
| #define	MDOC_Bullet	 7
 | |
| #define	MDOC_Dash	 8
 | |
| #define	MDOC_Hyphen	 9
 | |
| #define	MDOC_Item	 10
 | |
| #define	MDOC_Enum	 11
 | |
| #define	MDOC_Tag	 12
 | |
| #define	MDOC_Diag	 13
 | |
| #define	MDOC_Hang	 14
 | |
| #define	MDOC_Ohang	 15
 | |
| #define	MDOC_Inset	 16
 | |
| #define	MDOC_Column	 17
 | |
| #define	MDOC_Width	 18
 | |
| #define	MDOC_Compact	 19
 | |
| #define	MDOC_Std	 20
 | |
| #define	MDOC_Filled	 21
 | |
| #define	MDOC_Words	 22
 | |
| #define	MDOC_Emphasis	 23
 | |
| #define	MDOC_Symbolic	 24
 | |
| #define	MDOC_Nested	 25
 | |
| #define	MDOC_Centred	 26
 | |
| #define	MDOC_ARG_MAX	 27
 | |
| 
 | |
| /* Type of a syntax node. */
 | |
| enum	mdoc_type {
 | |
| 	MDOC_TEXT,
 | |
| 	MDOC_ELEM,
 | |
| 	MDOC_HEAD,
 | |
| 	MDOC_TAIL,
 | |
| 	MDOC_BODY,
 | |
| 	MDOC_BLOCK,
 | |
| 	MDOC_ROOT
 | |
| };
 | |
| 
 | |
| /* Section (named/unnamed) of `Sh'. */
 | |
| enum	mdoc_sec {
 | |
| 	SEC_NONE,		/* No section, yet. */
 | |
| 	SEC_NAME,
 | |
| 	SEC_LIBRARY,
 | |
| 	SEC_SYNOPSIS,
 | |
| 	SEC_DESCRIPTION,
 | |
| 	SEC_IMPLEMENTATION,
 | |
| 	SEC_RETURN_VALUES,
 | |
| 	SEC_ENVIRONMENT, 
 | |
| 	SEC_FILES,
 | |
| 	SEC_EXIT_STATUS,
 | |
| 	SEC_EXAMPLES,
 | |
| 	SEC_DIAGNOSTICS,
 | |
| 	SEC_COMPATIBILITY,
 | |
| 	SEC_ERRORS,
 | |
| 	SEC_SEE_ALSO,
 | |
| 	SEC_STANDARDS,
 | |
| 	SEC_HISTORY,
 | |
| 	SEC_AUTHORS,
 | |
| 	SEC_CAVEATS,
 | |
| 	SEC_BUGS,
 | |
| 	SEC_SECURITY,
 | |
| 	SEC_CUSTOM,		/* User-defined. */
 | |
| 	SEC__MAX
 | |
| };
 | |
| 
 | |
| /* Information from prologue. */
 | |
| struct	mdoc_meta {
 | |
| 	char		 *msec;
 | |
| 	char		 *vol;
 | |
| 	char		 *arch;
 | |
| 	time_t		  date;
 | |
| 	char		 *title;
 | |
| 	char		 *os;
 | |
| 	char		 *name;
 | |
| };
 | |
| 
 | |
| /* An argument to a macro (multiple values = `It -column'). */
 | |
| struct	mdoc_argv {
 | |
| 	int	  	  arg;
 | |
| 	int		  line;
 | |
| 	int		  pos;
 | |
| 	size_t		  sz;
 | |
| 	char		**value;
 | |
| };
 | |
| 
 | |
| struct 	mdoc_arg {
 | |
| 	size_t		  argc;
 | |
| 	struct mdoc_argv *argv;
 | |
| 	unsigned int	  refcnt;
 | |
| };
 | |
| 
 | |
| enum	mdoc_list {
 | |
| 	LIST__NONE = 0,
 | |
| 	LIST_bullet,
 | |
| 	LIST_column,
 | |
| 	LIST_dash,
 | |
| 	LIST_diag,
 | |
| 	LIST_enum,
 | |
| 	LIST_hang,
 | |
| 	LIST_hyphen,
 | |
| 	LIST_inset,
 | |
| 	LIST_item,
 | |
| 	LIST_ohang,
 | |
| 	LIST_tag
 | |
| };
 | |
| 
 | |
| enum	mdoc_disp {
 | |
| 	DISP__NONE = 0,
 | |
| 	DISP_centred,
 | |
| 	DISP_ragged,
 | |
| 	DISP_unfilled,
 | |
| 	DISP_filled,
 | |
| 	DISP_literal
 | |
| };
 | |
| 
 | |
| struct	mdoc_bd {
 | |
| 	const char	 *offs; /* -offset */
 | |
| 	enum mdoc_disp	  type; /* -ragged, etc. */
 | |
| 	int		  comp; /* -compact */
 | |
| };
 | |
| 
 | |
| struct	mdoc_bl {
 | |
| 	const char	 *width; /* -width */
 | |
| 	const char	 *offs; /* -offset */
 | |
| 	enum mdoc_list	  type; /* -tag, -enum, etc. */
 | |
| 	int		  comp; /* -compact */
 | |
| };
 | |
| 
 | |
| /* Node in AST. */
 | |
| struct	mdoc_node {
 | |
| 	struct mdoc_node *parent; /* parent AST node */
 | |
| 	struct mdoc_node *child; /* first child AST node */
 | |
| 	struct mdoc_node *next; /* sibling AST node */
 | |
| 	struct mdoc_node *prev; /* prior sibling AST node */
 | |
| 	int		  nchild; /* number children */
 | |
| 	int		  line; /* parse line */
 | |
| 	int		  pos; /* parse column */
 | |
| 	enum mdoct	  tok; /* tok or MDOC__MAX if none */
 | |
| 	int		  flags;
 | |
| #define	MDOC_VALID	 (1 << 0) /* has been validated */
 | |
| #define	MDOC_ACTED	 (1 << 1) /* has been acted upon */
 | |
| #define	MDOC_EOS	 (1 << 2) /* at sentence boundary */
 | |
| #define	MDOC_LINE	 (1 << 3) /* first macro/text on line */
 | |
| 	enum mdoc_type	  type; /* AST node type */
 | |
| 	enum mdoc_sec	  sec; /* current named section */
 | |
| 	struct mdoc_arg	 *args; 	/* BLOCK/ELEM */
 | |
| #ifdef	UGLY
 | |
| 	struct mdoc_node *pending;	/* BLOCK */
 | |
| #endif
 | |
| 	struct mdoc_node *head;		/* BLOCK */
 | |
| 	struct mdoc_node *body;		/* BLOCK */
 | |
| 	struct mdoc_node *tail;		/* BLOCK */
 | |
| 	char		 *string;	/* TEXT */
 | |
| 
 | |
| 	union {
 | |
| 		struct mdoc_bl Bl;
 | |
| 		struct mdoc_bd Bd;
 | |
| 	} data;
 | |
| };
 | |
| 
 | |
| #define	MDOC_IGN_SCOPE	 (1 << 0) /* Ignore scope violations. */
 | |
| #define	MDOC_IGN_ESCAPE	 (1 << 1) /* Ignore bad escape sequences. */
 | |
| #define	MDOC_IGN_MACRO	 (1 << 2) /* Ignore unknown macros. */
 | |
| 
 | |
| /* See mdoc.3 for documentation. */
 | |
| 
 | |
| extern	const char *const *mdoc_macronames;
 | |
| extern	const char *const *mdoc_argnames;
 | |
| 
 | |
| __BEGIN_DECLS
 | |
| 
 | |
| struct	mdoc;
 | |
| 
 | |
| /* See mdoc.3 for documentation. */
 | |
| 
 | |
| void	 	  mdoc_free(struct mdoc *);
 | |
| struct	mdoc	 *mdoc_alloc(void *, int, mandocmsg);
 | |
| void		  mdoc_reset(struct mdoc *);
 | |
| int	 	  mdoc_parseln(struct mdoc *, int, char *, int);
 | |
| const struct mdoc_node *mdoc_node(const struct mdoc *);
 | |
| const struct mdoc_meta *mdoc_meta(const struct mdoc *);
 | |
| int		  mdoc_endparse(struct mdoc *);
 | |
| 
 | |
| __END_DECLS
 | |
| 
 | |
| #endif /*!MDOC_H*/
 | 
