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

Diff for /mandoc/mdoc_state.c between version 1.13 and 1.19

version 1.13, 2018/12/31 04:55:47 version 1.19, 2022/08/19 12:59:26
Line 1 
Line 1 
 /*      $Id$ */  /* $Id$ */
 /*  /*
  * Copyright (c) 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2014,2015,2017,2018,2022 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 14 
Line 14 
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF   * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */   */
   #include "config.h"
   
 #include <sys/types.h>  #include <sys/types.h>
   
 #include <assert.h>  #include <assert.h>
Line 21 
Line 23 
 #include <stdlib.h>  #include <stdlib.h>
 #include <string.h>  #include <string.h>
   
   #if DEBUG_MEMORY
   #include "mandoc_dbg.h"
   #endif
 #include "mandoc.h"  #include "mandoc.h"
 #include "roff.h"  #include "roff.h"
 #include "mdoc.h"  #include "mdoc.h"
Line 32 
Line 37 
   
 typedef void    (*state_handler)(STATE_ARGS);  typedef void    (*state_handler)(STATE_ARGS);
   
 static  void     state_bd(STATE_ARGS);  static  void     setsec(struct roff_node *, enum roff_sec);
 static  void     state_bl(STATE_ARGS);  static  void     state_bl(STATE_ARGS);
 static  void     state_dl(STATE_ARGS);  
 static  void     state_sh(STATE_ARGS);  static  void     state_sh(STATE_ARGS);
 static  void     state_sm(STATE_ARGS);  static  void     state_sm(STATE_ARGS);
   
Line 46  static const state_handler state_handlers[MDOC_MAX - M
Line 50  static const state_handler state_handlers[MDOC_MAX - M
         NULL,           /* Ss */          NULL,           /* Ss */
         NULL,           /* Pp */          NULL,           /* Pp */
         NULL,           /* D1 */          NULL,           /* D1 */
         state_dl,       /* Dl */          NULL,           /* Dl */
         state_bd,       /* Bd */          NULL,           /* Bd */
         NULL,           /* Ed */          NULL,           /* Ed */
         state_bl,       /* Bl */          state_bl,       /* Bl */
         NULL,           /* El */          NULL,           /* El */
Line 159  static const state_handler state_handlers[MDOC_MAX - M
Line 163  static const state_handler state_handlers[MDOC_MAX - M
         NULL,           /* %Q */          NULL,           /* %Q */
         NULL,           /* %U */          NULL,           /* %U */
         NULL,           /* Ta */          NULL,           /* Ta */
           NULL,           /* Tg */
 };  };
   
   
Line 180  mdoc_state(struct roff_man *mdoc, struct roff_node *n)
Line 185  mdoc_state(struct roff_man *mdoc, struct roff_node *n)
 }  }
   
 static void  static void
 state_bd(STATE_ARGS)  
 {  
         enum mdocargt arg;  
   
         if (n->type != ROFFT_HEAD &&  
             (n->type != ROFFT_BODY || n->end != ENDBODY_NOT))  
                 return;  
   
         if (n->parent->args == NULL)  
                 return;  
   
         arg = n->parent->args->argv[0].arg;  
         if (arg != MDOC_Literal && arg != MDOC_Unfilled)  
                 return;  
   
         state_dl(mdoc, n);  
 }  
   
 static void  
 state_bl(STATE_ARGS)  state_bl(STATE_ARGS)
 {  {
         struct mdoc_arg *args;          struct mdoc_arg *args;
Line 223  state_bl(STATE_ARGS)
Line 209  state_bl(STATE_ARGS)
 }  }
   
 static void  static void
 state_dl(STATE_ARGS)  setsec(struct roff_node *n, enum roff_sec sec)
 {  {
           struct roff_node *nch;
   
         switch (n->type) {          n->sec = sec;
         case ROFFT_HEAD:          for (nch = n->child; nch != NULL; nch = nch->next)
                 mdoc->flags |= MDOC_LITERAL;                  setsec(nch, sec);
                 break;  
         case ROFFT_BODY:  
                 mdoc->flags &= ~MDOC_LITERAL;  
                 break;  
         default:  
                 break;  
         }  
 }  }
   
   /*
    * Set the section attribute for the BLOCK, HEAD, and HEAD children.
    * For other nodes, including the .Sh BODY, this is done when allocating
    * the node data structures, but for .Sh BLOCK and HEAD, the section is
    * still unknown at that time.
    */
 static void  static void
 state_sh(STATE_ARGS)  state_sh(STATE_ARGS)
 {  {
         struct roff_node *nch;          enum roff_sec sec;
         char             *secname;  
   
         if (n->type != ROFFT_HEAD)          if (n->type != ROFFT_HEAD)
                 return;                  return;
   
         if ( ! (n->flags & NODE_VALID)) {          if ((n->flags & NODE_VALID) == 0) {
                 secname = NULL;                  sec = n->child != NULL && n->child->type == ROFFT_TEXT &&
                 deroff(&secname, n);                      n->child->next == NULL ? mdoc_a2sec(n->child->string) :
                       SEC_CUSTOM;
                 /*                  n->parent->sec = sec;
                  * Set the section attribute for the BLOCK, HEAD,                  setsec(n, sec);
                  * and HEAD children; the latter can only be TEXT  
                  * nodes, so no recursion is needed.  For other  
                  * nodes, including the .Sh BODY, this is done  
                  * when allocating the node data structures, but  
                  * for .Sh BLOCK and HEAD, the section is still  
                  * unknown at that time.  
                  */  
   
                 n->sec = n->parent->sec = secname == NULL ?  
                     SEC_CUSTOM : mdoc_a2sec(secname);  
                 for (nch = n->child; nch != NULL; nch = nch->next)  
                         nch->sec = n->sec;  
                 free(secname);  
         }          }
   
         if ((mdoc->lastsec = n->sec) == SEC_SYNOPSIS) {          if ((mdoc->lastsec = n->sec) == SEC_SYNOPSIS) {
                 roff_setreg(mdoc->roff, "nS", 1, '=');                  roff_setreg(mdoc->roff, "nS", 1, '=');
                 mdoc->flags |= MDOC_SYNOPSIS;                  mdoc->flags |= MDOC_SYNOPSIS;

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

CVSweb