[BACK]Return to extern.h CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / texi2mdoc

Annotation of texi2mdoc/extern.h, Revision 1.17

1.17    ! kristaps    1: /*     $Id: extern.h,v 1.16 2015/02/25 14:49:14 kristaps Exp $ */
1.1       kristaps    2: /*
                      3:  * Copyright (c) 2015 Kristaps Dzonsons <kristaps@bsd.lv>
                      4:  *
                      5:  * Permission to use, copy, modify, and distribute this software for any
                      6:  * purpose with or without fee is hereby granted, provided that the above
                      7:  * copyright notice and this permission notice appear in all copies.
                      8:  *
                      9:  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
                     10:  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
                     11:  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
                     12:  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
                     13:  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
                     14:  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
                     15:  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
                     16:  */
                     17: #ifndef EXTERN_H
                     18: #define EXTERN_H
1.17    ! kristaps   19:
        !            20: #if !defined(__BEGIN_DECLS)
        !            21: #  ifdef __cplusplus
        !            22: #  define      __BEGIN_DECLS           extern "C" {
        !            23: #  else
        !            24: #  define      __BEGIN_DECLS
        !            25: #  endif
        !            26: #endif
        !            27: #if !defined(__END_DECLS)
        !            28: #  ifdef __cplusplus
        !            29: #  define      __END_DECLS             }
        !            30: #  else
        !            31: #  define      __END_DECLS
        !            32: #  endif
        !            33: #endif
