]> git.cameronkatri.com Git - mandoc.git/blobdiff - mdoc_strings.c
Remove the pod2man table entries. They can now be properly read and
[mandoc.git] / mdoc_strings.c
index 9007fa3208c885661775a6e95a60b12cddbf7213..e7ced1fe1b37e496ab3627e46e85e77cffb0cb6d 100644 (file)
@@ -1,6 +1,6 @@
-/*     $Id: mdoc_strings.c,v 1.16 2010/04/03 12:46:35 kristaps Exp $ */
+/*     $Id: mdoc_strings.c,v 1.24 2010/07/31 23:52:58 schwarze Exp $ */
 /*
 /*
- * Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
+ * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
  *
  * 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
 #include <string.h>
 #include <time.h>
 
 #include <string.h>
 #include <time.h>
 
+#include "mandoc.h"
 #include "libmdoc.h"
 
 #include "libmdoc.h"
 
-/* FIXME: this file is poorly named. */
-
-struct mdoc_secname {
-       const char      *name;  /* Name of section. */
-       enum mdoc_sec    sec;   /* Corresponding section. */
-};
-
-#define        SECNAME_MAX     (20)
-
-static const struct mdoc_secname secnames[SECNAME_MAX] = {
-       { "NAME", SEC_NAME },
-       { "LIBRARY", SEC_LIBRARY },
-       { "SYNOPSIS", SEC_SYNOPSIS },
-       { "DESCRIPTION", SEC_DESCRIPTION },
-       { "IMPLEMENTATION NOTES", SEC_IMPLEMENTATION },
-       { "EXIT STATUS", SEC_EXIT_STATUS },
-       { "RETURN VALUES", SEC_RETURN_VALUES },
-       { "ENVIRONMENT", SEC_ENVIRONMENT },
-       { "FILES", SEC_FILES },
-       { "EXAMPLES", SEC_EXAMPLES },
-       { "DIAGNOSTICS", SEC_DIAGNOSTICS },
-       { "COMPATIBILITY", SEC_COMPATIBILITY },
-       { "ERRORS", SEC_ERRORS },
-       { "SEE ALSO", SEC_SEE_ALSO },
-       { "STANDARDS", SEC_STANDARDS },
-       { "HISTORY", SEC_HISTORY },
-       { "AUTHORS", SEC_AUTHORS },
-       { "CAVEATS", SEC_CAVEATS },
-       { "BUGS", SEC_BUGS },
-       { "SECURITY CONSIDERATIONS", SEC_SECURITY }
+static const char * const secnames[SEC__MAX] = {
+       NULL,
+       "NAME",
+       "LIBRARY",
+       "SYNOPSIS",
+       "DESCRIPTION",
+       "IMPLEMENTATION NOTES",
+       "RETURN VALUES",
+       "ENVIRONMENT",
+       "FILES",
+       "EXIT STATUS",
+       "EXAMPLES",
+       "DIAGNOSTICS",
+       "COMPATIBILITY",
+       "ERRORS",
+       "SEE ALSO",
+       "STANDARDS",
+       "HISTORY",
+       "AUTHORS",
+       "CAVEATS",
+       "BUGS",
+       "SECURITY CONSIDERATIONS",
+       NULL
 };
 
 };
 
-
 /* 
  * FIXME: this is repeated in print_text() (html.c) and term_word()
  * (term.c).
  */
 /* 
  * FIXME: this is repeated in print_text() (html.c) and term_word()
  * (term.c).
  */
-int
+enum mdelim
 mdoc_iscdelim(char p)
 {
 
        switch (p) {
 mdoc_iscdelim(char p)
 {
 
        switch (p) {
-       case('|'): /* FIXME! */
-               /* FALLTHROUGH */
        case('('):
                /* FALLTHROUGH */
        case('['):
        case('('):
                /* FALLTHROUGH */
        case('['):
-               return(1);
+               return(DELIM_OPEN);
+       case('|'):
+               return(DELIM_MIDDLE);
        case('.'):
                /* FALLTHROUGH */
        case(','):
        case('.'):
                /* FALLTHROUGH */
        case(','):
@@ -91,35 +84,41 @@ mdoc_iscdelim(char p)
        case(')'):
                /* FALLTHROUGH */
        case(']'):
        case(')'):
                /* FALLTHROUGH */
        case(']'):
-               return(2);
+               return(DELIM_CLOSE);
        default:
                break;
        }
 
        default:
                break;
        }
 
-       return(0);
+       return(DELIM_NONE);
 }
 
 
 }
 
 
-int
+enum mdelim
 mdoc_isdelim(const char *p)
 {
 
 mdoc_isdelim(const char *p)
 {
 
-       if (0 == *p)
-               return(0);
-       if (0 != *(p + 1))
-               return(0);
-       return(mdoc_iscdelim(*p));
+       if ('\0' == p[0])
+               return(DELIM_NONE);
+       if ('\0' == p[1])
+               return(mdoc_iscdelim(p[0]));
+
+       /*
+        * XXX; account for groff bubu where the \*(Ba reserved string
+        * is treated in exactly the same way as the vertical bar.  This
+        * is the only function that checks for this.
+        */
+       return(strcmp(p, "\\*(Ba") ? DELIM_NONE : DELIM_MIDDLE);
 }
 
 
 enum mdoc_sec 
 }
 
 
 enum mdoc_sec 
-mdoc_atosec(const char *p)
+mdoc_str2sec(const char *p)
 {
        int              i;
 
 {
        int              i;
 
-       for (i = 0; i < SECNAME_MAX; i++) 
-               if (0 == strcmp(p, secnames[i].name))
-                       return(secnames[i].sec);
+       for (i = 0; i < (int)SEC__MAX; i++) 
+               if (secnames[i] && 0 == strcmp(p, secnames[i]))
+                       return((enum mdoc_sec)i);
 
        return(SEC_CUSTOM);
 }
 
        return(SEC_CUSTOM);
 }
@@ -127,7 +126,7 @@ mdoc_atosec(const char *p)
 
 /* FIXME: move this into an editable .in file. */
 size_t
 
 /* FIXME: move this into an editable .in file. */
 size_t
-mdoc_macro2len(int macro)
+mdoc_macro2len(enum mdoct macro)
 {
 
        switch (macro) {
 {
 
        switch (macro) {