version 1.57, 2015/03/01 16:57:39 |
version 1.64, 2015/03/07 11:49:32 |
Line 42 static void doaccent(struct texi *, enum texicmd, size |
|
Line 42 static void doaccent(struct texi *, enum texicmd, size |
|
static void doblock(struct texi *, enum texicmd, size_t *); |
static void doblock(struct texi *, enum texicmd, size_t *); |
static void dobracket(struct texi *, enum texicmd, size_t *); |
static void dobracket(struct texi *, enum texicmd, size_t *); |
static void dobye(struct texi *, enum texicmd, size_t *); |
static void dobye(struct texi *, enum texicmd, size_t *); |
|
static void docopying(struct texi *, enum texicmd, size_t *); |
static void dodefindex(struct texi *, enum texicmd, size_t *); |
static void dodefindex(struct texi *, enum texicmd, size_t *); |
static void dodefn(struct texi *, enum texicmd, size_t *); |
static void dodefn(struct texi *, enum texicmd, size_t *); |
static void dodisplay(struct texi *, enum texicmd, size_t *); |
static void dodisplay(struct texi *, enum texicmd, size_t *); |
Line 54 static void doignbracket(struct texi *, enum texicmd, |
|
Line 55 static void doignbracket(struct texi *, enum texicmd, |
|
static void doignline(struct texi *, enum texicmd, size_t *); |
static void doignline(struct texi *, enum texicmd, size_t *); |
static void doinline(struct texi *, enum texicmd, size_t *); |
static void doinline(struct texi *, enum texicmd, size_t *); |
static void doinclude(struct texi *, enum texicmd, size_t *); |
static void doinclude(struct texi *, enum texicmd, size_t *); |
|
static void doinsertcopying(struct texi *, enum texicmd, size_t *); |
static void doitem(struct texi *, enum texicmd, size_t *); |
static void doitem(struct texi *, enum texicmd, size_t *); |
static void doitemize(struct texi *, enum texicmd, size_t *); |
static void doitemize(struct texi *, enum texicmd, size_t *); |
static void dolink(struct texi *, enum texicmd, size_t *); |
static void dolink(struct texi *, enum texicmd, size_t *); |
static void domacro(struct texi *, enum texicmd, size_t *); |
static void domacro(struct texi *, enum texicmd, size_t *); |
static void domath(struct texi *, enum texicmd, size_t *); |
static void domath(struct texi *, enum texicmd, size_t *); |
|
#if 0 |
|
static void domenu(struct texi *, enum texicmd, size_t *); |
|
#endif |
static void domultitable(struct texi *, enum texicmd, size_t *); |
static void domultitable(struct texi *, enum texicmd, size_t *); |
static void doquotation(struct texi *, enum texicmd, size_t *); |
static void doquotation(struct texi *, enum texicmd, size_t *); |
static void dotable(struct texi *, enum texicmd, size_t *); |
static void dotable(struct texi *, enum texicmd, size_t *); |
Line 94 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 99 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosymbol, "*", 1 }, /* TEXICMD_ASTERISK */ |
{ dosymbol, "*", 1 }, /* TEXICMD_ASTERISK */ |
{ dosymbol, "@", 1 }, /* TEXICMD_AT */ |
{ dosymbol, "@", 1 }, /* TEXICMD_AT */ |
{ doignline, "author", 6 }, /* TEXICMD_AUTHOR */ |
{ doignline, "author", 6 }, /* TEXICMD_AUTHOR */ |
{ doinline, "b", 1 }, /* TEXICMD_BOLD */ |
{ doinline, "b", 1 }, /* TEXICMD_B */ |
|
{ dosymbol, "\\", 1 }, /* TEXICMD_BACKSLASH */ |
{ dosymbol, "!", 1 }, /* TEXICMD_BANG */ |
{ dosymbol, "!", 1 }, /* TEXICMD_BANG */ |
{ dosymbol, "bullet", 6 }, /* TEXICMD_BULLET */ |
{ dosymbol, "bullet", 6 }, /* TEXICMD_BULLET */ |
{ dobye, "bye", 3 }, /* TEXICMD_BYE */ |
{ dobye, "bye", 3 }, /* TEXICMD_BYE */ |
Line 114 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 120 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ doignline, "c", 1 }, /* TEXICMD_COMMENT */ |
{ doignline, "c", 1 }, /* TEXICMD_COMMENT */ |
{ doignline, "comment", 7 }, /* TEXICMD_COMMENT_LONG */ |
{ doignline, "comment", 7 }, /* TEXICMD_COMMENT_LONG */ |
{ doignline, "contents", 8 }, /* TEXICMD_CONTENTS */ |
{ doignline, "contents", 8 }, /* TEXICMD_CONTENTS */ |
{ doignblock, "copying", 7 }, /* TEXICMD_COPYING */ |
{ docopying, "copying", 7 }, /* TEXICMD_COPYING */ |
{ dosymbol, "copyright", 9 }, /* TEXICMD_COPYRIGHT */ |
{ dosymbol, "copyright", 9 }, /* TEXICMD_COPYRIGHT */ |
{ dodefindex, "defcodeindex", 12 }, /* TEXICMD_DEFCODEINDEX */ |
{ dodefindex, "defcodeindex", 12 }, /* TEXICMD_DEFCODEINDEX */ |
{ dodefn, "deffn", 5 }, /* TEXICMD_DEFFN */ |
{ dodefn, "deffn", 5 }, /* TEXICMD_DEFFN */ |
Line 213 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 219 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dodisplay, "indentblock", 11 }, /* TEXICMD_INDENTBLOCK */ |
{ dodisplay, "indentblock", 11 }, /* TEXICMD_INDENTBLOCK */ |
{ dolink, "indicateurl", 11 }, /* TEXICMD_INDICATEURL */ |
{ dolink, "indicateurl", 11 }, /* TEXICMD_INDICATEURL */ |
{ dolink, "inforef", 7 }, /* TEXICMD_INFOREF */ |
{ dolink, "inforef", 7 }, /* TEXICMD_INFOREF */ |
{ doignline, "insertcopying", 13 }, /* TEXICMD_INSERTCOPYING */ |
{ doinsertcopying, "insertcopying", 13 }, /* TEXICMD_INSERTCOPYING */ |
{ doitem, "item", 4 }, /* TEXICMD_ITEM */ |
{ doitem, "item", 4 }, /* TEXICMD_ITEM */ |
{ doitemize, "itemize", 7 }, /* TEXICMD_ITEMIZE */ |
{ doitemize, "itemize", 7 }, /* TEXICMD_ITEMIZE */ |
{ doitem, "itemx", 5 }, /* TEXICMD_ITEMX */ |
{ doitem, "itemx", 5 }, /* TEXICMD_ITEMX */ |
Line 268 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 274 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ doaccent, "ringaccent", 10 }, /* TEXICMD_RINGACCENT */ |
{ doaccent, "ringaccent", 10 }, /* TEXICMD_RINGACCENT */ |
{ doinline, "samp", 4 }, /* TEXICMD_SAMP */ |
{ doinline, "samp", 4 }, /* TEXICMD_SAMP */ |
{ doinline, "sansserif", 9 }, /* TEXICMD_SANSSERIF */ |
{ doinline, "sansserif", 9 }, /* TEXICMD_SANSSERIF */ |
{ dobracket, "sc", 2 }, /* TEXICMD_SC */ |
{ doinline, "sc", 2 }, /* TEXICMD_SC */ |
{ dosection, "section", 7 }, /* TEXICMD_SECTION */ |
{ dosection, "section", 7 }, /* TEXICMD_SECTION */ |
{ dovalue, "set", 3 }, /* TEXICMD_SET */ |
{ dovalue, "set", 3 }, /* TEXICMD_SET */ |
{ doignline, "setchapternewpage", 17 }, /* TEXICMD_SETCHAPNEWPAGE */ |
{ doignline, "setchapternewpage", 17 }, /* TEXICMD_SETCHAPNEWPAGE */ |
Line 341 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 347 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
|
|
const struct texitok *const texitoks = __texitoks; |
const struct texitok *const texitoks = __texitoks; |
|
|
|
/* |
|
* Texinfo has lots of indexes. |
|
* You can add new ones in a variety of ways. |
|
* We maintain an array of all of these index names (usually a few |
|
* letters) and pass unknown commands through the array list. |
|
*/ |
static void |
static void |
dodefindex(struct texi *p, enum texicmd cmd, size_t *pos) |
dodefindex(struct texi *p, enum texicmd cmd, size_t *pos) |
{ |
{ |
Line 349 dodefindex(struct texi *p, enum texicmd cmd, size_t *p |
|
Line 361 dodefindex(struct texi *p, enum texicmd cmd, size_t *p |
|
|
|
while (*pos < BUFSZ(p) && isws(BUF(p)[*pos])) |
while (*pos < BUFSZ(p) && isws(BUF(p)[*pos])) |
advance(p, pos); |
advance(p, pos); |
|
|
start = end = *pos; |
start = end = *pos; |
while (end < BUFSZ(p) && ! ismspace(BUF(p)[end])) |
while (end < BUFSZ(p) && ! ismspace(BUF(p)[end])) |
end++; |
end++; |
Line 357 dodefindex(struct texi *p, enum texicmd cmd, size_t *p |
|
Line 368 dodefindex(struct texi *p, enum texicmd cmd, size_t *p |
|
if (start == end) { |
if (start == end) { |
advanceeoln(p, pos, 1); |
advanceeoln(p, pos, 1); |
return; |
return; |
} else if (NULL == (cp = malloc(end - start + 1))) |
} |
|
|
|
if (NULL == (cp = malloc(end - start + 1))) |
texiabort(p, NULL); |
texiabort(p, NULL); |
|
|
memcpy(cp, &BUF(p)[start], end - start); |
memcpy(cp, &BUF(p)[start], end - start); |
cp[end - start] = '\0'; |
cp[end - start] = '\0'; |
|
|
|
/* FIXME: use reallocarray(). */ |
p->indexs = realloc(p->indexs, |
p->indexs = realloc(p->indexs, |
sizeof(char *) * (p->indexsz + 1)); |
sizeof(char *) * (p->indexsz + 1)); |
|
|
if (NULL == p->indexs) |
if (NULL == p->indexs) |
texiabort(p, NULL); |
texiabort(p, NULL); |
p->indexs[p->indexsz++] = cp; |
p->indexs[p->indexsz++] = cp; |
|
|
|
advanceeoln(p, pos, 1); |
} |
} |
|
|
static void |
static void |
Line 533 dodefn(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 547 dodefn(struct texi *p, enum texicmd cmd, size_t *pos) |
|
break; |
break; |
} |
} |
teximacro(p, "Bd -filled -offset indent"); |
teximacro(p, "Bd -filled -offset indent"); |
p->seenvs = 1; |
|
parseto(p, pos, blk); |
parseto(p, pos, blk); |
teximacro(p, "Ed"); |
teximacro(p, "Ed"); |
|
p->seenvs = 1; |
} |
} |
|
|
static void |
static void |
Line 725 doinline(struct texi *p, enum texicmd cmd, size_t *pos |
|
Line 739 doinline(struct texi *p, enum texicmd cmd, size_t *pos |
|
} |
} |
|
|
if (NULL == macro || p->literal || TEXILIST_TABLE == p->list) { |
if (NULL == macro || p->literal || TEXILIST_TABLE == p->list) { |
|
if (TEXICMD_SC == cmd) |
|
p->uppercase++; |
parsebracket(p, pos, 0); |
parsebracket(p, pos, 0); |
|
if (TEXICMD_SC == cmd) |
|
p->uppercase--; |
return; |
return; |
} |
} |
|
|
|
/* |
|
* If we haven't seen any whitespace, then we don't want the |
|
* subsequent macro to insert any whitespace. |
|
*/ |
|
if (p->outmacro && 0 == p->seenws) { |
|
teximacroopen(p, "Ns"); |
|
teximacroclose(p); |
|
} |
|
|
teximacroopen(p, macro); |
teximacroopen(p, macro); |
p->seenws = 0; |
p->seenws = 0; |
|
if (TEXICMD_CODE == cmd) |
|
p->literal++; |
|
if (TEXICMD_SC == cmd) |
|
p->uppercase++; |
parsebracket(p, pos, 0); |
parsebracket(p, pos, 0); |
|
if (TEXICMD_SC == cmd) |
|
p->uppercase--; |
|
if (TEXICMD_CODE == cmd) |
|
p->literal--; |
texipunctuate(p, pos); |
texipunctuate(p, pos); |
teximacroclose(p); |
teximacroclose(p); |
} |
} |
Line 775 doverb(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 810 doverb(struct texi *p, enum texicmd cmd, size_t *pos) |
|
} |
} |
|
|
static void |
static void |
|
doinsertcopying(struct texi *p, enum texicmd cmd, size_t *pos) |
|
{ |
|
|
|
advanceeoln(p, pos, 0); |
|
if (NULL == p->copying) |
|
return; |
|
texisplice(p, p->copying, p->copyingsz, *pos); |
|
} |
|
|
|
static void |
|
docopying(struct texi *p, enum texicmd cmd, size_t *pos) |
|
{ |
|
const char *end, *term; |
|
size_t endsz, endpos; |
|
|
|
/* We retain our starting (but not ending) newlines. */ |
|
end = "\n@end copying\n"; |
|
endsz = strlen(end); |
|
advanceeoln(p, pos, 0); |
|
if (*pos == BUFSZ(p)) { |
|
texiwarn(p, "unterminated \"%s\"", texitoks[cmd].tok); |
|
return; |
|
} |
|
|
|
term = memmem(&BUF(p)[*pos], BUFSZ(p) - *pos, end, endsz); |
|
if (NULL == term) { |
|
texiwarn(p, "unterminated \"%s\"", texitoks[cmd].tok); |
|
endpos = BUFSZ(p); |
|
} else |
|
endpos = *pos + (size_t)(term - &BUF(p)[*pos]); |
|
|
|
assert(endpos <= BUFSZ(p)); |
|
assert('\n' == BUF(p)[*pos]); |
|
advance(p, pos); |
|
|
|
p->copying = malloc(endpos - *pos + 1); |
|
p->copyingsz = endpos - *pos; |
|
memcpy(p->copying, &BUF(p)[*pos], p->copyingsz); |
|
p->copying[endpos - *pos] = '\0'; |
|
|
|
while (*pos < endpos) |
|
advance(p, pos); |
|
if (*pos < BUFSZ(p)) |
|
advanceto(p, pos, endpos + endsz); |
|
} |
|
|
|
static void |
doverbatim(struct texi *p, enum texicmd cmd, size_t *pos) |
doverbatim(struct texi *p, enum texicmd cmd, size_t *pos) |
{ |
{ |
const char *end, *term; |
const char *end, *term; |
Line 785 doverbatim(struct texi *p, enum texicmd cmd, size_t *p |
|
Line 867 doverbatim(struct texi *p, enum texicmd cmd, size_t *p |
|
endsz = strlen(end); |
endsz = strlen(end); |
advanceeoln(p, pos, 0); |
advanceeoln(p, pos, 0); |
if (*pos == BUFSZ(p)) { |
if (*pos == BUFSZ(p)) { |
texiwarn(p, "unexpected end of file"); |
texiwarn(p, "unterminated \"%s\"", texitoks[cmd].tok); |
return; |
return; |
} |
} |
|
|
term = memmem(&BUF(p)[*pos], BUFSZ(p) - *pos, end, endsz); |
term = memmem(&BUF(p)[*pos], BUFSZ(p) - *pos, end, endsz); |
if (NULL == term) { |
if (NULL == term) { |
texiwarn(p, "unterminated verbatim block"); |
texiwarn(p, "unterminated \"%s\"", texitoks[cmd].tok); |
endpos = BUFSZ(p); |
endpos = BUFSZ(p); |
} else |
} else |
endpos = *pos + (size_t)(term - &BUF(p)[*pos]); |
endpos = *pos + (size_t)(term - &BUF(p)[*pos]); |
Line 805 doverbatim(struct texi *p, enum texicmd cmd, size_t *p |
|
Line 887 doverbatim(struct texi *p, enum texicmd cmd, size_t *p |
|
advance(p, pos); |
advance(p, pos); |
} |
} |
teximacro(p, "Ed"); |
teximacro(p, "Ed"); |
|
p->seenvs = 1; |
if (*pos < BUFSZ(p)) |
if (*pos < BUFSZ(p)) |
advanceto(p, pos, endpos + endsz); |
advanceto(p, pos, endpos + endsz); |
} |
} |
Line 954 dodisplay(struct texi *p, enum texicmd cmd, size_t *po |
|
Line 1037 dodisplay(struct texi *p, enum texicmd cmd, size_t *po |
|
break; |
break; |
} |
} |
|
|
p->seenvs = 1; |
|
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
teximacro(p, "Ed"); |
teximacro(p, "Ed"); |
|
p->seenvs = 1; |
} |
} |
|
|
static void |
static void |
Line 970 doexample(struct texi *p, enum texicmd cmd, size_t *po |
|
Line 1053 doexample(struct texi *p, enum texicmd cmd, size_t *po |
|
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
p->literal--; |
p->literal--; |
teximacro(p, "Ed"); |
teximacro(p, "Ed"); |
|
p->seenvs = 1; |
} |
} |
|
|
static void |
static void |
Line 1196 dosymbol(struct texi *p, enum texicmd cmd, size_t *pos |
|
Line 1280 dosymbol(struct texi *p, enum texicmd cmd, size_t *pos |
|
case (TEXICMD_AT): |
case (TEXICMD_AT): |
texiputchar(p, '@'); |
texiputchar(p, '@'); |
break; |
break; |
|
case (TEXICMD_BACKSLASH): |
|
texiputchar(p, '\\'); |
|
break; |
case (TEXICMD_BANG): |
case (TEXICMD_BANG): |
texiputchar(p, '!'); |
texiputchar(p, '!'); |
break; |
break; |
Line 1367 doquotation(struct texi *p, enum texicmd cmd, size_t * |
|
Line 1454 doquotation(struct texi *p, enum texicmd cmd, size_t * |
|
teximacro(p, "Qc"); |
teximacro(p, "Qc"); |
} |
} |
|
|
|
#if 0 |
static void |
static void |
|
domenu(struct texi *p, enum texicmd cmd, size_t *pos) |
|
{ |
|
size_t start; |
|
|
|
if (NULL != p->chapters) { |
|
doignblock(p, cmd, pos); |
|
return; |
|
} |
|
|
|
advanceeoln(p, pos, 1); |
|
|
|
teximacro(p, "Bl -tag -width Ds"); |
|
while (*pos < BUFSZ(p)) { |
|
/* Read to next menu item. */ |
|
while (*pos < BUFSZ(p) && ismspace(BUF(p)[*pos])) |
|
advance(p, pos); |
|
if ('*' != BUF(p)[*pos]) |
|
break; |
|
|
|
assert('*' == BUF(p)[*pos]); |
|
advance(p, pos); |
|
while (*pos < BUFSZ(p) && ismspace(BUF(p)[*pos])) |
|
advance(p, pos); |
|
start = *pos; |
|
while (*pos < BUFSZ(p) && ':' != BUF(p)[*pos]) |
|
advance(p, pos); |
|
if (*pos == BUFSZ(p) || *pos == start) { |
|
texiwarn(p, "empty menu name"); |
|
break; |
|
} |
|
teximacroopen(p, "It"); |
|
teximacroopen(p, "Sx"); |
|
for ( ; start < *pos; start++) |
|
texiputchar(p, BUF(p)[start]); |
|
teximacroclose(p); |
|
teximacroclose(p); |
|
|
|
advance(p, pos); |
|
if (*pos == BUFSZ(p)) { |
|
texiwarn(p, "bad menu syntax"); |
|
break; |
|
} else if (':' != BUF(p)[*pos]) { |
|
while (*pos < BUFSZ(p) && isws(BUF(p)[*pos])) |
|
advance(p, pos); |
|
start = *pos; |
|
while (*pos < BUFSZ(p)) { |
|
switch (BUF(p)[*pos]) { |
|
case ('\t'): |
|
case ('\n'): |
|
case (','): |
|
break; |
|
case ('.'): |
|
if (*pos + 1 == BUFSZ(p)) { |
|
advance(p, pos); |
|
continue; |
|
} |
|
if (' ' == BUF(p)[*pos + 1]) { |
|
advance(p, pos); |
|
break; |
|
} |
|
/* FALLTHROUGH */ |
|
default: |
|
advance(p, pos); |
|
continue; |
|
} |
|
advance(p, pos); |
|
break; |
|
} |
|
} else |
|
advance(p, pos); |
|
|
|
while (*pos < BUFSZ(p) && isws(BUF(p)[*pos])) |
|
advance(p, pos); |
|
|
|
if (*pos == BUFSZ(p)) { |
|
texiwarn(p, "bad menu syntax"); |
|
break; |
|
} |
|
|
|
while (*pos < BUFSZ(p)) { |
|
if ('*' == BUF(p)[*pos]) |
|
break; |
|
if ('\n' != BUF(p)[*pos]) { |
|
texiputchar(p, BUF(p)[*pos]); |
|
advance(p, pos); |
|
continue; |
|
} |
|
advance(p, pos); |
|
while (*pos == BUFSZ(p)) { |
|
texiwarn(p, "bad menu syntax"); |
|
break; |
|
} |
|
if ('\n' == BUF(p)[*pos]) { |
|
advance(p, pos); |
|
break; |
|
} else if ('*' == BUF(p)[*pos]) { |
|
continue; |
|
} else if ('@' == BUF(p)[*pos]) |
|
break; |
|
texiputchar(p, ' '); |
|
} |
|
} |
|
|
|
teximacro(p, "El"); |
|
|
|
doignblock(p, cmd, pos); |
|
} |
|
#endif |
|
|
|
static void |
domath(struct texi *p, enum texicmd cmd, size_t *pos) |
domath(struct texi *p, enum texicmd cmd, size_t *pos) |
{ |
{ |
|
|
Line 1590 dosection(struct texi *p, enum texicmd cmd, size_t *po |
|
Line 1788 dosection(struct texi *p, enum texicmd cmd, size_t *po |
|
teximacroopen(p, sects[sec]); |
teximacroopen(p, sects[sec]); |
parseeoln(p, pos); |
parseeoln(p, pos); |
teximacroclose(p); |
teximacroclose(p); |
p->seenvs = 1; |
|
} |
} |
|
|
static void |
static void |
Line 1622 doitem(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 1819 doitem(struct texi *p, enum texicmd cmd, size_t *pos) |
|
|
|
/* Multitable is using raw tbl(7). */ |
/* Multitable is using raw tbl(7). */ |
if (TEXILIST_TABLE == p->list) { |
if (TEXILIST_TABLE == p->list) { |
texiputchar(p, '\n'); |
if (p->outcol > 0) |
|
texiputchar(p, '\n'); |
return; |
return; |
} |
} |
|
|
Line 1644 doitem(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 1842 doitem(struct texi *p, enum texicmd cmd, size_t *pos) |
|
} |
} |
|
|
/* Trick so we don't start with Pp. */ |
/* Trick so we don't start with Pp. */ |
p->seenvs = 1; |
|
parseeoln(p, pos); |
parseeoln(p, pos); |
|
|
if (TEXILIST_ITEM == p->list) |
if (TEXILIST_ITEM == p->list) |
Line 1658 dotab(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 1855 dotab(struct texi *p, enum texicmd cmd, size_t *pos) |
|
{ |
{ |
|
|
/* This command is only useful in @multitable. */ |
/* This command is only useful in @multitable. */ |
if (TEXILIST_TABLE == p->list) |
if (TEXILIST_TABLE == p->list && p->outcol) |
texiputchar(p, '\t'); |
texiputchar(p, '\t'); |
} |
} |
|
|
Line 1670 domultitable(struct texi *p, enum texicmd cmd, size_t |
|
Line 1867 domultitable(struct texi *p, enum texicmd cmd, size_t |
|
enum texicmd type; |
enum texicmd type; |
size_t i, end, columns; |
size_t i, end, columns; |
|
|
|
texivspace(p); |
p->list = TEXILIST_TABLE; |
p->list = TEXILIST_TABLE; |
/* |
/* |
* TS/TE blocks aren't "in mdoc(7)", so we can disregard the |
* TS/TE blocks aren't "in mdoc(7)", so we can disregard the |
Line 1723 domultitable(struct texi *p, enum texicmd cmd, size_t |
|
Line 1921 domultitable(struct texi *p, enum texicmd cmd, size_t |
|
texiputchar(p, ' '); |
texiputchar(p, ' '); |
texiputchar(p, 'l'); |
texiputchar(p, 'l'); |
} |
} |
texiputchars(p, ".\n"); |
|
|
texiputchar(p, '.'); |
|
texiputchar(p, '\n'); |
p->outmacro++; |
p->outmacro++; |
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
p->outmacro--; |
p->outmacro--; |
Line 1741 dotable(struct texi *p, enum texicmd cmd, size_t *pos) |
|
Line 1941 dotable(struct texi *p, enum texicmd cmd, size_t *pos) |
|
|
|
p->list = TEXILIST_ITEM; |
p->list = TEXILIST_ITEM; |
teximacro(p, "Bl -tag -width Ds"); |
teximacro(p, "Bl -tag -width Ds"); |
p->seenvs = 1; |
|
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
teximacro(p, "El"); |
teximacro(p, "El"); |
|
p->seenvs = 1; |
p->list = sv; |
p->list = sv; |
} |
} |
|
|
Line 1772 doenumerate(struct texi *p, enum texicmd cmd, size_t * |
|
Line 1972 doenumerate(struct texi *p, enum texicmd cmd, size_t * |
|
|
|
p->list = TEXILIST_NOITEM; |
p->list = TEXILIST_NOITEM; |
teximacro(p, "Bl -enum"); |
teximacro(p, "Bl -enum"); |
p->seenvs = 1; |
|
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
teximacro(p, "El"); |
teximacro(p, "El"); |
|
p->seenvs = 1; |
p->list = sv; |
p->list = sv; |
} |
} |
|
|
Line 1787 doitemize(struct texi *p, enum texicmd cmd, size_t *po |
|
Line 1987 doitemize(struct texi *p, enum texicmd cmd, size_t *po |
|
|
|
p->list = TEXILIST_NOITEM; |
p->list = TEXILIST_NOITEM; |
teximacro(p, "Bl -bullet"); |
teximacro(p, "Bl -bullet"); |
p->seenvs = 1; |
|
parseto(p, pos, texitoks[cmd].tok); |
parseto(p, pos, texitoks[cmd].tok); |
teximacro(p, "El"); |
teximacro(p, "El"); |
|
p->seenvs = 1; |
p->list = sv; |
p->list = sv; |
} |
} |
|
|