X-Git-Url: https://git.cameronkatri.com/mandoc.git/blobdiff_plain/04a9a9421c92d037b140f8d5d2c2b7a496b95f8f..7d393d45bdff6d0d4a4742e71d0c6997150410be:/xml.c diff --git a/xml.c b/xml.c index 607a87cb..8d73301b 100644 --- a/xml.c +++ b/xml.c @@ -1,4 +1,4 @@ -/* $Id: xml.c,v 1.16 2008/12/05 19:45:15 kristaps Exp $ */ +/* $Id: xml.c,v 1.23 2008/12/10 10:43:57 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -20,7 +20,6 @@ #include #include -#include "libmdocml.h" #include "private.h" #include "ml.h" @@ -34,11 +33,17 @@ static ssize_t xml_begintag(struct md_mbuf *, void *, const struct md_args *, enum md_ns, int, const int *, const char **); +static ssize_t xml_beginstring(struct md_mbuf *, + const struct md_args *, + const char *, size_t); +static ssize_t xml_endstring(struct md_mbuf *, + const struct md_args *, + const char *, size_t); static int xml_begin(struct md_mbuf *, const struct md_args *, const struct tm *, const char *, const char *, - const char *, const char *); + enum roffmsec, enum roffvol); static int xml_end(struct md_mbuf *, const struct md_args *); static ssize_t xml_printtagname(struct md_mbuf *, @@ -58,10 +63,13 @@ xml_printtagargs(struct md_mbuf *mbuf, const int *argc, return(0); assert(argc && argv); + /* LINTED */ for (res = 0, i = 0; ROFF_ARGMAX != (c = argc[i]); i++) { if ( ! ml_nputs(mbuf, " ", 1, &res)) return(-1); + /* FIXME: should puke on some, no? */ + if ( ! ml_puts(mbuf, tokargnames[c], &res)) return(-1); if ( ! ml_nputs(mbuf, "=\"", 2, &res)) @@ -116,15 +124,15 @@ xml_printtagname(struct md_mbuf *mbuf, enum md_ns ns, int tok) static int xml_begin(struct md_mbuf *mbuf, const struct md_args *args, const struct tm *tm, const char *os, - const char *title, const char *section, - const char *vol) + const char *title, enum roffmsec sec, enum roffvol vol) { if ( ! ml_puts(mbuf, "\n", NULL)) return(0); return(ml_puts(mbuf, "", NULL)); } @@ -138,6 +146,28 @@ xml_end(struct md_mbuf *mbuf, const struct md_args *args) } +/* ARGSUSED */ +static ssize_t +xml_beginstring(struct md_mbuf *mbuf, + const struct md_args *args, + const char *buf, size_t sz) +{ + + return(0); +} + + +/* ARGSUSED */ +static ssize_t +xml_endstring(struct md_mbuf *mbuf, + const struct md_args *args, + const char *buf, size_t sz) +{ + + return(0); +} + + /* ARGSUSED */ static ssize_t xml_begintag(struct md_mbuf *mbuf, void *data, @@ -169,6 +199,7 @@ int xml_alloc(void **p) { + *p = NULL; return(1); } @@ -210,6 +241,8 @@ md_init_xml(const struct md_args *args, cbs.ml_endtag = xml_endtag; cbs.ml_begin = xml_begin; cbs.ml_end = xml_end; + cbs.ml_beginstring = xml_beginstring; + cbs.ml_endstring = xml_endstring; return(mlg_alloc(args, rbuf, mbuf, &cbs)); }