1.1       kristaps   34:
                     35: /*
                     36:  * This defines each one of the Texinfo commands that we understand.
                     37:  * Obviously this only refers to native commands; overriden names are a
                     38:  * different story.
                     39:  */
                     40: enum   texicmd {
1.12      kristaps   41:        TEXICMD_A4PAPER,
                     42:        TEXICMD_AA,
                     43:        TEXICMD_AASMALL,
1.1       kristaps   44:        TEXICMD_ACRONYM,
                     45:        TEXICMD_ACUTE,
1.12      kristaps   46:        TEXICMD_AE,
                     47:        TEXICMD_AESMALL,
1.1       kristaps   48:        TEXICMD_ANCHOR,
                     49:        TEXICMD_APPENDIX,
                     50:        TEXICMD_APPENDIXSEC,
                     51:        TEXICMD_APPENDIXSUBSEC,
                     52:        TEXICMD_APPENDIXSUBSUBSEC,
1.2       kristaps   53:        TEXICMD_ASIS,
1.1       kristaps   54:        TEXICMD_ASTERISK,
                     55:        TEXICMD_AT,
                     56:        TEXICMD_AUTHOR,
                     57:        TEXICMD_B,
                     58:        TEXICMD_BANG,
                     59:        TEXICMD_BULLET,
                     60:        TEXICMD_BYE,
1.9       kristaps   61:        TEXICMD_CARTOUCHE,
                     62:        TEXICMD_CEDILLA,
1.1       kristaps   63:        TEXICMD_CENTER,
                     64:        TEXICMD_CHAPTER,
                     65:        TEXICMD_CINDEX,
                     66:        TEXICMD_CIRCUMFLEX,
                     67:        TEXICMD_CITE,
                     68:        TEXICMD_CLEAR,
                     69:        TEXICMD_CODE,
                     70:        TEXICMD_COLON,
                     71:        TEXICMD_COLUMNFRACTIONS,
1.10      kristaps   72:        TEXICMD_COMMA,
1.1       kristaps   73:        TEXICMD_COMMAND,
                     74:        TEXICMD_COMMENT,
                     75:        TEXICMD_COMMENT_LONG,
                     76:        TEXICMD_CONTENTS,
                     77:        TEXICMD_COPYING,
                     78:        TEXICMD_COPYRIGHT,
1.3       kristaps   79:        TEXICMD_DEFCODEINDEX,
1.1       kristaps   80:        TEXICMD_DEFFN,
                     81:        TEXICMD_DEFFNX,
1.3       kristaps   82:        TEXICMD_DEFINDEX,
1.1       kristaps   83:        TEXICMD_DEFMAC,
                     84:        TEXICMD_DEFMACX,
                     85:        TEXICMD_DEFTP,
                     86:        TEXICMD_DEFTPX,
                     87:        TEXICMD_DEFTYPEFN,
                     88:        TEXICMD_DEFTYPEFNX,
                     89:        TEXICMD_DEFTYPEFUN,
                     90:        TEXICMD_DEFTYPEFUNX,
1.9       kristaps   91:        TEXICMD_DEFTYPEMETHOD,
                     92:        TEXICMD_DEFTYPEMETHODX,
1.1       kristaps   93:        TEXICMD_DEFTYPEVAR,
                     94:        TEXICMD_DEFTYPEVARX,
                     95:        TEXICMD_DEFTYPEVR,
                     96:        TEXICMD_DEFTYPEVRX,
                     97:        TEXICMD_DEFUN,
                     98:        TEXICMD_DEFUNX,
                     99:        TEXICMD_DEFVAR,
                    100:        TEXICMD_DEFVARX,
                    101:        TEXICMD_DEFVR,
                    102:        TEXICMD_DEFVRX,
                    103:        TEXICMD_DETAILMENU,
                    104:        TEXICMD_DFN,
1.12      kristaps  105:        TEXICMD_DH,
                    106:        TEXICMD_DHSMALL,
1.1       kristaps  107:        TEXICMD_DIRCATEGORY,
                    108:        TEXICMD_DIRENTRY,
                    109:        TEXICMD_DISPLAY,
1.4       kristaps  110:        TEXICMD_DMN,
1.11      kristaps  111:        TEXICMD_DOCUMENTDESCRPITION,
                    112:        TEXICMD_DOCUMENTENCODING,
1.14      kristaps  113:        TEXICMD_DOCUMENTLANGUAGE,
1.12      kristaps  114:        TEXICMD_DOTACCENT,
                    115:        TEXICMD_DOTLESS,
1.1       kristaps  116:        TEXICMD_DOTS,
                    117:        TEXICMD_EMAIL,
                    118:        TEXICMD_EMPH,
                    119:        TEXICMD_END,
1.9       kristaps  120:        TEXICMD_ENDDOTS,
1.1       kristaps  121:        TEXICMD_ENUMERATE,
                    122:        TEXICMD_ENV,
1.4       kristaps  123:        TEXICMD_EQUIV,
1.1       kristaps  124:        TEXICMD_ERROR,
1.13      kristaps  125:        TEXICMD_EURO,
1.1       kristaps  126:        TEXICMD_EXAMPLE,
1.12      kristaps  127:        TEXICMD_EXCLAMDOWN,
1.2       kristaps  128:        TEXICMD_EXDENT,
1.1       kristaps  129:        TEXICMD_EXPANSION,
                    130:        TEXICMD_FILE,
                    131:        TEXICMD_FINALOUT,
                    132:        TEXICMD_FINDEX,
1.14      kristaps  133:        TEXICMD_FLUSHLEFT,
                    134:        TEXICMD_FLUSHRIGHT,
                    135:        TEXICMD_FIRSTPARAGRAPHINDENT,
1.7       kristaps  136:        TEXICMD_FOOTNOTE,
1.14      kristaps  137:        TEXICMD_FOOTNOTESTYLE,
1.1       kristaps  138:        TEXICMD_FTABLE,
                    139:        TEXICMD_FORMAT,
1.13      kristaps  140:        TEXICMD_GEQ,
1.1       kristaps  141:        TEXICMD_GRAVE,
                    142:        TEXICMD_GROUP,
1.13      kristaps  143:        TEXICMD_GUILLEMETLEFT,
                    144:        TEXICMD_GUILLEMETRIGHT,
                    145:        TEXICMD_GUILLEMOTLEFT,
                    146:        TEXICMD_GUILLEMOTRIGHT,
                    147:        TEXICMD_GUILSINGLLEFT,
                    148:        TEXICMD_GUILSINGLRIGHT,
1.12      kristaps  149:        TEXICMD_H,
1.1       kristaps  150:        TEXICMD_HEADING,
                    151:        TEXICMD_HEADINGS,
                    152:        TEXICMD_HEADITEM,
1.2       kristaps  153:        TEXICMD_HTML,
1.1       kristaps  154:        TEXICMD_HYPHEN,
                    155:        TEXICMD_I,
                    156:        TEXICMD_IFCLEAR,
                    157:        TEXICMD_IFDOCBOOK,
                    158:        TEXICMD_IFHTML,
                    159:        TEXICMD_IFINFO,
                    160:        TEXICMD_IFNOTDOCBOOK,
                    161:        TEXICMD_IFNOTHTML,
                    162:        TEXICMD_IFNOTINFO,
                    163:        TEXICMD_IFNOTPLAINTEXT,
                    164:        TEXICMD_IFNOTTEX,
                    165:        TEXICMD_IFNOTXML,
                    166:        TEXICMD_IFPLAINTEXT,
                    167:        TEXICMD_IFTEX,
                    168:        TEXICMD_IFSET,
                    169:        TEXICMD_IFXML,
                    170:        TEXICMD_IGNORE,
                    171:        TEXICMD_IMAGE,
                    172:        TEXICMD_INCLUDE,
                    173:        TEXICMD_INDENTBLOCK,
1.14      kristaps  174:        TEXICMD_INDICATEURL,
1.9       kristaps  175:        TEXICMD_INFOREF,
1.1       kristaps  176:        TEXICMD_INSERTCOPYING,
                    177:        TEXICMD_ITEM,
                    178:        TEXICMD_ITEMIZE,
                    179:        TEXICMD_ITEMX,
                    180:        TEXICMD_KBD,
                    181:        TEXICMD_KEY,
                    182:        TEXICMD_KINDEX,
1.12      kristaps  183:        TEXICMD_L,
1.1       kristaps  184:        TEXICMD_LATEX,
1.13      kristaps  185:        TEXICMD_LEQ,
1.1       kristaps  186:        TEXICMD_LOWERSECTIONS,
1.12      kristaps  187:        TEXICMD_LSMALL,
1.5       kristaps  188:        TEXICMD_MACRO,
1.12      kristaps  189:        TEXICMD_MACRON,
1.1       kristaps  190:        TEXICMD_MATH,
                    191:        TEXICMD_MENU,
1.2       kristaps  192:        TEXICMD_MINUS,
1.1       kristaps  193:        TEXICMD_MULTITABLE,
                    194:        TEXICMD_NEED,
                    195:        TEXICMD_NEWLINE,
                    196:        TEXICMD_NODE,
                    197:        TEXICMD_NOINDENT,
1.12      kristaps  198:        TEXICMD_O,
                    199:        TEXICMD_OE,
                    200:        TEXICMD_OESMALL,
                    201:        TEXICMD_OGONEK,
1.1       kristaps  202:        TEXICMD_OPTION,
1.12      kristaps  203:        TEXICMD_ORDF,
                    204:        TEXICMD_ORDM,
                    205:        TEXICMD_OSMALL,
1.1       kristaps  206:        TEXICMD_PAGE,
                    207:        TEXICMD_PARINDENT,
1.2       kristaps  208:        TEXICMD_PERIOD,
1.4       kristaps  209:        TEXICMD_PINDEX,
1.13      kristaps  210:        TEXICMD_POUNDS,
1.1       kristaps  211:        TEXICMD_PRINTINDEX,
1.12      kristaps  212:        TEXICMD_PXREF,
                    213:        TEXICMD_QUESTIONDOWN,
                    214:        TEXICMD_QUESTIONMARK,
                    215:        TEXICMD_QUOTATION,
1.13      kristaps  216:        TEXICMD_QUOTEDBLBASE,
                    217:        TEXICMD_QUOTEDBLLEFT,
                    218:        TEXICMD_QUOTEDBLRIGHT,
                    219:        TEXICMD_QUOTESINGLBASE,
                    220:        TEXICMD_QUOTELEFT,
                    221:        TEXICMD_QUOTERIGHT,
1.1       kristaps  222:        TEXICMD_R,
                    223:        TEXICMD_RAISESECTIONS,
                    224:        TEXICMD_REF,
1.4       kristaps  225:        TEXICMD_REFILL,
1.13      kristaps  226:        TEXICMD_REGISTEREDSYMBOL,
1.1       kristaps  227:        TEXICMD_RESULT,
1.12      kristaps  228:        TEXICMD_RINGACCENT,
1.1       kristaps  229:        TEXICMD_SAMP,
                    230:        TEXICMD_SANSSERIF,
                    231:        TEXICMD_SC,
                    232:        TEXICMD_SECTION,
                    233:        TEXICMD_SET,
                    234:        TEXICMD_SETCHAPNEWPAGE,
1.10      kristaps  235:        TEXICMD_SETCONTENTSAFTER,
1.1       kristaps  236:        TEXICMD_SETFILENAME,
                    237:        TEXICMD_SETTITLE,
1.2       kristaps  238:        TEXICMD_SHORTCONTENTS,
1.1       kristaps  239:        TEXICMD_SLANTED,
1.9       kristaps  240:        TEXICMD_SLASH,
1.1       kristaps  241:        TEXICMD_SP,
                    242:        TEXICMD_SPACE,
                    243:        TEXICMD_SMALLBOOK,
                    244:        TEXICMD_SMALLDISPLAY,
                    245:        TEXICMD_SMALLEXAMPLE,
                    246:        TEXICMD_SMALLFORMAT,
                    247:        TEXICMD_SMALLINDENTBLOCK,
                    248:        TEXICMD_SQUIGGLE_LEFT,
                    249:        TEXICMD_SQUIGGLE_RIGHT,
1.10      kristaps  250:        TEXICMD_SS,
1.1       kristaps  251:        TEXICMD_STRONG,
                    252:        TEXICMD_SUBHEADING,
                    253:        TEXICMD_SUBSECTION,
1.4       kristaps  254:        TEXICMD_SUBSUBHEADING,
1.1       kristaps  255:        TEXICMD_SUBSUBSECTION,
                    256:        TEXICMD_SUBTITLE,
1.2       kristaps  257:        TEXICMD_SUMMARYCONTENTS,
1.3       kristaps  258:        TEXICMD_SYNINDEX,
1.1       kristaps  259:        TEXICMD_SYNCODEINDEX,
                    260:        TEXICMD_T,
                    261:        TEXICMD_TAB,
                    262:        TEXICMD_TABSYM,
                    263:        TEXICMD_TABLE,
                    264:        TEXICMD_TEX,
                    265:        TEXICMD_TEXSYM,
1.13      kristaps  266:        TEXICMD_TEXTDEGREE,
1.12      kristaps  267:        TEXICMD_TH,
                    268:        TEXICMD_THSMALL,
1.10      kristaps  269:        TEXICMD_TIE,
1.12      kristaps  270:        TEXICMD_TIEACCENT,
1.1       kristaps  271:        TEXICMD_TILDE,
1.2       kristaps  272:        TEXICMD_TINDEX,
1.1       kristaps  273:        TEXICMD_TITLE,
                    274:        TEXICMD_TITLEFONT,
                    275:        TEXICMD_TITLEPAGE,
                    276:        TEXICMD_TOP,
1.12      kristaps  277:        TEXICMD_U,
                    278:        TEXICMD_UBARACCENT,
                    279:        TEXICMD_UDOTACCENT,
1.1       kristaps  280:        TEXICMD_UMLAUT,
                    281:        TEXICMD_UNNUMBERED,
                    282:        TEXICMD_UNNUMBEREDSEC,
                    283:        TEXICMD_UNNUMBEREDSUBSEC,
                    284:        TEXICMD_UNNUMBEREDSUBSUBSEC,
                    285:        TEXICMD_UREF,
                    286:        TEXICMD_URL,
1.9       kristaps  287:        TEXICMD_USER_INDEX,
1.12      kristaps  288:        TEXICMD_V,
1.1       kristaps  289:        TEXICMD_VALUE,
                    290:        TEXICMD_VAR,
1.8       kristaps  291:        TEXICMD_VERB,
1.2       kristaps  292:        TEXICMD_VERBATIM,
1.1       kristaps  293:        TEXICMD_VERBATIMINCLUDE,
                    294:        TEXICMD_VINDEX,
                    295:        TEXICMD_VSKIP,
                    296:        TEXICMD_VTABLE,
                    297:        TEXICMD_W,
                    298:        TEXICMD_XREF,
                    299:        TEXICMD__MAX
                    300: };
                    301:
