summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2009-02-26 16:08:11 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2009-02-26 16:08:11 +0000
commit20e876dc7ef79ecbcf34414dbc1356004ada7c35 (patch)
tree63b03cc2db44baac66ce52e528cdf1457085ef9d
parent6bdbfd3d4d8125256b009166659cdbfa09434ada (diff)
downloadmandoc-20e876dc7ef79ecbcf34414dbc1356004ada7c35.tar.gz
mandoc-20e876dc7ef79ecbcf34414dbc1356004ada7c35.tar.zst
mandoc-20e876dc7ef79ecbcf34414dbc1356004ada7c35.zip
Support for macro widths (/usr/share/tmac/mdoc/doc-common).
-rw-r--r--action.c53
-rw-r--r--private.h3
-rw-r--r--strings.c102
-rw-r--r--term.c24
4 files changed, 173 insertions, 9 deletions
diff --git a/action.c b/action.c
index 203982aa..ec4c9872 100644
--- a/action.c
+++ b/action.c
@@ -1,4 +1,4 @@
-/* $Id: action.c,v 1.19 2009/02/22 14:31:08 kristaps Exp $ */
+/* $Id: action.c,v 1.20 2009/02/26 16:08:11 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -17,7 +17,9 @@
* PERFORMANCE OF THIS SOFTWARE.
*/
#include <assert.h>
+#include <stdio.h>
#include <stdlib.h>
+#include <string.h>
#include <time.h>
#include "private.h"
@@ -34,6 +36,7 @@ struct actions {
/* Per-macro action routines. */
+static int post_bl(struct mdoc *);
static int post_sh(struct mdoc *);
static int post_os(struct mdoc *);
static int post_dt(struct mdoc *);
@@ -56,7 +59,7 @@ const struct actions mdoc_actions[MDOC_MAX] = {
{ NULL }, /* Dl */
{ NULL }, /* Bd */
{ NULL }, /* Ed */
- { NULL }, /* Bl */
+ { post_bl }, /* Bl */
{ NULL }, /* El */
{ NULL }, /* It */
{ NULL }, /* Ad */
@@ -276,6 +279,52 @@ post_os(struct mdoc *mdoc)
/*
+ * Transform -width MACRO values into real widths.
+ */
+static int
+post_bl(struct mdoc *mdoc)
+{
+ struct mdoc_block *bl;
+ size_t i, width;
+ int tok;
+ char buf[32];
+
+ if (MDOC_BLOCK != mdoc->last->type)
+ return(1);
+
+ bl = &mdoc->last->data.block;
+
+ for (i = 0; i < bl->argc; i++)
+ if (MDOC_Width == bl->argv[i].arg)
+ break;
+
+ if (i == bl->argc)
+ return(1);
+
+ assert(1 == bl->argv[i].sz);
+ if (MDOC_MAX == (tok = mdoc_find(mdoc, *bl->argv[i].value)))
+ return(1);
+
+ if (0 == (width = mdoc_macro2len(tok)))
+ return(mdoc_warn(mdoc, WARN_SYNTAX,
+ "-%s macro has no length",
+ mdoc_argnames[MDOC_Width]));
+
+ mdoc_msg(mdoc, "re-writing %s argument: %s -> %zun",
+ mdoc_argnames[MDOC_Width],
+ *bl->argv[i].value, width);
+
+ /* FIXME: silently truncates. */
+ (void)snprintf(buf, sizeof(buf), "%zun", width);
+
+ free(*bl->argv[i].value);
+ *bl->argv[i].value = strdup(buf);
+
+ return(1);
+}
+
+
+/*
* Prologue date must be parsed into document meta-data.
*/
static int
diff --git a/private.h b/private.h
index f78c8922..d334e157 100644
--- a/private.h
+++ b/private.h
@@ -1,4 +1,4 @@
-/* $Id: private.h,v 1.82 2009/02/24 14:52:55 kristaps Exp $ */
+/* $Id: private.h,v 1.83 2009/02/26 16:08:11 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -131,6 +131,7 @@ enum mdoc_msec mdoc_atomsec(const char *);
enum mdoc_vol mdoc_atovol(const char *);
enum mdoc_arch mdoc_atoarch(const char *);
time_t mdoc_atotime(const char *);
+size_t mdoc_macro2len(int);
char *mdoc_type2a(enum mdoc_type);
char *mdoc_node2a(struct mdoc_node *);
diff --git a/strings.c b/strings.c
index 78ff9d9a..5d143492 100644
--- a/strings.c
+++ b/strings.c
@@ -1,4 +1,4 @@
-/* $Id: strings.c,v 1.19 2009/02/25 12:32:50 kristaps Exp $ */
+/* $Id: strings.c,v 1.20 2009/02/26 16:08:11 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -178,9 +178,9 @@ mdoc_atotime(const char *p)
(void)memset(&tm, 0, sizeof(struct tm));
- if (xstrcmp(p, "$Mdocdate: February 25 2009 $"))
+ if (xstrcmp(p, "$Mdocdate: February 26 2009 $"))
return(time(NULL));
- if ((pp = strptime(p, "$Mdocdate: February 25 2009 $", &tm)) && 0 == *pp)
+ if ((pp = strptime(p, "$Mdocdate: February 26 2009 $", &tm)) && 0 == *pp)
return(mktime(&tm));
/* XXX - this matches "June 1999", which is wrong. */
if ((pp = strptime(p, "%b %d %Y", &tm)) && 0 == *pp)
@@ -404,7 +404,7 @@ mdoc_arch2a(enum mdoc_arch arch)
case (ARCH_armish):
return("ARMISH");
case (ARCH_aviion):
- return("AViion");
+ return("AViiON");
case (ARCH_hp300):
return("HP300");
case (ARCH_hppa):
@@ -726,3 +726,97 @@ mdoc_att2a(enum mdoc_att c)
return(p);
}
+
+
+size_t
+mdoc_macro2len(int macro)
+{
+
+ switch (macro) {
+ case(MDOC_Ad):
+ return(12);
+ case(MDOC_Ao):
+ return(12);
+ case(MDOC_An):
+ return(12);
+ case(MDOC_Aq):
+ return(12);
+ case(MDOC_Ar):
+ return(12);
+ case(MDOC_Bo):
+ return(12);
+ case(MDOC_Bq):
+ return(12);
+ case(MDOC_Cd):
+ return(12);
+ case(MDOC_Cm):
+ return(10);
+ case(MDOC_Do):
+ return(10);
+ case(MDOC_Dq):
+ return(12);
+ case(MDOC_Dv):
+ return(12);
+ case(MDOC_Eo):
+ return(12);
+ case(MDOC_Em):
+ return(10);
+ case(MDOC_Er):
+ return(12);
+ case(MDOC_Ev):
+ return(15);
+ case(MDOC_Fa):
+ return(12);
+ case(MDOC_Fl):
+ return(10);
+ case(MDOC_Fo):
+ return(16);
+ case(MDOC_Fn):
+ return(16);
+ case(MDOC_Ic):
+ return(10);
+ case(MDOC_Li):
+ return(16);
+ case(MDOC_Ms):
+ return(6);
+ case(MDOC_Nm):
+ return(10);
+ case(MDOC_No):
+ return(12);
+ case(MDOC_Oo):
+ return(10);
+ case(MDOC_Op):
+ return(14);
+ case(MDOC_Pa):
+ return(32);
+ case(MDOC_Pf):
+ return(12);
+ case(MDOC_Po):
+ return(12);
+ case(MDOC_Pq):
+ return(12);
+ case(MDOC_Ql):
+ return(16);
+ case(MDOC_Qo):
+ return(12);
+ case(MDOC_So):
+ return(12);
+ case(MDOC_Sq):
+ return(12);
+ case(MDOC_Sy):
+ return(6);
+ case(MDOC_Sx):
+ return(16);
+ case(MDOC_Tn):
+ return(10);
+ case(MDOC_Va):
+ return(12);
+ case(MDOC_Vt):
+ return(12);
+ case(MDOC_Xr):
+ return(10);
+ default:
+ break;
+ };
+ return(0);
+}
diff --git a/term.c b/term.c
index 18951322..d3b7d07a 100644
--- a/term.c
+++ b/term.c
@@ -1,4 +1,4 @@
-/* $Id: term.c,v 1.24 2009/02/26 14:56:27 kristaps Exp $ */
+/* $Id: term.c,v 1.25 2009/02/26 16:08:11 kristaps Exp $ */
/*
* Copyright (c) 2009 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -17,6 +17,7 @@
* PERFORMANCE OF THIS SOFTWARE.
*/
#include <assert.h>
+#include <ctype.h>
#include <err.h>
#include <stdio.h>
#include <stdlib.h>
@@ -276,9 +277,29 @@ const struct termact *termacts = __termacts;
static size_t
arg_width(const struct mdoc_arg *arg)
{
+ size_t len, i, v;
/* TODO */
assert(*arg->value);
+ if (0 == strcmp(*arg->value, "indent"))
+ return(INDENT);
+ if (0 == strcmp(*arg->value, "indent-two"))
+ return(INDENT * 2);
+
+ len = strlen(*arg->value);
+ assert(len > 0);
+
+ for (i = 0; i < len - 1; i++)
+ if ( ! isdigit((int)(*arg->value)[i]))
+ break;
+
+ if (i == len - 1) {
+ if ('n' == (*arg->value)[len - 1]) {
+ v = (size_t)atoi(*arg->value);
+ return(v);
+ }
+
+ }
return(strlen(*arg->value));
}
@@ -293,7 +314,6 @@ arg_offset(const struct mdoc_arg *arg)
return(INDENT);
if (0 == strcmp(*arg->value, "indent-two"))
return(INDENT * 2);
-
return(strlen(*arg->value));
}