]> git.cameronkatri.com Git - mandoc.git/blobdiff - mdoc.h
Boolean validation.
[mandoc.git] / mdoc.h
diff --git a/mdoc.h b/mdoc.h
index 1d8b0b0cde92eeb8c9f6bc2d2e0649577a065089..cac9fee98c25652425c44e784f9fda09b722b261 100644 (file)
--- a/mdoc.h
+++ b/mdoc.h
@@ -1,4 +1,4 @@
-/* $Id: mdoc.h,v 1.14 2009/01/05 16:11:14 kristaps Exp $ */
+/* $Id: mdoc.h,v 1.23 2009/01/16 12:23:25 kristaps Exp $ */
 /*
  * Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
  *
@@ -19,7 +19,7 @@
 #ifndef MDOC_H
 #define MDOC_H
 
-#define        MDOC_LINEARG_MAX 8
+/* What follows is a list of ALL possible macros. */
 
 #define        MDOC___          0
 #define        MDOC_Dd          1
 #define        MDOC_Ud          105
 #define        MDOC_MAX         106
 
+/* What follows is a list of ALL possible macro arguments. */
+
 #define        MDOC_Split       0
 #define        MDOC_Nosplit     1
 #define        MDOC_Ragged      2
 #define        MDOC_Symbolic    61
 #define        MDOC_ARG_MAX     62
 