1.11      kristaps  302: enum   texisrc {
                    303:        TEXISRC_FILE,
                    304:        TEXISRC_STDIN
                    305: };
                    306:
1.1       kristaps  307: /*
                    308:  * The file currently being parsed.
                    309:  * This keeps track of our location within that file.
                    310:  */
                    311: struct texifile {
1.11      kristaps  312:        enum texisrc     type; /* type of file */
1.1       kristaps  313:        const char      *name; /* name of the file */
                    314:        size_t           line; /* current line (from zero) */
                    315:        size_t           col; /* current column in line (from zero) */
1.15      kristaps  316:        char            *map; /* allocated file buffer */
                    317:        size_t           mapsz; /* size of map */
                    318:        size_t           mapmaxsz; /* full size of map */
1.16      kristaps  319:        size_t           insplice; /* how many bytes left in splice */
1.1       kristaps  320: };
                    321:
                    322: struct texi;
                    323:
                    324: /*
                    325:  * Callback for functions implementing texi commands.
                    326:  */
1.15      kristaps  327: typedef        void (*texicmdfp)(struct texi *, enum texicmd, size_t *);
1.1       kristaps  328:
                    329: /*
                    330:  * Describes Texinfo commands, whether native or overriden.
                    331:  */
                    332: struct texitok {
                    333:        texicmdfp        fp; /* callback (or NULL if none) */
                    334:        const char      *tok; /* name of the token */
                    335:        size_t           len; /* strlen(tok) */
                    336: };
                    337:
