aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2018-08-18 16:44:55 +0000
committerIngo Schwarze <schwarze@openbsd.org>2018-08-18 16:44:55 +0000
commitd88097f26ac5c01fd8ce0480ac8da79069610527 (patch)
treef653bd3f548b3392921657c6a7fa8492488a57fe
parent8fdf9729d1541e56cdc60db11e1db3db347140b9 (diff)
downloadmandoc-d88097f26ac5c01fd8ce0480ac8da79069610527.tar.gz
mandoc-d88097f26ac5c01fd8ce0480ac8da79069610527.tar.zst
mandoc-d88097f26ac5c01fd8ce0480ac8da79069610527.zip
Do not allocate a column for decimal points if all numbers are integers.
-rw-r--r--out.c12
-rw-r--r--tbl_term.c12
2 files changed, 10 insertions, 14 deletions
diff --git a/out.c b/out.c
index b2b64378..eacfcb4f 100644
--- a/out.c
+++ b/out.c
@@ -1,7 +1,7 @@
-/* $Id: out.c,v 1.70 2017/06/27 18:25:02 schwarze Exp $ */
+/* $Id: out.c,v 1.71 2018/08/18 16:44:55 schwarze Exp $ */
/*
* Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2011, 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2011,2014,2015,2017,2018 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
@@ -320,7 +320,7 @@ tblcalc_number(struct rofftbl *tbl, struct roffcol *col,
const struct tbl_opts *opts, const struct tbl_dat *dp)
{
int i;
- size_t sz, psz, ssz, d;
+ size_t sz, ssz, d;
const char *str;
char *cp;
char buf[2];
@@ -342,17 +342,15 @@ tblcalc_number(struct rofftbl *tbl, struct roffcol *col,
buf[0] = opts->decimal;
buf[1] = '\0';
- psz = (*tbl->slen)(buf, tbl->arg);
-
if (NULL != (cp = strrchr(str, opts->decimal))) {
buf[1] = '\0';
for (ssz = 0, i = 0; cp != &str[i]; i++) {
buf[0] = str[i];
ssz += (*tbl->slen)(buf, tbl->arg);
}
- d = ssz + psz;
+ d = ssz;
} else
- d = sz + psz;
+ d = sz;
/* Adjust the settings for this column. */
diff --git a/tbl_term.c b/tbl_term.c
index c154a0e9..3dda00d1 100644
--- a/tbl_term.c
+++ b/tbl_term.c
@@ -1,7 +1,7 @@
-/* $Id: tbl_term.c,v 1.57 2017/07/31 16:14:10 schwarze Exp $ */
+/* $Id: tbl_term.c,v 1.58 2018/08/18 16:44:55 schwarze Exp $ */
/*
* Copyright (c) 2009, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2011,2012,2014,2015,2017 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2011-2018 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
@@ -621,7 +621,7 @@ tbl_number(struct termp *tp, const struct tbl_opts *opts,
{
char *cp;
char buf[2];
- size_t sz, psz, ssz, d, padl;
+ size_t sz, ssz, d, padl;
int i;
/*
@@ -636,16 +636,14 @@ tbl_number(struct termp *tp, const struct tbl_opts *opts,
buf[0] = opts->decimal;
buf[1] = '\0';
- psz = term_strlen(tp, buf);
-
if ((cp = strrchr(dp->string, opts->decimal)) != NULL) {
for (ssz = 0, i = 0; cp != &dp->string[i]; i++) {
buf[0] = dp->string[i];
ssz += term_strlen(tp, buf);
}
- d = ssz + psz;
+ d = ssz;
} else
- d = sz + psz;
+ d = sz;
if (col->decimal > d && col->width > sz) {
padl = col->decimal - d;