version 1.123, 2012/07/10 14:38:51 |
version 1.135, 2015/02/05 00:14:13 |
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
*/ |
*/ |
#ifndef MDOC_H |
|
#define MDOC_H |
|
|
|
enum mdoct { |
enum mdoct { |
MDOC_Ap = 0, |
MDOC_Ap = 0, |
|
|
MDOC_sp, |
MDOC_sp, |
MDOC__U, |
MDOC__U, |
MDOC_Ta, |
MDOC_Ta, |
|
MDOC_ll, |
MDOC_MAX |
MDOC_MAX |
}; |
}; |
|
|
Line 186 enum mdoc_type { |
|
Line 185 enum mdoc_type { |
|
MDOC_ROOT |
MDOC_ROOT |
}; |
}; |
|
|
/* |
/* |
* Section (named/unnamed) of `Sh'. Note that these appear in the |
* Section (named/unnamed) of `Sh'. Note that these appear in the |
* conventional order imposed by mdoc.7. In the case of SEC_NONE, no |
* conventional order imposed by mdoc.7. In the case of SEC_NONE, no |
* section has been invoked (this shouldn't happen). SEC_CUSTOM refers |
* section has been invoked (this shouldn't happen). SEC_CUSTOM refers |
|
|
SEC_LIBRARY, /* LIBRARY */ |
SEC_LIBRARY, /* LIBRARY */ |
SEC_SYNOPSIS, /* SYNOPSIS */ |
SEC_SYNOPSIS, /* SYNOPSIS */ |
SEC_DESCRIPTION, /* DESCRIPTION */ |
SEC_DESCRIPTION, /* DESCRIPTION */ |
|
SEC_CONTEXT, /* CONTEXT */ |
SEC_IMPLEMENTATION, /* IMPLEMENTATION NOTES */ |
SEC_IMPLEMENTATION, /* IMPLEMENTATION NOTES */ |
SEC_RETURN_VALUES, /* RETURN VALUES */ |
SEC_RETURN_VALUES, /* RETURN VALUES */ |
SEC_ENVIRONMENT, /* ENVIRONMENT */ |
SEC_ENVIRONMENT, /* ENVIRONMENT */ |
|
|
SEC_CAVEATS, /* CAVEATS */ |
SEC_CAVEATS, /* CAVEATS */ |
SEC_BUGS, /* BUGS */ |
SEC_BUGS, /* BUGS */ |
SEC_SECURITY, /* SECURITY */ |
SEC_SECURITY, /* SECURITY */ |
SEC_CUSTOM, |
SEC_CUSTOM, |
SEC__MAX |
SEC__MAX |
}; |
}; |
|
|
Line 228 struct mdoc_meta { |
|
Line 228 struct mdoc_meta { |
|
char *name; /* leading `Nm' name */ |
char *name; /* leading `Nm' name */ |
}; |
}; |
|
|
/* |
/* |
* An argument to a macro (multiple values = `-column xxx yyy'). |
* An argument to a macro (multiple values = `-column xxx yyy'). |
*/ |
*/ |
struct mdoc_argv { |
struct mdoc_argv { |
enum mdocargt arg; /* type of argument */ |
enum mdocargt arg; /* type of argument */ |
int line; |
int line; |
int pos; |
int pos; |
size_t sz; /* elements in "value" */ |
size_t sz; /* elements in "value" */ |
Line 244 struct mdoc_argv { |
|
Line 244 struct mdoc_argv { |
|
* blocks have multiple instances of the same arguments spread across |
* blocks have multiple instances of the same arguments spread across |
* the HEAD, BODY, TAIL, and BLOCK node types. |
* the HEAD, BODY, TAIL, and BLOCK node types. |
*/ |
*/ |
struct mdoc_arg { |
struct mdoc_arg { |
size_t argc; |
size_t argc; |
struct mdoc_argv *argv; |
struct mdoc_argv *argv; |
unsigned int refcnt; |
unsigned int refcnt; |
Line 278 enum mdoc_list { |
|
Line 278 enum mdoc_list { |
|
|
|
enum mdoc_disp { |
enum mdoc_disp { |
DISP__NONE = 0, |
DISP__NONE = 0, |
DISP_centred, /* -centered */ |
DISP_centered, /* -centered */ |
DISP_ragged, /* -ragged */ |
DISP_ragged, /* -ragged */ |
DISP_unfilled, /* -unfilled */ |
DISP_unfilled, /* -unfilled */ |
DISP_filled, /* -filled */ |
DISP_filled, /* -filled */ |
Line 332 struct mdoc_rs { |
|
Line 332 struct mdoc_rs { |
|
* provided, etc. |
* provided, etc. |
*/ |
*/ |
union mdoc_data { |
union mdoc_data { |
struct mdoc_an An; |
struct mdoc_an An; |
struct mdoc_bd Bd; |
struct mdoc_bd Bd; |
struct mdoc_bf Bf; |
struct mdoc_bf Bf; |
struct mdoc_bl Bl; |
struct mdoc_bl Bl; |
|
struct mdoc_node *Es; |
struct mdoc_rs Rs; |
struct mdoc_rs Rs; |
}; |
}; |
|
|
/* |
/* |
* Single node in tree-linked AST. |
* Single node in tree-linked AST. |
*/ |
*/ |
struct mdoc_node { |
struct mdoc_node { |
struct mdoc_node *parent; /* parent AST node */ |
struct mdoc_node *parent; /* parent AST node */ |
Line 354 struct mdoc_node { |
|
Line 355 struct mdoc_node { |
|
enum mdoct tok; /* tok or MDOC__MAX if none */ |
enum mdoct tok; /* tok or MDOC__MAX if none */ |
int flags; |
int flags; |
#define MDOC_VALID (1 << 0) /* has been validated */ |
#define MDOC_VALID (1 << 0) /* has been validated */ |
|
#define MDOC_BREAK (1 << 1) /* has broken another block */ |
#define MDOC_EOS (1 << 2) /* at sentence boundary */ |
#define MDOC_EOS (1 << 2) /* at sentence boundary */ |
#define MDOC_LINE (1 << 3) /* first macro/text on line */ |
#define MDOC_LINE (1 << 3) /* first macro/text on line */ |
#define MDOC_SYNPRETTY (1 << 4) /* SYNOPSIS-style formatting */ |
#define MDOC_SYNPRETTY (1 << 4) /* SYNOPSIS-style formatting */ |
Line 363 struct mdoc_node { |
|
Line 365 struct mdoc_node { |
|
enum mdoc_type type; /* AST node type */ |
enum mdoc_type type; /* AST node type */ |
enum mdoc_sec sec; /* current named section */ |
enum mdoc_sec sec; /* current named section */ |
union mdoc_data *norm; /* normalised args */ |
union mdoc_data *norm; /* normalised args */ |
|
int prev_font; /* before entering this node */ |
/* FIXME: these can be union'd to shave a few bytes. */ |
/* FIXME: these can be union'd to shave a few bytes. */ |
struct mdoc_arg *args; /* BLOCK/ELEM */ |
struct mdoc_arg *args; /* BLOCK/ELEM */ |
struct mdoc_node *pending; /* BLOCK */ |
struct mdoc_node *pending; /* BLOCK */ |
|
|
|
|
const struct mdoc_node *mdoc_node(const struct mdoc *); |
const struct mdoc_node *mdoc_node(const struct mdoc *); |
const struct mdoc_meta *mdoc_meta(const struct mdoc *); |
const struct mdoc_meta *mdoc_meta(const struct mdoc *); |
|
void mdoc_deroff(char **, const struct mdoc_node *); |
|
|
__END_DECLS |
__END_DECLS |
|
|
#endif /*!MDOC_H*/ |
|