]> git.cameronkatri.com Git - mandoc.git/blobdiff - mdoc.h
In .Bl -column, if some of the column width declarations are given
[mandoc.git] / mdoc.h
diff --git a/mdoc.h b/mdoc.h
index cc807d778e69db8a8b2786e3466f5611a175c3d3..58ad81318f5e06037dfcf20f540249fed219370a 100644 (file)
--- a/mdoc.h
+++ b/mdoc.h
@@ -1,4 +1,4 @@
-/*     $Id: mdoc.h,v 1.124 2012/11/16 17:16:55 schwarze Exp $ */
+/*     $Id: mdoc.h,v 1.131 2014/07/29 13:58:18 schwarze Exp $ */
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  *
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  *
@@ -140,6 +140,7 @@ enum        mdoct {
        MDOC_sp,
        MDOC__U,
        MDOC_Ta,
        MDOC_sp,
        MDOC__U,
        MDOC_Ta,
+       MDOC_ll,
        MDOC_MAX
 };
 
        MDOC_MAX
 };
 
@@ -186,7 +187,7 @@ enum        mdoc_type {
        MDOC_ROOT
 };
 
        MDOC_ROOT
 };
 
-/* 
+/*
  * Section (named/unnamed) of `Sh'.   Note that these appear in the
  * 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 (named/unnamed) of `Sh'.   Note that these appear in the
  * conventional order imposed by mdoc.7.  In the case of SEC_NONE, no
  * section has been invoked (this shouldn't happen).  SEC_CUSTOM refers
@@ -198,6 +199,7 @@ enum        mdoc_sec {
        SEC_LIBRARY, /* LIBRARY */
        SEC_SYNOPSIS, /* SYNOPSIS */
        SEC_DESCRIPTION, /* DESCRIPTION */
        SEC_LIBRARY, /* LIBRARY */
        SEC_SYNOPSIS, /* SYNOPSIS */
        SEC_DESCRIPTION, /* DESCRIPTION */
+       SEC_CONTEXT, /* CONTEXT */
        SEC_IMPLEMENTATION, /* IMPLEMENTATION NOTES */
        SEC_RETURN_VALUES, /* RETURN VALUES */
        SEC_ENVIRONMENT,  /* ENVIRONMENT */
        SEC_IMPLEMENTATION, /* IMPLEMENTATION NOTES */
        SEC_RETURN_VALUES, /* RETURN VALUES */
        SEC_ENVIRONMENT,  /* ENVIRONMENT */
@@ -214,7 +216,7 @@ enum        mdoc_sec {
        SEC_CAVEATS, /* CAVEATS */
        SEC_BUGS, /* BUGS */
        SEC_SECURITY, /* SECURITY */
        SEC_CAVEATS, /* CAVEATS */
        SEC_BUGS, /* BUGS */
        SEC_SECURITY, /* SECURITY */
-       SEC_CUSTOM, 
+       SEC_CUSTOM,
        SEC__MAX
 };
 
        SEC__MAX
 };
 
@@ -228,11 +230,11 @@ 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               pos;
        size_t            sz; /* elements in "value" */
        int               line;
        int               pos;
        size_t            sz; /* elements in "value" */
@@ -244,7 +246,7 @@ struct      mdoc_argv {
  * blocks have multiple instances of the same arguments spread across
  * the HEAD, BODY, TAIL, and BLOCK node types.
  */
  * blocks have multiple instances of the same arguments spread across
  * the HEAD, BODY, TAIL, and BLOCK node types.
  */
-struct         mdoc_arg {
+struct mdoc_arg {
        size_t            argc;
        struct mdoc_argv *argv;
        unsigned int      refcnt;
        size_t            argc;
        struct mdoc_argv *argv;
        unsigned int      refcnt;
@@ -278,7 +280,7 @@ enum        mdoc_list {
 
 enum   mdoc_disp {
        DISP__NONE = 0,
 
 enum   mdoc_disp {
        DISP__NONE = 0,
-       DISP_centred, /* -centered */
+       DISP_centered, /* -centered */
        DISP_ragged, /* -ragged */
        DISP_unfilled, /* -unfilled */
        DISP_filled, /* -filled */
        DISP_ragged, /* -ragged */
        DISP_unfilled, /* -unfilled */
        DISP_filled, /* -filled */
@@ -332,15 +334,16 @@ struct    mdoc_rs {
  * provided, etc.
  */
 union  mdoc_data {
  * provided, etc.
  */
 union  mdoc_data {
-       struct mdoc_an    An;
+       struct mdoc_an    An;
        struct mdoc_bd    Bd;
        struct mdoc_bf    Bf;
        struct mdoc_bl    Bl;
        struct mdoc_bd    Bd;
        struct mdoc_bf    Bf;
        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 *parent; /* parent AST node */
  */
 struct mdoc_node {
        struct mdoc_node *parent; /* parent AST node */
@@ -351,6 +354,7 @@ struct      mdoc_node {
        int               nchild; /* number children */
        int               line; /* parse line */
        int               pos; /* parse column */
        int               nchild; /* number children */
        int               line; /* parse line */
        int               pos; /* parse column */
+       int               lastline; /* the node ends on this line */
        enum mdoct        tok; /* tok or MDOC__MAX if none */
        int               flags;
 #define        MDOC_VALID       (1 << 0) /* has been validated */
        enum mdoct        tok; /* tok or MDOC__MAX if none */
        int               flags;
 #define        MDOC_VALID       (1 << 0) /* has been validated */
@@ -388,6 +392,7 @@ struct      mdoc;
 
 const struct mdoc_node *mdoc_node(const struct mdoc *);
 const struct mdoc_meta *mdoc_meta(const struct mdoc *);
 
 const struct mdoc_node *mdoc_node(const struct mdoc *);
 const struct mdoc_meta *mdoc_meta(const struct mdoc *);
+void mdoc_deroff(char **, const struct mdoc_node *);
 
 __END_DECLS
 
 
 __END_DECLS