[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.5 and 1.19

version 1.5, 2017/04/24 23:06:18 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 <stdio.h>
 #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"
 #include "libmandoc.h"  #include "libmandoc.h"
   #include "roff_int.h"
 #include "libmdoc.h"  #include "libmdoc.h"
   
 #define STATE_ARGS  struct roff_man *mdoc, struct roff_node *n  #define STATE_ARGS  struct roff_man *mdoc, struct roff_node *n
   
 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);
   
 static  const state_handler __state_handlers[MDOC_MAX - MDOC_Dd] = {  static  const state_handler state_handlers[MDOC_MAX - MDOC_Dd] = {
         NULL,           /* Dd */          NULL,           /* Dd */
         NULL,           /* Dt */          NULL,           /* Dt */
         NULL,           /* Os */          NULL,           /* Os */
Line 43  static const state_handler __state_handlers[MDOC_MAX -
Line 50  static const state_handler __state_handlers[MDOC_MAX -
         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 154  static const state_handler __state_handlers[MDOC_MAX -
Line 161  static const state_handler __state_handlers[MDOC_MAX -
         NULL,           /* En */          NULL,           /* En */
         NULL,           /* Dx */          NULL,           /* Dx */
         NULL,           /* %Q */          NULL,           /* %Q */
         NULL,           /* br */  
         NULL,           /* sp */  
         NULL,           /* %U */          NULL,           /* %U */
         NULL,           /* Ta */          NULL,           /* Ta */
         NULL,           /* ll */          NULL,           /* Tg */
 };  };
 static const state_handler *const state_handlers = __state_handlers - MDOC_Dd;  
   
   
 void  void
Line 168  mdoc_state(struct roff_man *mdoc, struct roff_node *n)
Line 172  mdoc_state(struct roff_man *mdoc, struct roff_node *n)
 {  {
         state_handler handler;          state_handler handler;
   
         if (n->tok == TOKEN_NONE)          if (n->tok == TOKEN_NONE || n->tok < ROFF_MAX)
                 return;                  return;
   
         if ( ! (mdoc_macros[n->tok].flags & MDOC_PROLOGUE))          assert(n->tok >= MDOC_Dd && n->tok < MDOC_MAX);
           if ((mdoc_macro(n->tok)->flags & MDOC_PROLOGUE) == 0)
                 mdoc->flags |= MDOC_PBODY;                  mdoc->flags |= MDOC_PBODY;
   
         handler = state_handlers[n->tok];          handler = state_handlers[n->tok - MDOC_Dd];
         if (*handler)          if (*handler)
                 (*handler)(mdoc, n);                  (*handler)(mdoc, n);
 }  }
   
 void  
 mdoc_state_reset(struct roff_man *mdoc)  
 {  
   
         roff_setreg(mdoc->roff, "nS", 0, '=');  
         mdoc->flags = 0;  
 }  
   
 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;
           size_t           i;
   
         if (n->type != ROFFT_HEAD || n->parent->args == NULL)          if (n->type != ROFFT_HEAD || n->parent->args == NULL)
                 return;                  return;
   
         switch(n->parent->args->argv[0].arg) {          args = n->parent->args;
         case MDOC_Diag:          for (i = 0; i < args->argc; i++) {
                 n->norm->Bl.type = LIST_diag;                  switch(args->argv[i].arg) {
                 break;                  case MDOC_Diag:
         case MDOC_Column:                          n->norm->Bl.type = LIST_diag;
                 n->norm->Bl.type = LIST_column;                          return;
                 break;                  case MDOC_Column:
         default:                          n->norm->Bl.type = LIST_column;
                 break;                          return;
                   default:
                           break;
                   }
         }          }
 }  }
   
 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.5  
changed lines
  Added in v.1.19

CVSweb