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

Diff for /mandoc/man_macro.c between version 1.5 and 1.10

version 1.5, 2009/03/25 15:17:49 version 1.10, 2009/03/27 14:56:15
Line 18 
Line 18 
  */   */
 #include <assert.h>  #include <assert.h>
 #include <ctype.h>  #include <ctype.h>
 #include <err.h> /* XXX */  
 #include <stdlib.h>  #include <stdlib.h>
 #include <stdio.h>  #include <stdio.h>
 #include <string.h>  #include <string.h>
   
 #include "libman.h"  #include "libman.h"
   
   #define FL_NLINE        (1 << 0)
   #define FL_TLINE        (1 << 1)
   
 static  int              man_args(struct man *, int,  static  int              man_args(struct man *, int,
                                 int *, char *, char **);                                  int *, char *, char **);
   
   static  int man_flags[MAN_MAX] = {
           0, /* __ */
           0, /* TH */
           0, /* SH */
           0, /* SS */
           FL_TLINE, /* TP */
           0, /* LP */
           0, /* PP */
           0, /* P */
           0, /* IP */
           0, /* HP */
           FL_NLINE, /* SM */
           FL_NLINE, /* SB */
           FL_NLINE, /* BI */
           FL_NLINE, /* IB */
           FL_NLINE, /* BR */
           FL_NLINE, /* RB */
           FL_NLINE, /* R */
           FL_NLINE, /* B */
           FL_NLINE, /* I */
           FL_NLINE, /* IR */
           FL_NLINE, /* RI */
           0, /* br */
   };
   
 int  int
 man_macro(struct man *man, int tok, int line,  man_macro(struct man *man, int tok, int line,
Line 56  man_macro(struct man *man, int tok, int line, 
Line 82  man_macro(struct man *man, int tok, int line, 
                 man->next = MAN_NEXT_SIBLING;                  man->next = MAN_NEXT_SIBLING;
         }          }
   
         for ( ; man->last && man->last != n;          if (n == man->last && (FL_NLINE & man_flags[tok])) {
                         man->last = man->last->parent)                  if (MAN_NLINE & man->flags)
                           return(man_verr(man, line, ppos,
                                   "next-line scope already open"));
                   man->flags |= MAN_NLINE;
                   return(1);
           }
   
           if (FL_TLINE & man_flags[tok]) {
                   if (MAN_NLINE & man->flags)
                           return(man_verr(man, line, ppos,
                                   "next-line scope already open"));
                   man->flags |= MAN_NLINE;
                   return(1);
           }
   
           /*
            * Note that when TH is pruned, we'll be back at the root, so
            * make sure that we don't clobber as its sibling.
            */
   
           for ( ; man->last; man->last = man->last->parent) {
                   if (man->last == n)
                           break;
                   if (man->last->type == MAN_ROOT)
                           break;
                 if ( ! man_valid_post(man))                  if ( ! man_valid_post(man))
                         return(0);                          return(0);
                   if ( ! man_action_post(man))
                           return(0);
           }
   
         assert(man->last);          assert(man->last);
         if ( ! man_valid_post(man))  
           /*
            * Same here regarding whether we're back at the root.
            */
   
           if (man->last->type != MAN_ROOT && ! man_valid_post(man))
                 return(0);                  return(0);
         man->next = MAN_NEXT_SIBLING;          if (man->last->type != MAN_ROOT && ! man_action_post(man))
                   return(0);
           if (man->last->type != MAN_ROOT)
                   man->next = MAN_NEXT_SIBLING;
   
         return(1);          return(1);
 }  }
Line 74  int
Line 135  int
 man_macroend(struct man *m)  man_macroend(struct man *m)
 {  {
   
         /* TODO: validate & actions. */          for ( ; m->last && m->last != m->first;
                           m->last = m->last->parent) {
                   if ( ! man_valid_post(m))
                           return(0);
                   if ( ! man_action_post(m))
                           return(0);
           }
           assert(m->last == m->first);
   
           if ( ! man_valid_post(m))
                   return(0);
           if ( ! man_action_post(m))
                   return(0);
   
         return(1);          return(1);
 }  }
   
   
 /* ARGSUSED */  /* ARGSUSED */
 static int  static int
 man_args(struct man *man, int line,  man_args(struct man *m, int line,
                 int *pos, char *buf, char **v)                  int *pos, char *buf, char **v)
 {  {
   
Line 114  man_args(struct man *man, int line, 
Line 188  man_args(struct man *man, int line, 
                 if (buf[*pos])                  if (buf[*pos])
                         return(1);                          return(1);
   
                 warnx("tail whitespace");                  if ( ! man_vwarn(m, line, *pos, "trailing spaces"))
                 return(-1);                          return(-1);
   
                   return(1);
         }          }
   
         /*          /*
Line 130  man_args(struct man *man, int line, 
Line 206  man_args(struct man *man, int line, 
                 (*pos)++;                  (*pos)++;
   
         if (0 == buf[*pos]) {          if (0 == buf[*pos]) {
                 warnx("unterminated quotation");                  if ( ! man_vwarn(m, line, *pos, "unterminated quote"))
                 return(-1);                          return(-1);
                   return(1);
         }          }
   
         buf[(*pos)++] = 0;          buf[(*pos)++] = 0;
Line 144  man_args(struct man *man, int line, 
Line 221  man_args(struct man *man, int line, 
         if (buf[*pos])          if (buf[*pos])
                 return(1);                  return(1);
   
         warnx("tail whitespace");          if ( ! man_vwarn(m, line, *pos, "trailing spaces"))
         return(-1);                  return(-1);
           return(1);
 }  }

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.10

CVSweb