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

Diff for /mandoc/mdoc_macro.c between version 1.84 and 1.92

version 1.84, 2010/06/29 19:24:14 version 1.92, 2010/07/04 22:04:04
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
    * Copyright (c) 2010 Ingo Schwarze <schwarze@openbsd.org>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above   * purpose with or without fee is hereby granted, provided that the above
Line 34  enum rew { /* see rew_dohalt() */
Line 35  enum rew { /* see rew_dohalt() */
         REWIND_THIS,          REWIND_THIS,
         REWIND_MORE,          REWIND_MORE,
         REWIND_LATER,          REWIND_LATER,
         REWIND_ERROR,          REWIND_ERROR
 };  };
   
 static  int             blk_full(MACRO_PROT_ARGS);  static  int             blk_full(MACRO_PROT_ARGS);
Line 52  static int    append_delims(struct mdoc *, 
Line 53  static int    append_delims(struct mdoc *, 
                                 int, int *, char *);                                  int, int *, char *);
 static  enum mdoct      lookup(enum mdoct, const char *);  static  enum mdoct      lookup(enum mdoct, const char *);
 static  enum mdoct      lookup_raw(const char *);  static  enum mdoct      lookup_raw(const char *);
 static  int             make_pending(struct mdoc_node *, enum mdoc_type,  static  int             make_pending(struct mdoc_node *, enum mdoct,
                                 struct mdoc *, int, int);                                  struct mdoc *, int, int);
 static  int             phrase(struct mdoc *, int, int, char *);  static  int             phrase(struct mdoc *, int, int, char *);
 static  enum mdoct      rew_alt(enum mdoct);  static  enum mdoct      rew_alt(enum mdoct);
