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

Diff for /mandoc/man_validate.c between version 1.10 and 1.11

version 1.10, 2009/06/16 19:55:28 version 1.11, 2009/06/18 10:32:00
Line 23 
Line 23 
   
 #include "libman.h"  #include "libman.h"
   
 /* FIXME: validate text. */  
   
 #define POSTARGS  struct man *m, const struct man_node *n  #define POSTARGS  struct man *m, const struct man_node *n
   
   enum    merr {
           WPRINT
   };
   
 typedef int     (*v_post)(POSTARGS);  typedef int     (*v_post)(POSTARGS);
   
 struct  man_valid {  struct  man_valid {
         v_post   *posts;          v_post   *posts;
 };  };
   
 static  int       count(const struct man_node *);  
 static  int       check_eq0(POSTARGS);  static  int       check_eq0(POSTARGS);
 static  int       check_ge1(POSTARGS);  static  int       check_ge1(POSTARGS);
 static  int       check_ge2(POSTARGS);  static  int       check_ge2(POSTARGS);
 static  int       check_le1(POSTARGS);  static  int       check_le1(POSTARGS);
 static  int       check_le2(POSTARGS);  static  int       check_le2(POSTARGS);
 static  int       check_le5(POSTARGS);  static  int       check_le5(POSTARGS);
   static  int       check_text(POSTARGS);
   static  int       perr(struct man *, int, int, int, enum merr);
   
 static  v_post    posts_le1[] = { check_le1, NULL };  static  v_post    posts_le1[] = { check_le1, NULL };
 static  v_post    posts_le2[] = { check_le2, NULL };  static  v_post    posts_le2[] = { check_le2, NULL };
Line 85  man_valid_post(struct man *m)
Line 88  man_valid_post(struct man *m)
   
         switch (m->last->type) {          switch (m->last->type) {
         case (MAN_TEXT):          case (MAN_TEXT):
                 /* FALLTHROUGH */                  return(check_text(m, m->last));
         case (MAN_ROOT):          case (MAN_ROOT):
                 return(1);                  return(1);
         default:          default:
Line 102  man_valid_post(struct man *m)
Line 105  man_valid_post(struct man *m)
 }  }
   
   
 static inline int  static int
 count(const struct man_node *n)  perr(struct man *m, int line, int pos,
 {                  int iserr, enum merr type)
         int              i;  {
           const char       *p;
   
           p = NULL;
           switch (type) {
           case (WPRINT):
                   p = "invalid character";
                   break;
           }
           assert(p);
   
         for (i = 0; n; n = n->next, i++)          if (iserr)
                 /* Loop. */ ;                  return(man_verr(m, line, pos, p));
         return(i);  
           return(man_vwarn(m, line, pos, p));
 }  }
   
   
   static int
   check_text(POSTARGS)
   {
           const char      *p;
           int              pos;
   
           assert(n->string);
   
           for (p = n->string, pos = n->pos + 1; *p; p++, pos++) {
                   if ('\t' == *p || isprint((u_char)*p))
                           continue;
   
                   if (MAN_IGN_CHARS & m->pflags)
                           return(perr(m, n->line, pos, 0, WPRINT));
                   return(perr(m, n->line, pos, 1, WPRINT));
           }
   
           return(1);
   }
   
   
 #define INEQ_DEFINE(x, ineq, name) \  #define INEQ_DEFINE(x, ineq, name) \
 static int \  static int \
 check_##name(POSTARGS) \  check_##name(POSTARGS) \
 { \  { \
         int              c; \          if (n->nchild ineq (x)) \
         if ((c = count(n->child)) ineq (x)) \  
                 return(1); \                  return(1); \
         return(man_verr(m, n->line, n->pos, \          return(man_verr(m, n->line, n->pos, \
                         "expected line arguments %s %d, have %d", \                          "expected line arguments %s %d, have %d", \
                         #ineq, (x), c)); \                          #ineq, (x), n->nchild)); \
 }  }
   
 INEQ_DEFINE(0, ==, eq0)  INEQ_DEFINE(0, ==, eq0)

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

CVSweb