=================================================================== RCS file: /cvs/mandoc/Attic/private.h,v retrieving revision 1.57 retrieving revision 1.60 diff -u -p -r1.57 -r1.60 --- mandoc/Attic/private.h 2009/01/07 15:53:00 1.57 +++ mandoc/Attic/private.h 2009/01/08 14:55:59 1.60 @@ -1,4 +1,4 @@ -/* $Id: private.h,v 1.57 2009/01/07 15:53:00 kristaps Exp $ */ +/* $Id: private.h,v 1.60 2009/01/08 14:55:59 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -40,8 +40,12 @@ struct mdoc { enum mdoc_sec sec_last; }; + +#define MACRO_PROT_ARGS struct mdoc *mdoc, int tok, int line, \ + int ppos, int *pos, char *buf + struct mdoc_macro { - int (*fp)(struct mdoc *, int, int, int *, char *); + int (*fp)(MACRO_PROT_ARGS); int flags; #define MDOC_CALLABLE (1 << 0) #define MDOC_PARSED (1 << 1) @@ -53,24 +57,30 @@ struct mdoc_macro { extern const struct mdoc_macro *const mdoc_macros; -#define MACRO_PROT_ARGS struct mdoc *mdoc, int tok, \ - int ppos, int *pos, char *buf - __BEGIN_DECLS -int mdoc_err(struct mdoc *, int, int, enum mdoc_err); -int mdoc_warn(struct mdoc *, int, int, enum mdoc_warn); -void mdoc_msg(struct mdoc *, int, const char *, ...); -int mdoc_macro(struct mdoc *, int, int, int *, char *); +#define mdoc_vwarn(m, n, t) \ + mdoc_pwarn((m), (n)->line, (n)->pos, (t)) +#define mdoc_verr(m, n, t) \ + mdoc_perr((m), (n)->line, (n)->pos, (t)) +#define mdoc_warn(m, t) \ + mdoc_pwarn((m), (m)->last->line, (m)->last->pos, (t)) +#define mdoc_err(m, t) \ + mdoc_perr((m), (m)->last->line, (m)->last->pos, (t)) +int mdoc_pwarn(struct mdoc *, int, int, enum mdoc_warn); +int mdoc_perr(struct mdoc *, int, int, enum mdoc_err); +void mdoc_msg(struct mdoc *, const char *, ...); +int mdoc_macro(MACRO_PROT_ARGS); int mdoc_find(const struct mdoc *, const char *); -void mdoc_word_alloc(struct mdoc *, int, const char *); -void mdoc_elem_alloc(struct mdoc *, int, int, - size_t, const struct mdoc_arg *); -void mdoc_block_alloc(struct mdoc *, int, int, - size_t, const struct mdoc_arg *); -void mdoc_head_alloc(struct mdoc *, int, int); -void mdoc_tail_alloc(struct mdoc *, int, int); -void mdoc_body_alloc(struct mdoc *, int, int); +int mdoc_word_alloc(struct mdoc *, + int, int, const char *); +int mdoc_elem_alloc(struct mdoc *, int, int, + int, size_t, const struct mdoc_arg *); +int mdoc_block_alloc(struct mdoc *, int, int, + int, size_t, const struct mdoc_arg *); +int mdoc_head_alloc(struct mdoc *, int, int, int); +int mdoc_tail_alloc(struct mdoc *, int, int, int); +int mdoc_body_alloc(struct mdoc *, int, int, int); void mdoc_node_free(struct mdoc_node *); void mdoc_sibling(struct mdoc *, int, struct mdoc_node **, struct mdoc_node **, struct mdoc_node *); @@ -86,12 +96,12 @@ enum mdoc_arch mdoc_atoarch(const char *); enum mdoc_att mdoc_atoatt(const char *); time_t mdoc_atotime(const char *); -int mdoc_valid_pre(struct mdoc *, int, int, - int, const struct mdoc_arg *); -int mdoc_valid_post(struct mdoc *, int); -int mdoc_action(struct mdoc *, int); +int mdoc_valid_pre(struct mdoc *, struct mdoc_node *); +int mdoc_valid_post(struct mdoc *); +int mdoc_action_pre(struct mdoc *, struct mdoc_node *); +int mdoc_action_post(struct mdoc *); -int mdoc_argv(struct mdoc *, int, +int mdoc_argv(struct mdoc *, int, int, struct mdoc_arg *, int *, char *); #define ARGV_ERROR (-1) #define ARGV_EOLN (0)