Line 97  const struct mdoc_macro __mdoc_macros[MDOC_MAX] = {
Line 98  const struct mdoc_macro __mdoc_macros[MDOC_MAX] = {
         { in_line_argn, MDOC_CALLABLE | MDOC_PARSED }, /* In */          { in_line_argn, MDOC_CALLABLE | MDOC_PARSED }, /* In */
         { in_line, MDOC_CALLABLE | MDOC_PARSED }, /* Li */          { in_line, MDOC_CALLABLE | MDOC_PARSED }, /* Li */
         { blk_full, 0 }, /* Nd */          { blk_full, 0 }, /* Nd */
         { in_line, MDOC_CALLABLE | MDOC_PARSED }, /* Nm */          { ctx_synopsis, MDOC_CALLABLE | MDOC_PARSED }, /* Nm */
         { blk_part_imp, MDOC_CALLABLE | MDOC_PARSED }, /* Op */          { blk_part_imp, MDOC_CALLABLE | MDOC_PARSED }, /* Op */
         { obsolete, 0 }, /* Ot */          { obsolete, 0 }, /* Ot */
         { in_line, MDOC_CALLABLE | MDOC_PARSED }, /* Pa */          { in_line, MDOC_CALLABLE | MDOC_PARSED }, /* Pa */
Line 335  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
Line 336  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
                 const struct mdoc_node *p)                  const struct mdoc_node *p)
 {  {
   
           /*
            * No matching token, no delimiting block, no broken block.
            * This can happen when full implicit macros are called for
            * the first time but try to rewind their previous
            * instance anyway.
            */
         if (MDOC_ROOT == p->type)          if (MDOC_ROOT == p->type)
                 return(MDOC_BLOCK == type &&                  return(MDOC_BLOCK == type &&
                     MDOC_EXPLICIT & mdoc_macros[tok].flags ?                      MDOC_EXPLICIT & mdoc_macros[tok].flags ?
                     REWIND_ERROR : REWIND_NONE);                      REWIND_ERROR : REWIND_NONE);
   
           /*
            * When starting to rewind, skip plain text
            * and nodes that have already been rewound.
            */
         if (MDOC_TEXT == p->type || MDOC_VALID & p->flags)          if (MDOC_TEXT == p->type || MDOC_VALID & p->flags)
                 return(REWIND_MORE);                  return(REWIND_MORE);
   
           /*
            * The easiest case:  Found a matching token.
            * This applies to both blocks and elements.
            */
         tok = rew_alt(tok);          tok = rew_alt(tok);
         if (tok == p->tok)          if (tok == p->tok)
                 return(p->end ? REWIND_NONE :                  return(p->end ? REWIND_NONE :
                     type == p->type ? REWIND_THIS : REWIND_MORE);                      type == p->type ? REWIND_THIS : REWIND_MORE);
   
           /*
            * While elements do require rewinding for themselves,
            * they never affect rewinding of other nodes.
            */
         if (MDOC_ELEM == p->type)          if (MDOC_ELEM == p->type)
                 return(REWIND_MORE);                  return(REWIND_MORE);
   
           /*
            * Blocks delimited by our target token get REWIND_MORE.
            * Blocks delimiting our target token get REWIND_NONE.
            */
         switch (tok) {          switch (tok) {
         case (MDOC_Bl):          case (MDOC_Bl):
                 if (MDOC_It == p->tok)                  if (MDOC_It == p->tok)
Line 369  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
Line 393  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
                 if (MDOC_Op == p->tok)                  if (MDOC_Op == p->tok)
                         return(REWIND_MORE);                          return(REWIND_MORE);
                 break;                  break;
           case (MDOC_Nm):
                   return(REWIND_NONE);
         case (MDOC_Nd):          case (MDOC_Nd):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (MDOC_Ss):          case (MDOC_Ss):
Line 384  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
Line 410  rew_dohalt(enum mdoct tok, enum mdoc_type type, 
                 break;                  break;
         }          }
   
         return(p->end || (MDOC_BLOCK == p->type &&          /*
             ! (MDOC_EXPLICIT & mdoc_macros[tok].flags)) ?           * Default block rewinding rules.
             REWIND_MORE : REWIND_LATER);           * In particular, always skip block end markers,
            * and let all blocks rewind Nm children.
            */
           if (ENDBODY_NOT != p->end || MDOC_Nm == p->tok ||
               (MDOC_BLOCK == p->type &&
               ! (MDOC_EXPLICIT & mdoc_macros[tok].flags)))
                   return(REWIND_MORE);
   
           /*
            * Partial blocks allow delayed rewinding by default.
            */
           if (&blk_full != mdoc_macros[tok].fp)
                   return (REWIND_LATER);
   
           /*
            * Full blocks can only be rewound when matching
            * or when there is an explicit rule.
            */
           return(REWIND_ERROR);
 }  }
   
   
Line 468  make_pending(struct mdoc_node *broken, enum mdoct tok,
Line 512  make_pending(struct mdoc_node *broken, enum mdoct tok,
                         taker->pending = broken->pending;                          taker->pending = broken->pending;
                 }                  }
                 broken->pending = breaker;                  broken->pending = breaker;
                 mdoc_vmsg(m, MANDOCERR_SCOPE, line, ppos, "%s breaks %s",                  mdoc_vmsg(m, MANDOCERR_SCOPENEST, line, ppos,
                     mdoc_macronames[tok], mdoc_macronames[broken->tok]);                      "%s breaks %s", mdoc_macronames[tok],
                       mdoc_macronames[broken->tok]);
                 return(1);                  return(1);
         }          }
   
Line 503  rew_sub(enum mdoc_type t, struct mdoc *m, 
Line 548  rew_sub(enum mdoc_type t, struct mdoc *m, 
                         return(make_pending(n, tok, m, line, ppos));                          return(make_pending(n, tok, m, line, ppos));
                 case (REWIND_ERROR):                  case (REWIND_ERROR):
                         /* XXX Make this non-fatal. */                          /* XXX Make this non-fatal. */
                         mdoc_pmsg(m, line, ppos, MANDOCERR_SYNTNOSCOPE);                          mdoc_vmsg(m, MANDOCERR_SCOPEFATAL, line, ppos,
                               "%s cannot break %s", mdoc_macronames[tok],
                               mdoc_macronames[n->tok]);
                         return 0;                          return 0;
                 }                  }
                 break;                  break;
Line 609  blk_exp_close(MACRO_PROT_ARGS)
Line 656  blk_exp_close(MACRO_PROT_ARGS)
   
                 /* Remember the start of our own body. */                  /* Remember the start of our own body. */
                 if (MDOC_BODY == n->type && atok == n->tok) {                  if (MDOC_BODY == n->type && atok == n->tok) {
                         if ( ! n->end)                          if (ENDBODY_NOT == n->end)
                                 body = n;                                  body = n;
                         continue;                          continue;
                 }                  }
   
                 if (MDOC_BLOCK != n->type)                  if (MDOC_BLOCK != n->type || MDOC_Nm == n->tok)
                         continue;                          continue;
                 if (atok == n->tok) {                  if (atok == n->tok) {
                         assert(body);                          assert(body);
Line 979  blk_full(MACRO_PROT_ARGS)
Line 1026  blk_full(MACRO_PROT_ARGS)
                 lac = ARGS_ERROR == ac ? ARGS_PEND : ac;                  lac = ARGS_ERROR == ac ? ARGS_PEND : ac;
                 ac = mdoc_args(m, line, pos, buf, tok, &p);                  ac = mdoc_args(m, line, pos, buf, tok, &p);
   
                   if (ARGS_PUNCT == ac)
                           break;
   
                 if (ARGS_ERROR == ac)                  if (ARGS_ERROR == ac)
                         return(0);                          return(0);
   
Line 1251  blk_part_imp(MACRO_PROT_ARGS)
Line 1301  blk_part_imp(MACRO_PROT_ARGS)
          * is ugly behaviour nodding its head to OpenBSD's overwhelming           * is ugly behaviour nodding its head to OpenBSD's overwhelming
          * crufty use of `Op' breakage.           * crufty use of `Op' breakage.
          */           */
         if (n != body && ! mdoc_vmsg(m, MANDOCERR_SCOPE, line, ppos,          if (n != body && ! mdoc_vmsg(m, MANDOCERR_SCOPENEST,
             "%s broken", mdoc_macronames[tok]))              line, ppos, "%s broken", mdoc_macronames[tok]))
                 return(0);                  return(0);
   
         if (n && ! rew_sub(MDOC_BODY, m, tok, line, ppos))          if (n && ! rew_sub(MDOC_BODY, m, tok, line, ppos))
Line 1533  in_line_eoln(MACRO_PROT_ARGS)
Line 1583  in_line_eoln(MACRO_PROT_ARGS)
   
         assert( ! (MDOC_PARSED & mdoc_macros[tok].flags));          assert( ! (MDOC_PARSED & mdoc_macros[tok].flags));
   
           if (tok == MDOC_Pp)
                   rew_sub(MDOC_BLOCK, m, MDOC_Nm, line, ppos);
   
         /* Parse macro arguments. */          /* Parse macro arguments. */
   
         for (arg = NULL; ; ) {          for (arg = NULL; ; ) {
Line 1596  ctx_synopsis(MACRO_PROT_ARGS)
Line 1649  ctx_synopsis(MACRO_PROT_ARGS)
         nl = MDOC_NEWLINE & m->flags;          nl = MDOC_NEWLINE & m->flags;
   
         /* If we're not in the SYNOPSIS, go straight to in-line. */          /* If we're not in the SYNOPSIS, go straight to in-line. */
         if (SEC_SYNOPSIS != m->lastsec)          if ( ! (MDOC_SYNOPSIS & m->flags))
                 return(in_line(m, tok, line, ppos, pos, buf));                  return(in_line(m, tok, line, ppos, pos, buf));
   
         /* If we're a nested call, same place. */          /* If we're a nested call, same place. */
Line 1608  ctx_synopsis(MACRO_PROT_ARGS)
Line 1661  ctx_synopsis(MACRO_PROT_ARGS)
          * up formatting the block scope, then child nodes will inherit           * up formatting the block scope, then child nodes will inherit
          * the formatting.  Be careful.           * the formatting.  Be careful.
          */           */
           if (MDOC_Nm == tok)
                   return(blk_full(m, tok, line, ppos, pos, buf));
           assert(MDOC_Vt == tok);
         return(blk_part_imp(m, tok, line, ppos, pos, buf));          return(blk_part_imp(m, tok, line, ppos, pos, buf));
 }  }
   

Legend:
Removed from v.1.84  
changed lines
  Added in v.1.92

CVSweb