]> git.cameronkatri.com Git - mandoc.git/blobdiff - mdoc.c
Added new old escape sequence \*[nn].
[mandoc.git] / mdoc.c
diff --git a/mdoc.c b/mdoc.c
index af8a7fcce8802cbf3d24cc12ff02881db4c0b06d..ca3f5752a648092b916352875150daa8c2043bc9 100644 (file)
--- a/mdoc.c
+++ b/mdoc.c
@@ -1,4 +1,4 @@
-/* $Id: mdoc.c,v 1.49 2009/03/01 23:14:15 kristaps Exp $ */
+/* $Id: mdoc.c,v 1.50 2009/03/02 17:14:46 kristaps Exp $ */
 /*
  * Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
  *
 /*
  * Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
  *
@@ -180,6 +180,12 @@ mdoc_endparse(struct mdoc *mdoc)
 }
 
 
 }
 
 
+/*
+ * Main line-parsing routine.  If the line is a macro-line (started with
+ * a '.' control character), then pass along to the parser, which parses
+ * subsequent macros until the end of line.  If normal text, simply
+ * append the entire line to the chain.
+ */
 int
 mdoc_parseln(struct mdoc *mdoc, int line, char *buf)
 {
 int
 mdoc_parseln(struct mdoc *mdoc, int line, char *buf)
 {
@@ -191,20 +197,24 @@ mdoc_parseln(struct mdoc *mdoc, int line, char *buf)
 
        mdoc->linetok = 0;
 
 
        mdoc->linetok = 0;
 
-       /*
-        * FIXME: should puke on whitespace in non-literal displays.
-        */
-
        if ('.' != *buf) {
        if ('.' != *buf) {
+               /*
+                * Free-form text.  Not allowed in the prologue.
+                */
                if (SEC_PROLOGUE == mdoc->lastnamed)
                        return(mdoc_perr(mdoc, line, 0, 
                if (SEC_PROLOGUE == mdoc->lastnamed)
                        return(mdoc_perr(mdoc, line, 0, 
-                               "no text in document prologue"));
+                                       "no text in prologue"));
+
                if ( ! mdoc_word_alloc(mdoc, line, 0, buf))
                        return(0);
                mdoc->next = MDOC_NEXT_SIBLING;
                return(1);
        }
 
                if ( ! mdoc_word_alloc(mdoc, line, 0, buf))
                        return(0);
                mdoc->next = MDOC_NEXT_SIBLING;
                return(1);
        }
 
+       /*
+        * Control-character detected.  Begin the parsing sequence.
+        */
+
        if (buf[1] && '\\' == buf[1])
                if (buf[2] && '\"' == buf[2])
                        return(1);
        if (buf[1] && '\\' == buf[1])
                if (buf[2] && '\"' == buf[2])
                        return(1);
@@ -238,6 +248,7 @@ mdoc_parseln(struct mdoc *mdoc, int line, char *buf)
                mdoc->flags |= MDOC_HALT;
                return(0);
        }
                mdoc->flags |= MDOC_HALT;
                return(0);
        }
+
        return(1);
 }
 
        return(1);
 }