[BACK]Return to action.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/Attic/action.c between version 1.13 and 1.16

version 1.13, 2009/01/20 12:51:28 version 1.16, 2009/01/21 11:35:26
Line 22 
Line 22 
   
 #include "private.h"  #include "private.h"
   
   /*
    * Actions are executed on macros after they've been post-validated: in
    * other words, a macro will not be "acted upon" until all of its
    * children have been filled in (post-fix order).
    */
   
 struct  actions {  struct  actions {
         int     (*post)(struct mdoc *);          int     (*post)(struct mdoc *);
Line 149  const struct actions mdoc_actions[MDOC_MAX] = {
Line 154  const struct actions mdoc_actions[MDOC_MAX] = {
 };  };
   
   
   /*
    * The `Nm' macro sets the document's name when used the first time with
    * an argument.  Subsequent calls without a value will result in the
    * name value being used.
    */
 static int  static int
 post_nm(struct mdoc *mdoc)  post_nm(struct mdoc *mdoc)
 {  {
Line 169  post_nm(struct mdoc *mdoc)
Line 179  post_nm(struct mdoc *mdoc)
 }  }
   
   
   /*
    * We keep track of the current section in order to provide warnings on
    * section ordering, per-section macros, and so on.
    */
 static int  static int
 post_sh(struct mdoc *mdoc)  post_sh(struct mdoc *mdoc)
 {  {
Line 179  post_sh(struct mdoc *mdoc)
Line 193  post_sh(struct mdoc *mdoc)
                 return(1);                  return(1);
         if (xstrlcats(buf, mdoc->last->child, 64)) {          if (xstrlcats(buf, mdoc->last->child, 64)) {
                 if (SEC_CUSTOM != (sec = mdoc_atosec(buf)))                  if (SEC_CUSTOM != (sec = mdoc_atosec(buf)))
                         mdoc->sec_lastn = sec;                          mdoc->lastnamed = sec;
                 mdoc->sec_last = sec;  
                 return(1);                  return(1);
         }          }
   
Line 188  post_sh(struct mdoc *mdoc)
Line 201  post_sh(struct mdoc *mdoc)
 }  }
   
   
   /*
    * Prologue title must be parsed into document meta-data.
    */
 static int  static int
 post_dt(struct mdoc *mdoc)  post_dt(struct mdoc *mdoc)
 {  {
Line 229  post_dt(struct mdoc *mdoc)
Line 245  post_dt(struct mdoc *mdoc)
         if (NULL == mdoc->meta.title)          if (NULL == mdoc->meta.title)
                 mdoc->meta.title = xstrdup("untitled");                  mdoc->meta.title = xstrdup("untitled");
   
           mdoc_msg(mdoc, "title: %s", mdoc->meta.title);
   
         return(post_prologue(mdoc));          return(post_prologue(mdoc));
 }  }
   
   
   /*
    * Prologue operating system must be parsed into document meta-data.
    */
 static int  static int
 post_os(struct mdoc *mdoc)  post_os(struct mdoc *mdoc)
 {  {
Line 246  post_os(struct mdoc *mdoc)
Line 267  post_os(struct mdoc *mdoc)
                 return(mdoc_err(mdoc, "macro parameters too long"));                  return(mdoc_err(mdoc, "macro parameters too long"));
   
         mdoc->meta.os = xstrdup(buf[0] ? buf : "local");          mdoc->meta.os = xstrdup(buf[0] ? buf : "local");
         mdoc->sec_lastn = mdoc->sec_last = SEC_BODY;          mdoc->lastnamed = SEC_BODY;
         mdoc->flags |= MDOC_BODYPARSE;  
   
         return(post_prologue(mdoc));          return(post_prologue(mdoc));
 }  }
   
   
   /*
    * Prologue date must be parsed into document meta-data.
    */
 static int  static int
 post_dd(struct mdoc *mdoc)  post_dd(struct mdoc *mdoc)
 {  {
         char              date[64];          char              buf[64];
         size_t            sz;  
         char             *p;  
         struct mdoc_node *n;  
   
         assert(MDOC_ELEM == mdoc->last->type);          assert(MDOC_ELEM == mdoc->last->type);
         assert(MDOC_Dd == mdoc->last->tok);          assert(MDOC_Dd == mdoc->last->tok);
   
         n = mdoc->last->child;  
         assert(0 == mdoc->meta.date);          assert(0 == mdoc->meta.date);
         date[0] = 0;  
   
         sz = 64;          if ( ! xstrlcats(buf, mdoc->last->child, 64))
                   return(mdoc_err(mdoc, "macro parameters too long"));
           if (0 == (mdoc->meta.date = mdoc_atotime(buf)))
                   return(mdoc_err(mdoc, "invalid parameter syntax"));
   
         for ( ; 0 == mdoc->meta.date && n; n = n->next) {          mdoc_msg(mdoc, "date: %u", mdoc->meta.date);
                 assert(MDOC_TEXT == n->type);  
                 p = n->data.text.string;  
   
                 if (xstrcmp(p, "$Mdocdate$")) {          return(post_prologue(mdoc));
                         mdoc->meta.date = time(NULL);  
                         continue;  
                 } else if (xstrcmp(p, "$")) {  
                         mdoc->meta.date = mdoc_atotime(date);  
                         continue;  
                 } else if (xstrcmp(p, "$Mdocdate:"))  
                         continue;  
   
                 if ( ! xstrlcat(date, n->data.text.string, sz))  
                         return(mdoc_nerr(mdoc, n, "invalid parameter syntax"));  
                 if (n->next && ! xstrlcat(date, " ", sz))  
                         return(mdoc_nerr(mdoc, n, "invalid parameter syntax"));  
         }  
   
         if (mdoc->meta.date && NULL == n)  
                 return(post_prologue(mdoc));  
         else if (n)  
                 return(mdoc_err(mdoc, "invalid parameter syntax"));  
         if ((mdoc->meta.date = mdoc_atotime(date)))  
                 return(post_prologue(mdoc));  
         return(mdoc_err(mdoc, "invalid parameter syntax"));  
 }  }
   
   
   /*
    * The end document shouldn't have the prologue macros as part of the
    * syntax tree (they encompass only meta-data).
    */
 static int  static int
 post_prologue(struct mdoc *mdoc)  post_prologue(struct mdoc *mdoc)
 {  {

Legend:
Removed from v.1.13  
changed lines
  Added in v.1.16

CVSweb