]> git.cameronkatri.com Git - mandoc.git/blobdiff - roff_html.c
Create the link from ./man to ./mandoc in the "all" target rather than
[mandoc.git] / roff_html.c
index aec483e441212910ae86e0ec9993f30b60ffda90..3cc7c19a8a511a1e049bb9b3e396013f9a7f2198 100644 (file)
@@ -1,7 +1,7 @@
-/*     $Id: roff_html.c,v 1.14 2018/12/13 11:55:47 schwarze Exp $ */
+/* $Id: roff_html.c,v 1.21 2020/06/22 19:20:40 schwarze Exp $ */
 /*
  * Copyright (c) 2010 Kristaps Dzonsons <kristaps@bsd.lv>
 /*
  * Copyright (c) 2010 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2014, 2017, 2018 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2014, 2017, 2018, 2019 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
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */
+#include "config.h"
+
 #include <sys/types.h>
 
 #include <assert.h>
 #include <sys/types.h>
 
 #include <assert.h>
-#include <stddef.h>
+#include <stdio.h>
+#include <string.h>
 
 
+#include "mandoc.h"
 #include "roff.h"
 #include "out.h"
 #include "html.h"
 #include "roff.h"
 #include "out.h"
 #include "html.h"
@@ -30,14 +34,19 @@ typedef     void    (*roff_html_pre_fp)(ROFF_HTML_ARGS);
 
 static void      roff_html_pre_br(ROFF_HTML_ARGS);
 static void      roff_html_pre_ce(ROFF_HTML_ARGS);
 
 static void      roff_html_pre_br(ROFF_HTML_ARGS);
 static void      roff_html_pre_ce(ROFF_HTML_ARGS);
+static void      roff_html_pre_fi(ROFF_HTML_ARGS);
+static void      roff_html_pre_ft(ROFF_HTML_ARGS);
+static void      roff_html_pre_nf(ROFF_HTML_ARGS);
 static void      roff_html_pre_sp(ROFF_HTML_ARGS);
 
 static const roff_html_pre_fp roff_html_pre_acts[ROFF_MAX] = {
        roff_html_pre_br,  /* br */
        roff_html_pre_ce,  /* ce */
 static void      roff_html_pre_sp(ROFF_HTML_ARGS);
 
 static const roff_html_pre_fp roff_html_pre_acts[ROFF_MAX] = {
        roff_html_pre_br,  /* br */
        roff_html_pre_ce,  /* ce */
-       NULL,  /* ft */
+       roff_html_pre_fi,  /* fi */
+       roff_html_pre_ft,  /* ft */
        NULL,  /* ll */
        NULL,  /* mc */
        NULL,  /* ll */
        NULL,  /* mc */
+       roff_html_pre_nf,  /* nf */
        NULL,  /* po */
        roff_html_pre_ce,  /* rj */
        roff_html_pre_sp,  /* sp */
        NULL,  /* po */
        roff_html_pre_ce,  /* rj */
        roff_html_pre_sp,  /* sp */
@@ -74,8 +83,37 @@ roff_html_pre_ce(ROFF_HTML_ARGS)
        roff_html_pre_br(h, n);
 }
 
        roff_html_pre_br(h, n);
 }
 
+static void
+roff_html_pre_fi(ROFF_HTML_ARGS)
+{
+       if (html_fillmode(h, TOKEN_NONE) == ROFF_fi)
+               print_otag(h, TAG_BR, "");
+}
+
+static void
+roff_html_pre_ft(ROFF_HTML_ARGS)
+{
+       const char      *cp;
+
+       cp = n->child->string;
+       html_setfont(h, mandoc_font(cp, (int)strlen(cp)));
+}
+
+static void
+roff_html_pre_nf(ROFF_HTML_ARGS)
+{
+       if (html_fillmode(h, TOKEN_NONE) == ROFF_nf)
+               print_otag(h, TAG_BR, "");
+}
+
 static void
 roff_html_pre_sp(ROFF_HTML_ARGS)
 {
 static void
 roff_html_pre_sp(ROFF_HTML_ARGS)
 {
-       print_paragraph(h);
+       if (html_fillmode(h, TOKEN_NONE) == ROFF_nf) {
+               h->col++;
+               print_endline(h);
+       } else {
+               html_close_paragraph(h);
+               print_otag(h, TAG_P, "c", "Pp");
+       }
 }
 }