1.11      kristaps  338: /*
                    339:  * These values instruct us on whether a list (or table) of some type is
                    340:  * currently being parsed.
                    341:  */
1.1       kristaps  342: enum   texilist {
                    343:        TEXILIST_NONE = 0,
                    344:        TEXILIST_ITEM,
                    345:        TEXILIST_NOITEM,
                    346:        TEXILIST_TABLE
                    347: };
                    348:
1.11      kristaps  349: /*
                    350:  * Hold values assigned with @set and retrieved with @value.
                    351:  * These values can contain arbitrary Texinfo.
                    352:  */
1.1       kristaps  353: struct texivalue {
1.11      kristaps  354:        char            *key; /* the nil-terminated value name */
                    355:        char            *value; /* the nil-terminated value */
1.1       kristaps  356: };
                    357:
1.11      kristaps  358: /*
                    359:  * Macros are (possibly-recursive) Texinfo sequences created with @macro
                    360:  * and filled in by arguments when invoked.
                    361:  */
1.5       kristaps  362: struct teximacro {
1.11      kristaps  363:        char             *key; /* nil-terminated macro name */
                    364:        char             *value; /* nil-terminated value */
                    365:        char            **args; /* array of argument names (or NULL) */
                    366:        size_t            argsz; /* array size */
1.5       kristaps  367: };
                    368:
