summaryrefslogtreecommitdiffstatshomepage
path: root/libmdocml.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2008-12-08 16:29:57 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2008-12-08 16:29:57 +0000
commit4cfe3bb512af4b91885cb7ab426ab406a4882ebb (patch)
treec5ce1f7d1bf7591de2bfd56afaff2ac5ed874a3b /libmdocml.c
parentfc4521dc8c1b84bf19e7b81d0eb40e925cd097c1 (diff)
downloadmandoc-4cfe3bb512af4b91885cb7ab426ab406a4882ebb.tar.gz
mandoc-4cfe3bb512af4b91885cb7ab426ab406a4882ebb.tar.zst
mandoc-4cfe3bb512af4b91885cb7ab426ab406a4882ebb.zip
*** empty log message ***
Diffstat (limited to 'libmdocml.c')
-rw-r--r--libmdocml.c20
1 files changed, 6 insertions, 14 deletions
diff --git a/libmdocml.c b/libmdocml.c
index f419c1f5..2bec7e93 100644
--- a/libmdocml.c
+++ b/libmdocml.c
@@ -1,4 +1,4 @@
-/* $Id: libmdocml.c,v 1.18 2008/12/03 14:39:59 kristaps Exp $ */
+/* $Id: libmdocml.c,v 1.19 2008/12/08 16:29:57 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -28,8 +28,6 @@
#include "libmdocml.h"
#include "private.h"
-#define BUFFER_LINE BUFSIZ /* Default line-buffer size. */
-
static int md_run_enter(const struct md_args *,
struct md_mbuf *, struct md_rbuf *, void *);
static int md_run_leave(const struct md_args *, struct md_mbuf *,
@@ -162,8 +160,8 @@ md_run_enter(const struct md_args *args, struct md_mbuf *mbuf,
struct md_rbuf *rbuf, void *p)
{
ssize_t sz, i;
- char line[BUFFER_LINE];
size_t pos;
+ char line[MD_LINE];
md_line fp;
assert(args);
@@ -192,17 +190,10 @@ again:
return(md_run_leave(args, mbuf, rbuf, 0, p));
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 (pos < BUFFER_LINE) {
+ if (pos < MD_LINE) {
/* LINTED */
- line[pos++] = rbuf->buf[i];
+ rbuf->linebuf[pos++] = rbuf->buf[i];
continue;
}
warnx("%s: line %zu too long",
@@ -210,7 +201,8 @@ again:
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))
return(md_run_leave(args, mbuf, rbuf, -1, p));
rbuf->line++;