]> git.cameronkatri.com Git - mandoc.git/blobdiff - libroff.h
Reduce the amount of code by moving the three copies of the ohash
[mandoc.git] / libroff.h
index 58dc86c90ba894574f8c66fe26ed535d0be06549..08ed1f7925d2332837650cb424ec248e1fad8fd7 100644 (file)
--- a/libroff.h
+++ b/libroff.h
@@ -1,6 +1,7 @@
-/*     $Id: libroff.h,v 1.22 2011/07/17 12:13:37 kristaps Exp $ */
+/*     $Id: libroff.h,v 1.38 2015/01/30 04:11:50 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
+ * Copyright (c) 2014, 2015 Ingo Schwarze <schwarze@openbsd.org>
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */
-#ifndef LIBROFF_H
-#define LIBROFF_H
-
-__BEGIN_DECLS
 
 enum   tbl_part {
        TBL_PART_OPTS, /* in options (first line) */
@@ -31,17 +28,31 @@ struct      tbl_node {
        int               pos; /* invocation column */
        int               line; /* invocation line */
        enum tbl_part     part;
-       struct tbl        opts;
+       struct tbl_opts   opts;
        struct tbl_row   *first_row;
        struct tbl_row   *last_row;
        struct tbl_span  *first_span;
        struct tbl_span  *current_span;
        struct tbl_span  *last_span;
-       struct tbl_head  *first_head;
-       struct tbl_head  *last_head;
        struct tbl_node  *next;
 };
 
+struct eqn_node {
+       struct eqn        eqn;    /* syntax tree of this equation */
+       struct mparse    *parse;  /* main parser, for error reporting */
+       struct eqn_node  *next;   /* singly linked list of equations */
+       struct eqn_def   *defs;   /* array of definitions */
+       char             *data;   /* source code of this equation */
+       size_t            defsz;  /* number of definitions */
+       size_t            sz;     /* length of the source code */
+       size_t            cur;    /* parse point in the source code */
+       size_t            rew;    /* beginning of the current token */
+       int               gsize;  /* default point size */
+       int               delim;  /* in-line delimiters enabled */
+       char              odelim; /* in-line opening delimiter */
+       char              cdelim; /* in-line closing delimiter */
+};
+
 struct eqn_def {
        char             *key;
        size_t            keysz;
@@ -49,31 +60,23 @@ struct      eqn_def {
        size_t            valsz;
 };
 
-struct eqn_node {
-       struct eqn_def   *defs;
-       size_t            defsz;
-       struct eqn        eqn;
-       struct mparse    *parse;
-       struct eqn_node  *next;
-};
+__BEGIN_DECLS
 
 struct tbl_node        *tbl_alloc(int, int, struct mparse *);
 void            tbl_restart(int, int, struct tbl_node *);
 void            tbl_free(struct tbl_node *);
 void            tbl_reset(struct tbl_node *);
-enum rofferr    tbl_read(struct tbl_node *, int, const char *, int);
-int             tbl_option(struct tbl_node *, int, const char *);
-int             tbl_layout(struct tbl_node *, int, const char *);
-int             tbl_data(struct tbl_node *, int, const char *);
-int             tbl_cdata(struct tbl_node *, int, const char *);
+enum rofferr    tbl_read(struct tbl_node *, int, const char *, int);
+void            tbl_option(struct tbl_node *, int, const char *, int *);
+void            tbl_layout(struct tbl_node *, int, const char *, int);
+void            tbl_data(struct tbl_node *, int, const char *, int);
+int             tbl_cdata(struct tbl_node *, int, const char *, int);
 const struct tbl_span  *tbl_span(struct tbl_node *);
-void            tbl_end(struct tbl_node *);
+int             tbl_end(struct tbl_node **);
 struct eqn_node        *eqn_alloc(int, int, struct mparse *);
-void            eqn_end(struct eqn_node *);
+enum rofferr    eqn_end(struct eqn_node **);
 void            eqn_free(struct eqn_node *);
-enum rofferr    eqn_read(struct eqn_node **, int, 
+enum rofferr    eqn_read(struct eqn_node **, int,
                        const char *, int, int *);
 
 __END_DECLS
-
-#endif /*LIBROFF_H*/