version 1.24, 2015/02/20 09:58:50 |
version 1.25, 2015/02/20 12:25:25 |
Line 71 static void dosymbol(struct texi *, enum texicmd, cons |
|
Line 71 static void dosymbol(struct texi *, enum texicmd, cons |
|
static void dotab(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void dotab(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void dotitle(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void dotitle(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void dovalue(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void dovalue(struct texi *, enum texicmd, const char *, size_t, size_t *); |
|
static void doverb(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void doverbinclude(struct texi *, enum texicmd, const char *, size_t, size_t *); |
static void doverbinclude(struct texi *, enum texicmd, const char *, size_t, size_t *); |
|
|
static const struct texitok __texitoks[TEXICMD__MAX] = { |
static const struct texitok __texitoks[TEXICMD__MAX] = { |
Line 83 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 84 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosection, "appendixsec", 11 }, /* TEXICMD_APPENDIXSEC */ |
{ dosection, "appendixsec", 11 }, /* TEXICMD_APPENDIXSEC */ |
{ dosubsection, "appendixsubsec", 14 }, /* TEXICMD_APPENDIXSUBSEC */ |
{ dosubsection, "appendixsubsec", 14 }, /* TEXICMD_APPENDIXSUBSEC */ |
{ dosubsubsection, "appendixsubsubsec", 17 }, /* TEXICMD_APPENDIXSUBSUBSEC */ |
{ dosubsubsection, "appendixsubsubsec", 17 }, /* TEXICMD_APPENDIXSUBSUBSEC */ |
|
{ doinline, "asis", 4 }, /* TEXICMD_ASIS */ |
{ 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 */ |
Line 138 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 140 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ doinline, "env", 3 }, /* TEXICMD_ENV */ |
{ doinline, "env", 3 }, /* TEXICMD_ENV */ |
{ dosymbol, "error", 5 }, /* TEXICMD_ERROR */ |
{ dosymbol, "error", 5 }, /* TEXICMD_ERROR */ |
{ doexample, "example", 7 }, /* TEXICMD_EXAMPLE */ |
{ doexample, "example", 7 }, /* TEXICMD_EXAMPLE */ |
|
{ doignline, "exdent", 6 }, /* TEXICMD_EXDENT */ |
{ dosymbol, "expansion", 9 }, /* TEXICMD_EXPANSION */ |
{ dosymbol, "expansion", 9 }, /* TEXICMD_EXPANSION */ |
{ doinline, "file", 4 }, /* TEXICMD_FILE */ |
{ doinline, "file", 4 }, /* TEXICMD_FILE */ |
{ doignline, "finalout", 8 }, /* TEXICMD_FINALOUT */ |
{ doignline, "finalout", 8 }, /* TEXICMD_FINALOUT */ |
Line 149 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 152 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosection, "heading", 7 }, /* TEXICMD_HEADING */ |
{ dosection, "heading", 7 }, /* TEXICMD_HEADING */ |
{ doignline, "headings", 8 }, /* TEXICMD_HEADINGS */ |
{ doignline, "headings", 8 }, /* TEXICMD_HEADINGS */ |
{ doitem, "headitem", 8 }, /* TEXICMD_HEADITEM */ |
{ doitem, "headitem", 8 }, /* TEXICMD_HEADITEM */ |
|
{ doignblock, "html", 4 }, /* TEXICMD_HTML */ |
{ dosymbol, "-", 1 }, /* TEXICMD_HYPHEN */ |
{ dosymbol, "-", 1 }, /* TEXICMD_HYPHEN */ |
{ doinline, "i", 1 }, /* TEXICMD_I */ |
{ doinline, "i", 1 }, /* TEXICMD_I */ |
{ dovalue, "ifclear", 7 }, /* TEXICMD_IFCLEAR */ |
{ dovalue, "ifclear", 7 }, /* TEXICMD_IFCLEAR */ |
Line 180 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 184 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosecoffs, "lowersections", 13 }, /* TEXICMD_LOWERSECTIONS */ |
{ dosecoffs, "lowersections", 13 }, /* TEXICMD_LOWERSECTIONS */ |
{ domath, "math", 4 }, /* TEXICMD_MATH */ |
{ domath, "math", 4 }, /* TEXICMD_MATH */ |
{ doignblock, "menu", 4 }, /* TEXICMD_MENU */ |
{ doignblock, "menu", 4 }, /* TEXICMD_MENU */ |
|
{ dosymbol, "minus", 5 }, /* TEXICMD_MINUS */ |
{ domultitable, "multitable", 10 }, /* TEXICMD_MULTITABLE */ |
{ domultitable, "multitable", 10 }, /* TEXICMD_MULTITABLE */ |
{ doignline, "need", 4 }, /* TEXICMD_NEED */ |
{ doignline, "need", 4 }, /* TEXICMD_NEED */ |
{ dosymbol, "\n", 1 }, /* TEXICMD_NEWLINE */ |
{ dosymbol, "\n", 1 }, /* TEXICMD_NEWLINE */ |
Line 190 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 195 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosymbol, "?", 1 }, /* TEXICMD_QUESTIONMARK */ |
{ dosymbol, "?", 1 }, /* TEXICMD_QUESTIONMARK */ |
{ doquotation, "quotation", 9 }, /* TEXICMD_QUOTATION */ |
{ doquotation, "quotation", 9 }, /* TEXICMD_QUOTATION */ |
{ doignline, "page", 4 }, /* TEXICMD_PAGE */ |
{ doignline, "page", 4 }, /* TEXICMD_PAGE */ |
{ doignline, "paragraphindent", 14 }, /* TEXICMD_PARINDENT */ |
{ doignline, "paragraphindent", 15 }, /* TEXICMD_PARINDENT */ |
|
{ dosymbol, ".", 1 }, /* TEXICMD_PERIOD */ |
{ doignline, "printindex", 10 }, /* TEXICMD_PRINTINDEX */ |
{ doignline, "printindex", 10 }, /* TEXICMD_PRINTINDEX */ |
{ doinline, "r", 1 }, /* TEXICMD_R */ |
{ doinline, "r", 1 }, /* TEXICMD_R */ |
{ dosecoffs, "raisesections", 13 }, /* TEXICMD_RAISESECTIONS */ |
{ dosecoffs, "raisesections", 13 }, /* TEXICMD_RAISESECTIONS */ |
Line 204 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 210 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ doignline, "setchapternewpage", 17 }, /* TEXICMD_SETCHAPNEWPAGE */ |
{ doignline, "setchapternewpage", 17 }, /* TEXICMD_SETCHAPNEWPAGE */ |
{ doignline, "setfilename", 11 }, /* TEXICMD_SETFILENAME */ |
{ doignline, "setfilename", 11 }, /* TEXICMD_SETFILENAME */ |
{ dotitle, "settitle", 8 }, /* TEXICMD_SETTITLE */ |
{ dotitle, "settitle", 8 }, /* TEXICMD_SETTITLE */ |
|
{ doignline, "shortcontents", 13 }, /* TEXICMD_SHORTCONTENTS */ |
{ doinline, "slanted", 7 }, /* TEXICMD_SLANTED */ |
{ doinline, "slanted", 7 }, /* TEXICMD_SLANTED */ |
{ dosp, "sp", 2 }, /* TEXICMD_SP */ |
{ dosp, "sp", 2 }, /* TEXICMD_SP */ |
{ dosymbol, " ", 1 }, /* TEXICMD_SPACE */ |
{ dosymbol, " ", 1 }, /* TEXICMD_SPACE */ |
Line 219 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 226 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dosubsection, "subsection", 10 }, /* TEXICMD_SUBSECTION */ |
{ dosubsection, "subsection", 10 }, /* TEXICMD_SUBSECTION */ |
{ dosubsubsection, "subsubsection", 13 }, /* TEXICMD_SUBSUBSECTION */ |
{ dosubsubsection, "subsubsection", 13 }, /* TEXICMD_SUBSUBSECTION */ |
{ doignline, "subtitle", 8 }, /* TEXICMD_SUBTITLE */ |
{ doignline, "subtitle", 8 }, /* TEXICMD_SUBTITLE */ |
|
{ doignline, "summarycontents", 15 }, /* TEXICMD_SUMMARYCONTENTS */ |
{ doignline, "syncodeindex", 12 }, /* TEXICMD_SYNCODEINDEX */ |
{ doignline, "syncodeindex", 12 }, /* TEXICMD_SYNCODEINDEX */ |
{ doinline, "t", 1 }, /* TEXICMD_T */ |
{ doinline, "t", 1 }, /* TEXICMD_T */ |
{ dotab, "tab", 3 }, /* TEXICMD_TAB */ |
{ dotab, "tab", 3 }, /* TEXICMD_TAB */ |
Line 227 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 235 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ doignblock, "tex", 3 }, /* TEXICMD_TEX */ |
{ doignblock, "tex", 3 }, /* TEXICMD_TEX */ |
{ dosymbol, "TeX", 3 }, /* TEXICMD_TEXSYM */ |
{ dosymbol, "TeX", 3 }, /* TEXICMD_TEXSYM */ |
{ doaccent, "~", 1 }, /* TEXICMD_TILDE */ |
{ doaccent, "~", 1 }, /* TEXICMD_TILDE */ |
|
{ doignline, "tindex", 6 }, /* TEXICMD_TINDEX */ |
{ doignline, "title", 5 }, /* TEXICMD_TITLE */ |
{ doignline, "title", 5 }, /* TEXICMD_TITLE */ |
{ dobracket, "titlefont", 9 }, /* TEXICMD_TITLEFONT */ |
{ dobracket, "titlefont", 9 }, /* TEXICMD_TITLEFONT */ |
{ doignblock, "titlepage", 9 }, /* TEXICMD_TITLEPAGE */ |
{ doignblock, "titlepage", 9 }, /* TEXICMD_TITLEPAGE */ |
Line 240 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 249 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
{ dolink, "url", 3 }, /* TEXICMD_URL */ |
{ dolink, "url", 3 }, /* TEXICMD_URL */ |
{ dovalue, "value", 5 }, /* TEXICMD_VALUE */ |
{ dovalue, "value", 5 }, /* TEXICMD_VALUE */ |
{ doinline, "var", 3 }, /* TEXICMD_VAR */ |
{ doinline, "var", 3 }, /* TEXICMD_VAR */ |
|
{ doverb, "verbatim", 8 }, /* TEXICMD_VERBATIM */ |
{ doverbinclude, "verbatiminclude", 15 }, /* TEXICMD_VERBATIMINCLUDE */ |
{ doverbinclude, "verbatiminclude", 15 }, /* TEXICMD_VERBATIMINCLUDE */ |
{ doignline, "vindex", 6 }, /* TEXICMD_VINDEX */ |
{ doignline, "vindex", 6 }, /* TEXICMD_VINDEX */ |
{ dosp, "vskip", 5 }, /* TEXICMD_VSKIP */ |
{ dosp, "vskip", 5 }, /* TEXICMD_VSKIP */ |
Line 251 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
Line 261 static const struct texitok __texitoks[TEXICMD__MAX] = |
|
|
|
const struct texitok *const texitoks = __texitoks; |
const struct texitok *const texitoks = __texitoks; |
|
|
static char * |
|
lineargdup(struct texi *p, const char *buf, size_t sz, size_t *pos) |
|
{ |
|
char *key; |
|
size_t start, end; |
|
|
|
while (*pos < sz && isws(buf[*pos])) |
|
advance(p, buf, pos); |
|
if (*pos == sz) |
|
return(NULL); |
|
for (start = end = *pos; end < sz; end++) |
|
if ('\n' == buf[end]) |
|
break; |
|
advanceto(p, buf, pos, end); |
|
if (*pos < sz) |
|
advance(p, buf, pos); |
|
key = malloc(end - start + 1); |
|
if (NULL == key) { |
|
perror(NULL); |
|
exit(EXIT_FAILURE); |
|
} |
|
memcpy(key, &buf[start], end - start); |
|
key[end - start] = '\0'; |
|
return(key); |
|
} |
|
|
|
static void |
static void |
dodefn(struct texi *p, enum texicmd cmd, |
dodefn(struct texi *p, enum texicmd cmd, |
const char *buf, size_t sz, size_t *pos) |
const char *buf, size_t sz, size_t *pos) |
Line 461 doinline(struct texi *p, enum texicmd cmd, |
|
Line 445 doinline(struct texi *p, enum texicmd cmd, |
|
break; |
break; |
} |
} |
|
|
if (NULL == macro || p->literal) { |
if (NULL == macro || p->literal || TEXILIST_TABLE == p->list) { |
parsebracket(p, buf, sz, pos); |
parsebracket(p, buf, sz, pos); |
return; |
return; |
} |
} |
Line 474 doinline(struct texi *p, enum texicmd cmd, |
|
Line 458 doinline(struct texi *p, enum texicmd cmd, |
|
} |
} |
|
|
static void |
static void |
|
doverb(struct texi *p, enum texicmd cmd, |
|
const char *buf, size_t sz, size_t *pos) |
|
{ |
|
const char *end, *term; |
|
size_t endsz, endpos; |
|
|
|
/* We end at exactly this token. */ |
|
end = "\n@end verbatim\n"; |
|
endsz = strlen(end); |
|
|
|
/* |
|
* Look up where our end token occurs. |
|
* Set our end position based on the relative offset of that |
|
* from our current position. |
|
*/ |
|
term = memmem(&buf[*pos], sz, end, endsz); |
|
endpos = NULL == term ? sz : |
|
*pos + term - &buf[*pos]; |
|
|
|
teximacro(p, "Bd -literal -offset indent"); |
|
assert(endpos <= sz); |
|
/* Run to the point inclusive the endpoint newline. */ |
|
while (*pos < endpos + 1) { |
|
if (*pos > 0 && '.' == buf[*pos]) |
|
if ('\n' == buf[*pos - 1]) |
|
fputs("\\&", stdout); |
|
putchar(buf[*pos]); |
|
if ('\\' == buf[*pos]) |
|
putchar('e'); |
|
advance(p, buf, pos); |
|
} |
|
teximacro(p, "Ed"); |
|
advanceto(p, buf, pos, *pos + endpos + endsz); |
|
} |
|
|
|
static void |
doverbinclude(struct texi *p, enum texicmd cmd, |
doverbinclude(struct texi *p, enum texicmd cmd, |
const char *buf, size_t sz, size_t *pos) |
const char *buf, size_t sz, size_t *pos) |
{ |
{ |
char fname[PATH_MAX], path[PATH_MAX]; |
char fname[PATH_MAX], path[PATH_MAX]; |
int rc; |
int rc; |
size_t i; |
size_t i, end; |
|
const char *v; |
|
enum texicmd type; |
|
|
while (*pos < sz && ' ' == buf[*pos]) |
while (*pos < sz && ' ' == buf[*pos]) |
advance(p, buf, pos); |
advance(p, buf, pos); |
|
|
/* Read in the filename. */ |
for (i = 0; *pos < sz && '\n' != buf[*pos]; ) { |
for (i = 0; *pos < sz && '\n' != buf[*pos]; i++) { |
|
if (i == sizeof(fname) - 1) |
if (i == sizeof(fname) - 1) |
break; |
break; |
fname[i] = buf[*pos]; |
if ('@' != buf[*pos]) { |
advance(p, buf, pos); |
fname[i++] = buf[*pos]; |
|
advance(p, buf, pos); |
|
continue; |
|
} |
|
type = texicmd(p, buf, *pos, sz, &end); |
|
advanceto(p, buf, pos, end); |
|
if (TEXICMD_VALUE != type) |
|
texierr(p, "unknown verbatiminclude command"); |
|
v = valueblookup(p, buf, sz, pos); |
|
if (NULL == v) |
|
continue; |
|
while ('\0' != *v) { |
|
if (i == sizeof(fname) - 1) |
|
break; |
|
fname[i++] = *v++; |
|
} |
|
if ('\0' != *v) |
|
break; |
} |
} |
|
|
if (i == 0) |
if (i == 0) |
|
|
doinclude(struct texi *p, enum texicmd cmd, |
doinclude(struct texi *p, enum texicmd cmd, |
const char *buf, size_t sz, size_t *pos) |
const char *buf, size_t sz, size_t *pos) |
{ |
{ |
char fname[PATH_MAX], path[PATH_MAX]; |
char fname[PATH_MAX], path[PATH_MAX]; |
size_t i; |
size_t i, end; |
int rc; |
int rc; |
|
const char *v; |
|
enum texicmd type; |
|
|
while (*pos < sz && ' ' == buf[*pos]) |
while (*pos < sz && ' ' == buf[*pos]) |
advance(p, buf, pos); |
advance(p, buf, pos); |
|
|
/* Read in the filename. */ |
/* Read in the filename. */ |
for (i = 0; *pos < sz && '\n' != buf[*pos]; i++) { |
for (i = 0; *pos < sz && '\n' != buf[*pos]; ) { |
if (i == sizeof(fname) - 1) |
if (i == sizeof(fname) - 1) |
break; |
break; |
fname[i] = buf[*pos]; |
if ('@' != buf[*pos]) { |
advance(p, buf, pos); |
fname[i++] = buf[*pos]; |
|
advance(p, buf, pos); |
|
continue; |
|
} |
|
type = texicmd(p, buf, *pos, sz, &end); |
|
advanceto(p, buf, pos, end); |
|
if (TEXICMD_VALUE != type) |
|
texierr(p, "unknown include command"); |
|
v = valueblookup(p, buf, sz, pos); |
|
if (NULL == v) |
|
continue; |
|
while ('\0' != *v) { |
|
if (i == sizeof(fname) - 1) |
|
break; |
|
fname[i++] = *v++; |
|
} |
|
if ('\0' != *v) |
|
break; |
} |
} |
|
|
if (i == 0) |
if (i == 0) |
Line 754 dosymbol(struct texi *p, enum texicmd cmd, |
|
Line 811 dosymbol(struct texi *p, enum texicmd cmd, |
|
case (TEXICMD_LATEX): |
case (TEXICMD_LATEX): |
texiputchars(p, "LaTeX"); |
texiputchars(p, "LaTeX"); |
break; |
break; |
|
case (TEXICMD_MINUS): |
|
texiputchars(p, "\\-"); |
|
break; |
|
case (TEXICMD_PERIOD): |
|
texiputchar(p, '.'); |
|
break; |
case (TEXICMD_QUESTIONMARK): |
case (TEXICMD_QUESTIONMARK): |
texiputchar(p, '?'); |
texiputchar(p, '?'); |
break; |
break; |
|
|
dovalue(struct texi *p, enum texicmd cmd, |
dovalue(struct texi *p, enum texicmd cmd, |
const char *buf, size_t sz, size_t *pos) |
const char *buf, size_t sz, size_t *pos) |
{ |
{ |
size_t i, start, end; |
size_t start, end; |
int clr; |
int clr; |
char *key, *val; |
char *key, *val; |
|
const char *cp; |
|
|
if (TEXICMD_SET == cmd) { |
if (TEXICMD_SET == cmd) { |
/* |
|
* If we're going to set a value, then first parse the |
|
* key and value from the input stream. |
|
* Disallow empty keys. |
|
*/ |
|
while (*pos < sz && isws(buf[*pos])) |
while (*pos < sz && isws(buf[*pos])) |
advance(p, buf, pos); |
advance(p, buf, pos); |
for (start = end = *pos; end < sz; end++) |
for (start = end = *pos; end < sz; end++) |
if (ismspace(buf[end])) |
if (ismspace(buf[end])) |
break; |
break; |
|
/* We don't allow empty keys. */ |
if (start == end) |
if (start == end) |
return; |
return; |
|
advanceto(p, buf, pos, end); |
|
|
key = malloc(end - start + 1); |
key = malloc(end - start + 1); |
if (NULL == key) { |
if (NULL == key) { |
Line 856 dovalue(struct texi *p, enum texicmd cmd, |
|
Line 917 dovalue(struct texi *p, enum texicmd cmd, |
|
memcpy(key, &buf[start], end - start); |
memcpy(key, &buf[start], end - start); |
key[end - start] = '\0'; |
key[end - start] = '\0'; |
|
|
advanceto(p, buf, pos, end); |
|
|
|
while (*pos < sz && isws(buf[*pos])) |
while (*pos < sz && isws(buf[*pos])) |
advance(p, buf, pos); |
advance(p, buf, pos); |
for (start = end = *pos; end < sz; end++) |
for (start = end = *pos; end < sz; end++) |
if ('\n' == buf[end]) |
if ('\n' == buf[end]) |
break; |
break; |
|
/* We do allow empty values. */ |
|
advanceeoln(p, buf, sz, pos, 1); |
|
|
val = malloc(end - start + 1); |
val = malloc(end - start + 1); |
if (NULL == val) { |
if (NULL == val) { |
Line 871 dovalue(struct texi *p, enum texicmd cmd, |
|
Line 932 dovalue(struct texi *p, enum texicmd cmd, |
|
} |
} |
memcpy(val, &buf[start], end - start); |
memcpy(val, &buf[start], end - start); |
val[end - start] = '\0'; |
val[end - start] = '\0'; |
|
valueadd(p, key, val); |
/* |
|
* Now look up the key in our table of existing keys. |
|
* If we find it, then free the local key and replace |
|
* the value (freeing the existing) of the existing. |
|
* If not, reallocate the structure. |
|
*/ |
|
for (i = 0; i < p->valsz; i++) |
|
if (0 == strcmp(p->vals[i].key, key)) |
|
break; |
|
|
|
if (i < p->valsz) { |
|
free(key); |
|
free(p->vals[i].value); |
|
p->vals[i].value = val; |
|
} else { |
|
p->vals = realloc(p->vals, |
|
(p->valsz + 1) * |
|
sizeof(struct texivalue)); |
|
if (NULL == p->vals) { |
|
perror(NULL); |
|
exit(EXIT_FAILURE); |
|
} |
|
p->vals[p->valsz].key = key; |
|
p->vals[p->valsz].value = val; |
|
p->valsz++; |
|
} |
|
|
|
advanceeoln(p, buf, sz, pos, 1); |
|
} else if (TEXICMD_VALUE == cmd) { |
} else if (TEXICMD_VALUE == cmd) { |
/* |
|
* First, parse out the key from the stream, which is |
|
* just the material within the quotes. |
|
*/ |
|
while (*pos < sz && '{' != buf[*pos]) |
|
advance(p, buf, pos); |
|
if (*pos == sz) |
|
return; |
|
advance(p, buf, pos); |
|
start = *pos; |
|
while (*pos < sz && '}' != buf[*pos]) |
|
advance(p, buf, pos); |
|
if ((end = *pos) < sz) |
|
advance(p, buf, pos); |
|
|
|
key = malloc(end - start + 1); |
|
if (NULL == key) { |
|
perror(NULL); |
|
exit(EXIT_FAILURE); |
|
} |
|
memcpy(key, &buf[start], end - start); |
|
key[end - start] = '\0'; |
|
|
|
/* |
|
* Next, look up the key in our table. |
|
* If it exists, print it out, being mindful all the |
|
* while of prior whitespace. |
|
* If it doesn't, print out a message. |
|
*/ |
|
for (i = 0; i < p->valsz; i++) |
|
if (0 == strcmp(p->vals[i].key, key)) |
|
break; |
|
if (p->seenws) |
if (p->seenws) |
texiputchar(p, ' '); |
texiputchar(p, ' '); |
p->seenws = 0; |
p->seenws = 0; |
if (i == p->valsz || NULL == p->vals[i].value) { |
if (NULL == (cp = valueblookup(p, buf, sz, pos))) |
texiputchars(p, "{No value for \\(lq"); |
texiputchars(p, "{No value}"); |
texiputchars(p, key); |
else |
texiputchars(p, "\\(rq}"); |
texiputchars(p, cp); |
} else |
|
texiputchars(p, p->vals[i].value); |
|
free(key); |
|
} else if (TEXICMD_CLEAR == cmd) { |
|
key = lineargdup(p, buf, sz, pos); |
|
for (i = 0; i < p->valsz; i++) |
|
if (0 == strcmp(p->vals[i].key, key)) { |
|
free(p->vals[i].value); |
|
p->vals[i].value = NULL; |
|
break; |
|
} |
|
free(key); |
|
} else if (TEXICMD_IFCLEAR == cmd) { |
} else if (TEXICMD_IFCLEAR == cmd) { |
key = lineargdup(p, buf, sz, pos); |
clr = NULL != valuellookup(p, buf, sz, pos); |
for (i = 0; i < p->valsz; i++) |
|
if (0 == strcmp(p->vals[i].key, key)) |
|
break; |
|
free(key); |
|
clr = i < p->valsz && NULL != p->vals[i].value; |
|
if (clr) |
if (clr) |
p->ign++; |
p->ign++; |
parseto(p, buf, sz, pos, texitoks[cmd].tok); |
parseto(p, buf, sz, pos, texitoks[cmd].tok); |
if (clr) |
if (clr) |
p->ign--; |
p->ign--; |
} |
} else if (TEXICMD_CLEAR == cmd) |
|
valuelclear(p, buf, sz, pos); |
} |
} |
|
|
static void |
static void |
Line 1244 domultitable(struct texi *p, enum texicmd cmd, |
|
Line 1229 domultitable(struct texi *p, enum texicmd cmd, |
|
type = texicmd(p, buf, *pos, sz, &end); |
type = texicmd(p, buf, *pos, sz, &end); |
advanceto(p, buf, pos, end); |
advanceto(p, buf, pos, end); |
if (TEXICMD_COLUMNFRACTIONS != type) |
if (TEXICMD_COLUMNFRACTIONS != type) |
texierr(p, "unknown multitable type"); |
texierr(p, "unknown multitable command"); |
while (*pos < sz && '\n' != buf[*pos]) { |
while (*pos < sz && '\n' != buf[*pos]) { |
while (*pos < sz && isws(buf[*pos])) |
while (*pos < sz && isws(buf[*pos])) |
advance(p, buf, pos); |
advance(p, buf, pos); |