summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2008-11-27 14:02:41 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2008-11-27 14:02:41 +0000
commit97bac15e79bcdeafa59295e4c628267f70593cf2 (patch)
tree82d4317caffa08f24580dbd2e7dbe5f61998e81b
parenta14a59e05281ac1ce2fbcea855c1d4101650dd36 (diff)
downloadmandoc-97bac15e79bcdeafa59295e4c628267f70593cf2.tar.gz
mandoc-97bac15e79bcdeafa59295e4c628267f70593cf2.tar.zst
mandoc-97bac15e79bcdeafa59295e4c628267f70593cf2.zip
Added "special" macros.
-rw-r--r--dummy.c141
-rw-r--r--private.h3
-rw-r--r--roff.c23
3 files changed, 107 insertions, 60 deletions
diff --git a/dummy.c b/dummy.c
index 37bf3806..6991ae0c 100644
--- a/dummy.c
+++ b/dummy.c
@@ -1,4 +1,4 @@
-/* $Id: dummy.c,v 1.7 2008/11/26 16:50:34 kristaps Exp $ */
+/* $Id: dummy.c,v 1.8 2008/11/27 14:02:41 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -33,6 +33,9 @@ static int md_dummy_blk_in(int);
static int md_dummy_blk_out(int);
static int md_dummy_text_in(int, int *, char **);
static int md_dummy_text_out(int);
+static int md_dummy_special(int);
+static int md_dummy_head(void);
+static int md_dummy_tail(void);
static void dbg_prologue(const char *);
static void dbg_epilogue(void);
@@ -45,6 +48,61 @@ struct md_dummy {
struct roffcb cb;
};
+
+int
+md_line_dummy(void *arg, char *buf, size_t sz)
+{
+ struct md_dummy *p;
+
+ p = (struct md_dummy *)arg;
+ return(roff_engine(p->tree, buf, sz));
+}
+
+
+int
+md_exit_dummy(void *data, int flush)
+{
+ int c;
+ struct md_dummy *p;
+
+ p = (struct md_dummy *)data;
+ c = roff_free(p->tree, flush);
+ free(p);
+
+ return(c);
+}
+
+
+void *
+md_init_dummy(const struct md_args *args,
+ struct md_mbuf *mbuf, const struct md_rbuf *rbuf)
+{
+ struct md_dummy *p;
+
+ if (NULL == (p = malloc(sizeof(struct md_dummy)))) {
+ warn("malloc");
+ return(NULL);
+ }
+
+ p->cb.roffhead = md_dummy_head;
+ p->cb.rofftail = md_dummy_tail;
+ p->cb.roffin = md_dummy_text_in;
+ p->cb.roffout = md_dummy_text_out;
+ p->cb.roffblkin = md_dummy_blk_in;
+ p->cb.roffblkout = md_dummy_blk_out;
+ p->cb.roffspecial = md_dummy_special;
+
+ p->tree = roff_alloc(args, mbuf, rbuf, &p->cb);
+
+ if (NULL == p->tree) {
+ free(p);
+ return(NULL);
+ }
+
+ return(p);
+}
+
+
static void
dbg_prologue(const char *p)
{
@@ -68,6 +126,34 @@ dbg_epilogue(void)
static int
+md_dummy_head(void)
+{
+
+ return(1);
+}
+
+
+static int
+md_dummy_tail(void)
+{
+
+ return(1);
+}
+
+
+static int
+md_dummy_special(int tok)
+{
+
+ dbg_prologue("noop");
+ (void)strlcat(dbg_line, toknames[tok], sizeof(dbg_line) - 1);
+ dbg_epilogue();
+
+ return(1);
+}
+
+
+static int
md_dummy_blk_in(int tok)
{
@@ -124,56 +210,3 @@ md_dummy_text_out(int tok)
return(1);
}
-
-
-int
-md_line_dummy(void *arg, char *buf, size_t sz)
-{
- struct md_dummy *p;
-
- p = (struct md_dummy *)arg;
- return(roff_engine(p->tree, buf, sz));
-}
-
-
-int
-md_exit_dummy(void *data, int flush)
-{
- int c;
- struct md_dummy *p;
-
- p = (struct md_dummy *)data;
- c = roff_free(p->tree, flush);
- free(p);
-
- return(c);
-}
-
-
-void *
-md_init_dummy(const struct md_args *args,
- struct md_mbuf *mbuf, const struct md_rbuf *rbuf)
-{
- struct md_dummy *p;
-
- if (NULL == (p = malloc(sizeof(struct md_dummy)))) {
- warn("malloc");
- return(NULL);
- }
-
- p->cb.roffhead = NULL;
- p->cb.rofftail = NULL;
- p->cb.roffin = md_dummy_text_in;
- p->cb.roffout = md_dummy_text_out;
- p->cb.roffblkin = md_dummy_blk_in;
- p->cb.roffblkout = md_dummy_blk_out;
-
- p->tree = roff_alloc(args, mbuf, rbuf, &p->cb);
-
- if (NULL == p->tree) {
- free(p);
- return(NULL);
- }
-
- return(p);
-}
diff --git a/private.h b/private.h
index 59f5059f..845e606a 100644
--- a/private.h
+++ b/private.h
@@ -1,4 +1,4 @@
-/* $Id: private.h,v 1.10 2008/11/27 11:23:51 kristaps Exp $ */
+/* $Id: private.h,v 1.11 2008/11/27 14:02:41 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -215,6 +215,7 @@ struct roffcb {
int (*roffout)(int);
int (*roffblkin)(int);
int (*roffblkout)(int);
+ int (*roffspecial)(int);
};
__BEGIN_DECLS
diff --git a/roff.c b/roff.c
index f6eec90f..0bf761f0 100644
--- a/roff.c
+++ b/roff.c
@@ -1,4 +1,4 @@
-/* $Id: roff.c,v 1.10 2008/11/27 13:29:44 kristaps Exp $ */
+/* $Id: roff.c,v 1.11 2008/11/27 14:02:41 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -35,7 +35,9 @@
/* FIXME: ; : } ) (etc.) after text macros? */
-#define ROFF_MAXARG 10
+/* FIXME: NAME section needs specific elements. */
+
+#define ROFF_MAXARG 32
enum roffd {
ROFF_ENTER = 0,
@@ -45,7 +47,8 @@ enum roffd {
enum rofftype {
ROFF_COMMENT,
ROFF_TEXT,
- ROFF_LAYOUT
+ ROFF_LAYOUT,
+ ROFF_SPECIAL
};
#define ROFFCALL_ARGS \
@@ -107,6 +110,7 @@ static int roff_layout(ROFFCALL_ARGS);
static int roff_text(ROFFCALL_ARGS);
static int roff_comment(ROFFCALL_ARGS);
static int roff_close(ROFFCALL_ARGS);
+static int roff_special(ROFFCALL_ARGS);
static struct roffnode *roffnode_new(int, struct rofftree *);
static void roffnode_free(int, struct rofftree *);
@@ -224,7 +228,7 @@ static const struct rofftok tokens[ROFF_MAX] = {
{ NULL, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Bq */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED }, /* Bsx */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED }, /* Bx */
- { NULL, NULL, NULL, NULL, 0, ROFF_TEXT, 0 }, /* Db */ /* XXX */
+ {roff_special, NULL, NULL, NULL, 0, ROFF_SPECIAL, 0 }, /* Db */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Dc */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Do */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Dq */
@@ -251,7 +255,7 @@ static const struct rofftok tokens[ROFF_MAX] = {
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Sc */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* So */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Sq */
- { NULL, NULL, NULL, NULL, 0, ROFF_TEXT, 0 }, /* Sm */
+ {roff_special, NULL, NULL, NULL, 0, ROFF_SPECIAL, 0 }, /* Sm */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Sx */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Sy */
{ roff_text, NULL, NULL, NULL, 0, ROFF_TEXT, ROFF_PARSED | ROFF_CALLABLE }, /* Tn */
@@ -1110,3 +1114,12 @@ roff_close(ROFFCALL_ARGS)
return(1);
}
+
+
+/* ARGSUSED */
+static int
+roff_special(ROFFCALL_ARGS)
+{
+
+ return((*tree->cb->roffspecial)(tok));
+}