1.1       kristaps  369: /*
                    370:  * The main parse structure.
                    371:  * This keeps any necessary information handy.
                    372:  */
                    373: struct texi {
                    374:        struct texifile   files[64]; /* stack of open files */
                    375:        size_t            filepos; /* number of open files */
1.4       kristaps  376:        const char       *valstack[64]; /* stack of opened values */
                    377:        size_t            valstackpos; /* position in valstack */
1.1       kristaps  378:        size_t            outcol; /* column in output line */
                    379:        char            **dirs; /* texi directories */
                    380:        size_t            dirsz; /* number of texi directories */
                    381:        char             *title; /* title of document */
                    382:        char             *subtitle; /* subtitle of document */
                    383:        int               secoffs; /* see sectioner() */
1.3       kristaps  384:        char            **indexs; /* @defindex indices */
                    385:        size_t            indexsz; /* entries in indexs */
                    386:        struct texivalue *vals; /* @value entries */
                    387:        size_t            valsz; /* entries in vals */
1.11      kristaps  388:        struct teximacro *macros; /* @macro entries */
                    389:        size_t            macrosz; /* entries in macros */
1.1       kristaps  390:        /*
                    391:         * The following control what we output to the screen.
                    392:         * The complexity is required to accomodate for mdoc(7).
                    393:         */
                    394:        enum texilist     list; /* current list (set recursively) */
                    395:        int               outmacro; /* if >0, output is in line macro */
                    396:        int               seenws; /* ws has been seen (and ignored) */
                    397:        int               seenvs; /* newline has been Pp'd */
                    398:        int               ign; /* if >0, don't print anything */
                    399:        int               literal; /* if >0, literal context */
                    400: };
                    401:
