version 1.49, 2010/12/26 14:44:13 |
version 1.58, 2011/03/23 12:33:01 |
|
|
/* $Id$ */ |
/* $Id$ */ |
/* |
/* |
* Copyright (c) 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv> |
* Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv> |
* |
* |
* Permission to use, copy, modify, and distribute this software for any |
* Permission to use, copy, modify, and distribute this software for any |
* purpose with or without fee is hereby granted, provided that the above |
* purpose with or without fee is hereby granted, provided that the above |
|
|
#ifndef MAN_H |
#ifndef MAN_H |
#define MAN_H |
#define MAN_H |
|
|
/* |
|
* What follows is a list of ALL possible macros. |
|
*/ |
|
enum mant { |
enum mant { |
MAN_br = 0, |
MAN_br = 0, |
MAN_TH, |
MAN_TH, |
|
|
MAN_MAX |
MAN_MAX |
}; |
}; |
|
|
/* |
|
* Type of a syntax node. |
|
*/ |
|
enum man_type { |
enum man_type { |
MAN_TEXT, |
MAN_TEXT, |
MAN_ELEM, |
MAN_ELEM, |
MAN_ROOT, |
MAN_ROOT, |
MAN_BLOCK, |
MAN_BLOCK, |
MAN_HEAD, |
MAN_HEAD, |
MAN_BODY |
MAN_BODY, |
|
MAN_TAIL, |
|
MAN_TBL, |
|
MAN_EQN |
}; |
}; |
|
|
/* |
|
* Information from prologue. |
|
*/ |
|
struct man_meta { |
struct man_meta { |
char *msec; /* `TH' section (1, 3p, etc.) */ |
char *msec; /* `TH' section (1, 3p, etc.) */ |
time_t date; /* `TH' normalised date */ |
char *date; /* `TH' normalised date */ |
char *rawdate; /* raw `TH' date */ |
|
char *vol; /* `TH' volume */ |
char *vol; /* `TH' volume */ |
char *title; /* `TH' title (e.g., FOO) */ |
char *title; /* `TH' title (e.g., FOO) */ |
char *source; /* `TH' source (e.g., GNU) */ |
char *source; /* `TH' source (e.g., GNU) */ |
}; |
}; |
|
|
/* |
|
* Single node in tree-linked AST. |
|
*/ |
|
struct man_node { |
struct man_node { |
struct man_node *parent; /* parent AST node */ |
struct man_node *parent; /* parent AST node */ |
struct man_node *child; /* first child AST node */ |
struct man_node *child; /* first child AST node */ |
Line 96 struct man_node { |
|
Line 86 struct man_node { |
|
int flags; |
int flags; |
#define MAN_VALID (1 << 0) /* has been validated */ |
#define MAN_VALID (1 << 0) /* has been validated */ |
#define MAN_EOS (1 << 2) /* at sentence boundary */ |
#define MAN_EOS (1 << 2) /* at sentence boundary */ |
|
#define MAN_LINE (1 << 3) /* first macro/text on line */ |
enum man_type type; /* AST node type */ |
enum man_type type; /* AST node type */ |
char *string; /* TEXT node argument */ |
char *string; /* TEXT node argument */ |
struct man_node *head; /* BLOCK node HEAD ptr */ |
struct man_node *head; /* BLOCK node HEAD ptr */ |
|
struct man_node *tail; /* BLOCK node TAIL ptr */ |
struct man_node *body; /* BLOCK node BODY ptr */ |
struct man_node *body; /* BLOCK node BODY ptr */ |
|
const struct tbl_span *span; /* TBL */ |
|
const struct eqn *eqn; /* EQN */ |
}; |
}; |
|
|
/* |
/* Names of macros. Index is enum mant. */ |
* Names of macros. Index is enum mant. Indexing into this returns |
|
* the normalised name, e.g., man_macronames[MAN_SH] -> "SH". |
|
*/ |
|
extern const char *const *man_macronames; |
extern const char *const *man_macronames; |
|
|
__BEGIN_DECLS |
__BEGIN_DECLS |
|
|
struct man; |
struct man; |
|
|
void man_free(struct man *); |
|
struct man *man_alloc(struct regset *, void *, mandocmsg); |
|
void man_reset(struct man *); |
|
int man_parseln(struct man *, int, char *, int); |
|
int man_endparse(struct man *); |
|
|
|
const struct man_node *man_node(const struct man *); |
const struct man_node *man_node(const struct man *); |
const struct man_meta *man_meta(const struct man *); |
const struct man_meta *man_meta(const struct man *); |