version 1.16, 2008/11/30 21:41:35 |
version 1.20, 2008/12/09 17:09:12 |
|
|
#include <string.h> |
#include <string.h> |
#include <unistd.h> |
#include <unistd.h> |
|
|
#include "libmdocml.h" |
|
#include "private.h" |
#include "private.h" |
|
|
#define BUFFER_LINE BUFSIZ /* Default line-buffer size. */ |
|
|
|
static int md_run_enter(const struct md_args *, |
static int md_run_enter(const struct md_args *, |
struct md_mbuf *, struct md_rbuf *, void *); |
struct md_mbuf *, struct md_rbuf *, void *); |
static int md_run_leave(const struct md_args *, struct md_mbuf *, |
static int md_run_leave(const struct md_args *, struct md_mbuf *, |
Line 139 md_run_leave(const struct md_args *args, struct md_mbu |
|
Line 136 md_run_leave(const struct md_args *args, struct md_mbu |
|
|
|
/* Run exiters. */ |
/* Run exiters. */ |
switch (args->type) { |
switch (args->type) { |
case (MD_HTML4_STRICT): |
case (MD_HTML): |
if ( ! md_exit_html4_strict(data, -1 == c ? 0 : 1)) |
if ( ! md_exit_html(data, -1 == c ? 0 : 1)) |
c = -1; |
c = -1; |
break; |
break; |
default: |
default: |
Line 150 md_run_leave(const struct md_args *args, struct md_mbu |
|
Line 147 md_run_leave(const struct md_args *args, struct md_mbu |
|
} |
} |
|
|
/* Make final flush of buffer. */ |
/* Make final flush of buffer. */ |
if ( ! md_buf_flush(mbuf)) |
if (-1 != c && ! md_buf_flush(mbuf)) |
return(-1); |
return(-1); |
|
|
return(c); |
return(c); |
Line 162 md_run_enter(const struct md_args *args, struct md_mbu |
|
Line 159 md_run_enter(const struct md_args *args, struct md_mbu |
|
struct md_rbuf *rbuf, void *p) |
struct md_rbuf *rbuf, void *p) |
{ |
{ |
ssize_t sz, i; |
ssize_t sz, i; |
char line[BUFFER_LINE]; |
|
size_t pos; |
size_t pos; |
|
char line[MD_LINE]; |
md_line fp; |
md_line fp; |
|
|
assert(args); |
assert(args); |
Line 172 md_run_enter(const struct md_args *args, struct md_mbu |
|
Line 169 md_run_enter(const struct md_args *args, struct md_mbu |
|
|
|
/* Function ptrs to line-parsers. */ |
/* Function ptrs to line-parsers. */ |
switch (args->type) { |
switch (args->type) { |
case (MD_HTML4_STRICT): |
case (MD_HTML): |
fp = md_line_html4_strict; |
fp = md_line_html; |
break; |
break; |
default: |
default: |
fp = md_line_xml; |
fp = md_line_xml; |
|
|
return(md_run_leave(args, mbuf, rbuf, 0, p)); |
return(md_run_leave(args, mbuf, rbuf, 0, p)); |
|
|
for (i = 0; i < sz; i++) { |
for (i = 0; i < sz; i++) { |
/* |
|
if ( ! isascii(rbuf->buf[i])) { |
|
warnx("%s: non-ascii char (line %zu, col %zu)", |
|
rbuf->name, rbuf->line, pos); |
|
return(md_run_leave(args, mbuf, rbuf, -1, p)); |
|
} |
|
*/ |
|
if ('\n' != rbuf->buf[i]) { |
if ('\n' != rbuf->buf[i]) { |
if (pos < BUFFER_LINE) { |
if (pos < MD_LINE) { |
/* LINTED */ |
/* LINTED */ |
line[pos++] = rbuf->buf[i]; |
rbuf->linebuf[pos++] = rbuf->buf[i]; |
continue; |
continue; |
} |
} |
warnx("%s: line %zu too long", |
warnx("%s: line %zu too long", |
|
|
return(md_run_leave(args, mbuf, rbuf, -1, p)); |
return(md_run_leave(args, mbuf, rbuf, -1, p)); |
} |
} |
|
|
line[(int)pos] = 0; |
rbuf->linebuf[(int)pos] = 0; |
|
(void)memcpy(line, rbuf->linebuf, sizeof(line)); |
if ( ! (*fp)(p, line)) |
if ( ! (*fp)(p, line)) |
return(md_run_leave(args, mbuf, rbuf, -1, p)); |
return(md_run_leave(args, mbuf, rbuf, -1, p)); |
rbuf->line++; |
rbuf->line++; |
Line 242 md_run(const struct md_args *args, |
|
Line 233 md_run(const struct md_args *args, |
|
|
|
/* Run initialisers. */ |
/* Run initialisers. */ |
switch (args->type) { |
switch (args->type) { |
case (MD_HTML4_STRICT): |
case (MD_HTML): |
data = md_init_html4_strict |
data = md_init_html(args, &mbuf, &rbuf); |
(args, &mbuf, &rbuf); |
|
break; |
break; |
default: |
default: |
data = md_init_xml(args, &mbuf, &rbuf); |
data = md_init_xml(args, &mbuf, &rbuf); |