1.15      kristaps  402: #define        BUF(_p) ((_p)->files[(_p)->filepos - 1].map)
                    403: #define        BUFSZ(_p) ((_p)->files[(_p)->filepos - 1].mapsz)
                    404:
1.1       kristaps  405: #define        isws(_x) \
                    406:        (' ' == (_x) || '\t' == (_x))
                    407: #define        ismspace(_x) \
                    408:        (isws((_x)) || '\n' == (_x))
                    409:
                    410: __BEGIN_DECLS
                    411:
1.15      kristaps  412: void   advance(struct texi *, size_t *);
                    413: size_t advanceeoln(struct texi *, size_t *, int);
                    414: void   advanceto(struct texi *, size_t *, size_t);
1.1       kristaps  415:
1.15      kristaps  416: char  **argparse(struct texi *, size_t *, size_t *, size_t);
1.5       kristaps  417:
1.15      kristaps  418: int    parsearg(struct texi *, size_t *, size_t);
                    419: void   parsebracket(struct texi *, size_t *);
1.11      kristaps  420: void   parsestdin(struct texi *);
1.1       kristaps  421: void   parsefile(struct texi *, const char *, int);
1.15      kristaps  422: int    parselinearg(struct texi *, size_t *);
                    423: void   parseeoln(struct texi *, size_t *);
                    424: void   parseto(struct texi *, size_t *, const char *);
1.1       kristaps  425:
1.3       kristaps  426: void   texiabort(struct texi *, const char *)
                    427:                __attribute__((noreturn));
1.1       kristaps  428: enum texicmd
1.15      kristaps  429:        texicmd(struct texi *, size_t,
1.5       kristaps  430:                size_t *, struct teximacro **);
1.1       kristaps  431: void   texierr(struct texi *, const char *, ...)
1.3       kristaps  432:                __attribute__((format(printf, 2, 3)))
                    433:                __attribute__((noreturn));
1.1       kristaps  434: void   texiexit(struct texi *p);
                    435: void   texifilepop(struct texi *);
                    436: void   teximacro(struct texi *, const char *);
                    437: void   teximacroclose(struct texi *);
                    438: void   teximacroopen(struct texi *, const char *);
1.15      kristaps  439: void   texipunctuate(struct texi *, size_t *);
                    440: void   texiputbuf(struct texi *p, size_t, size_t);
1.1       kristaps  441: void   texiputchar(struct texi *p, char);
                    442: void   texiputchars(struct texi *, const char *);
                    443: void   texivspace(struct texi *);
                    444: void   texiwarn(const struct texi *, const char *, ...)
                    445:                __attribute__((format(printf, 2, 3)));
1.15      kristaps  446: void   texisplice(struct texi *, const char *, size_t, size_t *);
1.2       kristaps  447:
                    448: void   valueadd(struct texi *, char *, char *);
                    449: const char *
1.15      kristaps  450:        valueblookup(struct texi *, size_t *);
                    451: void   valuelclear(struct texi *, size_t *);
1.2       kristaps  452: const char *
1.15      kristaps  453:        valuellookup(struct texi *, size_t *);
1.1       kristaps  454:
                    455: extern const struct texitok *const texitoks;
                    456:
                    457: __END_DECLS
                    458:
                    459: #endif

CVSweb