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

Diff for /mandoc/man.c between version 1.73 and 1.74

version 1.73, 2010/05/17 10:50:32 version 1.74, 2010/05/17 22:11:42
Line 27 
Line 27 
 #include <stdio.h>  #include <stdio.h>
 #include <string.h>  #include <string.h>
   
   #include "mandoc.h"
 #include "libman.h"  #include "libman.h"
 #include "libmandoc.h"  #include "libmandoc.h"
   
 const   char *const __man_merrnames[WERRMAX] = {  
         "invalid character", /* WNPRINT */  
         "invalid date format", /* WDATE */  
         "scope of prior line violated", /* WLNSCOPE */  
         "over-zealous prior line scope violation", /* WLNSCOPE2 */  
         "trailing whitespace", /* WTSPACE */  
         "unterminated quoted parameter", /* WTQUOTE */  
         "document has no body", /* WNODATA */  
         "document has no title/section", /* WNOTITLE */  
         "invalid escape sequence", /* WESCAPE */  
         "invalid number format", /* WNUMFMT */  
         "expected block head arguments", /* WHEADARGS */  
         "expected block body arguments", /* WBODYARGS */  
         "expected empty block head", /* WNHEADARGS */  
         "ill-formed macro", /* WMACROFORM */  
         "scope open on exit", /* WEXITSCOPE */  
         "no scope context", /* WNOSCOPE */  
         "literal context already open", /* WOLITERAL */  
         "no literal context open", /* WNLITERAL */  
         "document title should be uppercase", /* WTITLECASE */  
         "deprecated comment style", /* WBADCOMMENT */  
 };  
   
 const   char *const __man_macronames[MAN_MAX] = {  const   char *const __man_macronames[MAN_MAX] = {
         "br",           "TH",           "SH",           "SS",          "br",           "TH",           "SH",           "SS",
         "TP",           "LP",           "PP",           "P",          "TP",           "LP",           "PP",           "P",
Line 116  man_free(struct man *man)
Line 94  man_free(struct man *man)
   
   
 struct man *  struct man *
 man_alloc(void *data, int pflags, const struct man_cb *cb)  man_alloc(void *data, int pflags, mandocmsg msg)
 {  {
         struct man      *p;          struct man      *p;
   
         p = mandoc_calloc(1, sizeof(struct man));          p = mandoc_calloc(1, sizeof(struct man));
   
         if (cb)  
                 memcpy(&p->cb, cb, sizeof(struct man_cb));  
   
         man_hash_init();          man_hash_init();
         p->data = data;          p->data = data;
         p->pflags = pflags;          p->pflags = pflags;
           p->msg = msg;
   
         man_alloc1(p);          man_alloc1(p);
         return(p);          return(p);
Line 375  man_ptext(struct man *m, int line, char *buf, int offs
Line 351  man_ptext(struct man *m, int line, char *buf, int offs
         if ('\\' == buf[offs] &&          if ('\\' == buf[offs] &&
                         '.' == buf[offs + 1] &&                          '.' == buf[offs + 1] &&
                         '"' == buf[offs + 2])                          '"' == buf[offs + 2])
                 return(man_pwarn(m, line, offs, WBADCOMMENT));                  return(man_pmsg(m, line, offs, MANDOCERR_BADCOMMENT));
   
         /* Literal free-form text whitespace is preserved. */          /* Literal free-form text whitespace is preserved. */
   
Line 407  man_ptext(struct man *m, int line, char *buf, int offs
Line 383  man_ptext(struct man *m, int line, char *buf, int offs
   
         if (' ' == buf[i - 1] || '\t' == buf[i - 1]) {          if (' ' == buf[i - 1] || '\t' == buf[i - 1]) {
                 if (i > 1 && '\\' != buf[i - 2])                  if (i > 1 && '\\' != buf[i - 2])
                         if ( ! man_pwarn(m, line, i - 1, WTSPACE))                          if ( ! man_pmsg(m, line, i - 1, MANDOCERR_EOLNSPACE))
                                 return(0);                                  return(0);
   
                 for (--i; i && ' ' == buf[i]; i--)                  for (--i; i && ' ' == buf[i]; i--)
Line 441  descope:
Line 417  descope:
   
         if (MAN_ELINE & m->flags) {          if (MAN_ELINE & m->flags) {
                 m->flags &= ~MAN_ELINE;                  m->flags &= ~MAN_ELINE;
                 if ( ! man_unscope(m, m->last->parent, WERRMAX))                  if ( ! man_unscope(m, m->last->parent, MANDOCERR_MAX))
                         return(0);                          return(0);
         }          }
   
Line 449  descope:
Line 425  descope:
                 return(1);                  return(1);
         m->flags &= ~MAN_BLINE;          m->flags &= ~MAN_BLINE;
   
         if ( ! man_unscope(m, m->last->parent, WERRMAX))          if ( ! man_unscope(m, m->last->parent, MANDOCERR_MAX))
                 return(0);                  return(0);
         return(man_body_alloc(m, line, offs, m->last->tok));          return(man_body_alloc(m, line, offs, m->last->tok));
 }  }
Line 458  descope:
Line 434  descope:
 static int  static int
 macrowarn(struct man *m, int ln, const char *buf, int offs)  macrowarn(struct man *m, int ln, const char *buf, int offs)
 {  {
         if ( ! (MAN_IGN_MACRO & m->pflags))          int              rc;
                 return(man_verr(m, ln, offs, "unknown macro: %s%s",  
                                 buf, strlen(buf) > 3 ? "..." : ""));          rc = man_vmsg(m, MANDOCERR_MACRO, ln, offs,
         return(man_vwarn(m, ln, offs, "unknown macro: %s%s",                          "unknown macro: %s%s",
                                 buf, strlen(buf) > 3 ? "..." : ""));                          buf, strlen(buf) > 3 ? "..." : "");
   
           return(MAN_IGN_MACRO & m->pflags ? rc : 0);
 }  }
   
   
Line 510  man_pmacro(struct man *m, int ln, char *buf, int offs)
Line 488  man_pmacro(struct man *m, int ln, char *buf, int offs)
   
                 if (isgraph((u_char)buf[i]))                  if (isgraph((u_char)buf[i]))
                         continue;                          continue;
                 return(man_perr(m, ln, i, WNPRINT));                  if ( ! man_pmsg(m, ln, i, MANDOCERR_BADCHAR))
                           return(0);
                   i--;
         }          }
   
         mac[j] = '\0';          mac[j] = '\0';
   
         if (j == 4 || j < 1) {          if (j == 4 || j < 1) {
                 if ( ! (MAN_IGN_MACRO & m->pflags)) {                  if ( ! macrowarn(m, ln, mac, ppos))
                         (void)man_perr(m, ln, ppos, WMACROFORM);  
                         goto err;                          goto err;
                 }  
                 if ( ! man_pwarn(m, ln, ppos, WMACROFORM))  
                         goto err;  
                 return(1);                  return(1);
         }          }
   
Line 542  man_pmacro(struct man *m, int ln, char *buf, int offs)
Line 518  man_pmacro(struct man *m, int ln, char *buf, int offs)
          */           */
   
         if ('\0' == buf[i] && ' ' == buf[i - 1])          if ('\0' == buf[i] && ' ' == buf[i - 1])
                 if ( ! man_pwarn(m, ln, i - 1, WTSPACE))                  if ( ! man_pmsg(m, ln, i - 1, MANDOCERR_EOLNSPACE))
                         goto err;                          goto err;
   
         /*          /*
Line 564  man_pmacro(struct man *m, int ln, char *buf, int offs)
Line 540  man_pmacro(struct man *m, int ln, char *buf, int offs)
                  *   I hate man macros.                   *   I hate man macros.
                  * Flat-out disallow this madness.                   * Flat-out disallow this madness.
                  */                   */
                 if (MAN_NSCOPED & man_macros[m->last->tok].flags)                  if (MAN_NSCOPED & man_macros[m->last->tok].flags) {
                         return(man_perr(m, ln, ppos, WLNSCOPE));                          man_pmsg(m, ln, ppos, MANDOCERR_SYNTLINESCOPE);
                           return(0);
                   }
   
                 n = m->last;                  n = m->last;
   
Line 573  man_pmacro(struct man *m, int ln, char *buf, int offs)
Line 551  man_pmacro(struct man *m, int ln, char *buf, int offs)
                 assert(NULL == n->child);                  assert(NULL == n->child);
                 assert(0 == n->nchild);                  assert(0 == n->nchild);
   
                 if ( ! man_nwarn(m, n, WLNSCOPE))                  if ( ! man_nmsg(m, n, MANDOCERR_LINESCOPE))
                         return(0);                          return(0);
   
                 man_node_delete(m, n);                  man_node_delete(m, n);
Line 630  out:
Line 608  out:
         assert(MAN_BLINE & m->flags);          assert(MAN_BLINE & m->flags);
         m->flags &= ~MAN_BLINE;          m->flags &= ~MAN_BLINE;
   
         if ( ! man_unscope(m, m->last->parent, WERRMAX))          if ( ! man_unscope(m, m->last->parent, MANDOCERR_MAX))
                 return(0);                  return(0);
         return(man_body_alloc(m, ln, offs, m->last->tok));          return(man_body_alloc(m, ln, offs, m->last->tok));
   
Line 642  err: /* Error out. */
Line 620  err: /* Error out. */
   
   
 int  int
 man_verr(struct man *man, int ln, int pos, const char *fmt, ...)  man_vmsg(struct man *man, enum mandocerr t,
                   int ln, int pos, const char *fmt, ...)
 {  {
         char             buf[256];          char             buf[256];
         va_list          ap;          va_list          ap;
   
         if (NULL == man->cb.man_err)  
                 return(0);  
   
         va_start(ap, fmt);          va_start(ap, fmt);
         (void)vsnprintf(buf, sizeof(buf) - 1, fmt, ap);          vsnprintf(buf, sizeof(buf) - 1, fmt, ap);
         va_end(ap);          va_end(ap);
         return((*man->cb.man_err)(man->data, ln, pos, buf));          return((*man->msg)(t, man->data, ln, pos, buf));
 }  
   
   
 int  
 man_vwarn(struct man *man, int ln, int pos, const char *fmt, ...)  
 {  
         char             buf[256];  
         va_list          ap;  
   
         if (NULL == man->cb.man_warn)  
                 return(0);  
   
         va_start(ap, fmt);  
         (void)vsnprintf(buf, sizeof(buf) - 1, fmt, ap);  
         va_end(ap);  
         return((*man->cb.man_warn)(man->data, ln, pos, buf));  
 }  
   
   
 int  
 man_err(struct man *m, int line, int pos, int iserr, enum merr type)  
 {  
         const char       *p;  
   
         p = __man_merrnames[(int)type];  
         assert(p);  
   
         if (iserr)  
                 return(man_verr(m, line, pos, p));  
   
         return(man_vwarn(m, line, pos, p));  
 }  }
   
   

Legend:
Removed from v.1.73  
changed lines
  Added in v.1.74

CVSweb