-enum   mdoc_err {
-       ERR_SYNTAX_QUOTE, /* NOTUSED */
-       ERR_SYNTAX_UNQUOTE,
-       ERR_SYNTAX_NOPUNCT,
-       ERR_SYNTAX_WS,
-       ERR_SYNTAX_ARG,
-       ERR_SYNTAX_ARGFORM,
-       ERR_SYNTAX_ARGVAL,
-       ERR_SYNTAX_ARGBAD,
-       ERR_SYNTAX_ARGMANY,
-       ERR_MACRO_NOTSUP,
-       ERR_MACRO_NOTCALL,
-       ERR_SCOPE_BREAK,
-       ERR_SCOPE_NOCTX,
-       ERR_SCOPE_NONEST,
-       ERR_SEC_PROLOGUE,
-       ERR_SEC_NPROLOGUE,
-       ERR_SEC_PROLOGUE_OO,
-       ERR_SEC_PROLOGUE_REP,
-       ERR_SEC_NAME,
-       ERR_ARGS_EQ0,
-       ERR_ARGS_EQ1,
-       ERR_ARGS_GE1,
-       ERR_ARGS_LE2,
-       ERR_ARGS_MANY,
-       ERR_SYNTAX_CHILDHEAD,
-       ERR_SYNTAX_CHILDBODY,
-       ERR_SYNTAX_EMPTYBODY,
-       ERR_SYNTAX_EMPTYHEAD
+enum   mdoc_warn {
+       WARN_SYNTAX,            /* Syntax warn (at line/col). */
+       WARN_COMPAT             /* Groff compat warn (at line/col). */
 };
 
+/* Possible values for the `At' macro. */
 enum   mdoc_att {
        ATT_DEFAULT = 0,
        ATT_v1,
@@ -240,36 +217,40 @@ enum      mdoc_att {
        ATT_V4
 };
 
-enum   mdoc_warn {
-       WARN_SYNTAX_WS_EOLN,
-       WARN_SYNTAX_MACLIKE,
-       WARN_SYNTAX_ARGLIKE,
-       WARN_SYNTAX_QUOTED,
-       WARN_SYNTAX_EMPTYBODY,
-       WARN_IGN_AFTER_BLK,
-       WARN_IGN_BEFORE_BLK,
-       WARN_IGN_OBSOLETE,
-       WARN_SEC_OO,
-       WARN_ARGS_GE1,
-       WARN_ARGS_EQ0,
-       WARN_COMPAT_TROFF
-};
-
+/* An argument to a macro (multiple values = `It -column'). */
 struct mdoc_arg {
        int               arg;
+       int               line;
+       int               pos;
        size_t            sz;
        char            **value;
 };
 
+/*
+ * Simplified grammar of syntax tree:
+ *
+ * MDOC_ROOT: root of tree
+ * MDOC_TEXT: free-form text
+ * MDOC_ELEM: elem [args] MDOC_TEXT...
+ * MDOC_BLOCK, MDOC_HEAD, MDOC_BODY, MDOC_TAIL:
+ *   MDOC_BLOCK:
+ *     MDOC_HEAD [args] (MDOC_TEXT|MDOC_ELEM|MDOC_BLOCK)...
+ *     MDOC_BODY (MDOC_TEXT|MDOC_ELEM|MDOC_BLOCK)...
+ *     MDOC_TAIL (optional) (MDOC_TEXT|MDOC_ELEM|MDOC_BLOCK)...
+ */
+
+/* Type of a syntax node. */
 enum   mdoc_type {
        MDOC_TEXT,
        MDOC_ELEM,
        MDOC_HEAD,
        MDOC_TAIL,
        MDOC_BODY,
-       MDOC_BLOCK
+       MDOC_BLOCK,
+       MDOC_ROOT
 };
 
+/* Manual section. */
 enum   mdoc_msec {
        MSEC_DEFAULT = 0,
        MSEC_1,
@@ -292,6 +273,7 @@ enum        mdoc_msec {
        MSEC_paper
 };
 
+/* Section (named/unnamed) of `Ss'. */
 enum   mdoc_sec {
        SEC_PROLOGUE = 0,
        SEC_BODY,
@@ -313,6 +295,7 @@ enum        mdoc_sec {
        SEC_CUSTOM
 };
 
+/* Volume of `Dt'. */
 enum   mdoc_vol {
        VOL_DEFAULT = 0,
        VOL_AMD,
@@ -326,12 +309,14 @@ enum      mdoc_vol {
        VOL_USD
 };
 
+/* Architecture of `Dt'. */
 enum   mdoc_arch {
        ARCH_DEFAULT = 0,
        ARCH_alpha, 
        ARCH_amd64, 
        ARCH_amiga, 
        ARCH_arc, 
+       ARCH_arm, 
        ARCH_armish, 
        ARCH_aviion, 
        ARCH_hp300,
@@ -355,6 +340,7 @@ enum        mdoc_arch {
        ARCH_zaurus
 };
 
+/* Meta-information from prologue. */
 struct mdoc_meta {
        enum mdoc_msec    msec;
        enum mdoc_vol     vol;
@@ -371,27 +357,16 @@ struct    mdoc_text {
 };
 
 struct mdoc_block {
-       int               tok;
        size_t            argc;
        struct mdoc_arg  *argv;
-};
-
-struct mdoc_head {
-       int               tok;
-};
-
-struct mdoc_tail {
-       int               tok;
-};
-
-struct mdoc_body {
-       int               tok;
+       struct mdoc_node *head;
+       struct mdoc_node *body;
+       struct mdoc_node *tail;
 };
 
 struct mdoc_elem {
        size_t            sz;
        char            **args;
-       int               tok;
        size_t            argc;
        struct mdoc_arg  *argv;
 };
@@ -399,25 +374,28 @@ struct    mdoc_elem {
 union  mdoc_data {
        struct mdoc_text  text;
        struct mdoc_elem  elem;
-       struct mdoc_body  body;
-       struct mdoc_head  head;
-       struct mdoc_tail  tail;
        struct mdoc_block block;
 };
 
+/* Syntax node in parse tree. */
 struct mdoc_node {
        struct mdoc_node *parent;
        struct mdoc_node *child;
        struct mdoc_node *next;
        struct mdoc_node *prev;
+       int               line;
+       int               pos;
+       int               tok;
        enum mdoc_type    type;
        union mdoc_data   data;
 };
 
+/* Call-backs for parse messages. */
 struct mdoc_cb {
-       int     (*mdoc_err)(void *, int, int, enum mdoc_err);
-       int     (*mdoc_warn)(void *, int, int, enum mdoc_warn);
-       void    (*mdoc_msg)(void *, int, const char *);
+       void    (*mdoc_msg)(void *, int, int, const char *);
+       int     (*mdoc_err)(void *, int, int, const char *);
+       int     (*mdoc_warn)(void *, int, int, 
+                       enum mdoc_warn, const char *);
 };
 
 extern const char *const *mdoc_macronames;
@@ -427,11 +405,23 @@ __BEGIN_DECLS
 
 struct mdoc;
 
+/* Free memory allocated with mdoc_alloc. */
 void             mdoc_free(struct mdoc *);
+
+/* Allocate a new parser instance. */
 struct mdoc     *mdoc_alloc(void *data, const struct mdoc_cb *);
-int              mdoc_parseln(struct mdoc *, char *buf);
-const struct mdoc_node
-                *mdoc_result(struct mdoc *);
+
+/* Parse a single line (boolean retval). */
+int              mdoc_parseln(struct mdoc *, int, char *buf);
+
+/* Get parse result or NULL. */
+const struct mdoc_node *mdoc_result(struct mdoc *);
+
+/* Signal end of parse sequence (boolean retval). */
+int              mdoc_endparse(struct mdoc *);
+
+/* Node type to static string. */
+char            *mdoc_type2a(enum mdoc_type);
 
 __END_DECLS