summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2011-01-25 12:16:22 +0000
committerIngo Schwarze <schwarze@openbsd.org>2011-01-25 12:16:22 +0000
commit034659ec17379196818c8a75030d9d0de3daee04 (patch)
tree99e31fc0b888ec001953e405d2ed95b6d8697dbd
parent85cfe8e76ee75394eb9ad586bebf1ba8904c4f9b (diff)
downloadmandoc-034659ec17379196818c8a75030d9d0de3daee04.tar.gz
Do not skip data after horizontal lines in the layout.
Instead, let one line of input data add two new spans to the tbl tree during one single call of tbl_data(). Note that this causes the horizontal line to get parsed into the tbl tree, but not yet used in the output, which will be fixed next. Avoids data loss in cpu(4/hppa). ok kristaps@
-rw-r--r--tbl_data.c60
1 files changed, 44 insertions, 16 deletions
diff --git a/tbl_data.c b/tbl_data.c
index 1a0d06ff..75ed0612 100644
--- a/tbl_data.c
+++ b/tbl_data.c
@@ -1,6 +1,7 @@
/* $Id$ */
/*
- * Copyright (c) 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
+ * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
+ * Copyright (c) 2011 Ingo Schwarze <schwarze@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
@@ -30,6 +31,8 @@
static int data(struct tbl_node *, struct tbl_span *,
int, const char *, int *);
+static struct tbl_span *newspan(struct tbl_node *, struct tbl_row *);
+
static int
data(struct tbl_node *tbl, struct tbl_span *dp,
@@ -172,6 +175,27 @@ tbl_cdata(struct tbl_node *tbl, int ln, const char *p)
return(0);
}
+static struct tbl_span *
+newspan(struct tbl_node *tbl, struct tbl_row *rp)
+{
+ struct tbl_span *dp;
+
+ dp = mandoc_calloc(1, sizeof(struct tbl_span));
+ dp->tbl = &tbl->opts;
+ dp->layout = rp;
+ dp->head = tbl->first_head;
+
+ if (tbl->last_span) {
+ tbl->last_span->next = dp;
+ tbl->last_span = dp;
+ } else {
+ tbl->last_span = tbl->first_span = dp;
+ dp->flags |= TBL_SPAN_FIRST;
+ }
+
+ return(dp);
+}
+
int
tbl_data(struct tbl_node *tbl, int ln, const char *p)
{
@@ -196,9 +220,24 @@ tbl_data(struct tbl_node *tbl, int ln, const char *p)
if (tbl->last_span) {
assert(tbl->last_span->layout);
- if (tbl->last_span->pos == TBL_SPAN_DATA)
- rp = tbl->last_span->layout->next;
- else
+ if (tbl->last_span->pos == TBL_SPAN_DATA) {
+ for (rp = tbl->last_span->layout->next;
+ rp && rp->first; rp = rp->next) {
+ switch (rp->first->pos) {
+ case (TBL_CELL_HORIZ):
+ dp = newspan(tbl, rp);
+ dp->pos = TBL_SPAN_HORIZ;
+ continue;
+ case (TBL_CELL_DHORIZ):
+ dp = newspan(tbl, rp);
+ dp->pos = TBL_SPAN_DHORIZ;
+ continue;
+ default:
+ break;
+ }
+ break;
+ }
+ } else
rp = tbl->last_span->layout;
if (NULL == rp)
@@ -208,18 +247,7 @@ tbl_data(struct tbl_node *tbl, int ln, const char *p)
assert(rp);
- dp = mandoc_calloc(1, sizeof(struct tbl_span));
- dp->tbl = &tbl->opts;
- dp->layout = rp;
- dp->head = tbl->first_head;
-
- if (tbl->last_span) {
- tbl->last_span->next = dp;
- tbl->last_span = dp;
- } else {
- tbl->last_span = tbl->first_span = dp;
- dp->flags |= TBL_SPAN_FIRST;
- }
+ dp = newspan(tbl, rp);
if ( ! strcmp(p, "_")) {
dp->pos = TBL_SPAN_HORIZ;