[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.2 and 1.8

version 1.2, 2015/10/21 23:51:11 version 1.8, 2017/05/05 15:17:32
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2014, 2015 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2014, 2015, 2017 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 16 
Line 16 
  */   */
 #include <sys/types.h>  #include <sys/types.h>
   
   #include <assert.h>
 #include <stdlib.h>  #include <stdlib.h>
 #include <string.h>  #include <string.h>
   
Line 35  static void  state_dl(STATE_ARGS);
Line 36  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] = {  static  const state_handler __state_handlers[MDOC_MAX - MDOC_Dd] = {
         NULL,           /* Ap */  
         NULL,           /* Dd */          NULL,           /* Dd */
         NULL,           /* Dt */          NULL,           /* Dt */
         NULL,           /* Os */          NULL,           /* Os */
Line 52  static const state_handler state_handlers[MDOC_MAX] = 
Line 52  static const state_handler state_handlers[MDOC_MAX] = 
         NULL,           /* It */          NULL,           /* It */
         NULL,           /* Ad */          NULL,           /* Ad */
         NULL,           /* An */          NULL,           /* An */
           NULL,           /* Ap */
         NULL,           /* Ar */          NULL,           /* Ar */
         NULL,           /* Cd */          NULL,           /* Cd */
         NULL,           /* Cm */          NULL,           /* Cm */
Line 154  static const state_handler state_handlers[MDOC_MAX] = 
Line 155  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 */  
 };  };
   static const state_handler *const state_handlers = __state_handlers - MDOC_Dd;
   
   
 void  void
Line 167  mdoc_state(struct roff_man *mdoc, struct roff_node *n)
Line 166  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;
   
           assert(n->tok >= MDOC_Dd && n->tok < MDOC_MAX);
         if ( ! (mdoc_macros[n->tok].flags & MDOC_PROLOGUE))          if ( ! (mdoc_macros[n->tok].flags & MDOC_PROLOGUE))
                 mdoc->flags |= MDOC_PBODY;                  mdoc->flags |= MDOC_PBODY;
   
Line 195  state_bd(STATE_ARGS)
Line 195  state_bd(STATE_ARGS)
             (n->type != ROFFT_BODY || n->end != ENDBODY_NOT))              (n->type != ROFFT_BODY || n->end != ENDBODY_NOT))
                 return;                  return;
   
           if (n->parent->args == NULL)
                   return;
   
         arg = n->parent->args->argv[0].arg;          arg = n->parent->args->argv[0].arg;
         if (arg != MDOC_Literal && arg != MDOC_Unfilled)          if (arg != MDOC_Literal && arg != MDOC_Unfilled)
                 return;                  return;
Line 246  state_sh(STATE_ARGS)
Line 249  state_sh(STATE_ARGS)
         if (n->type != ROFFT_HEAD)          if (n->type != ROFFT_HEAD)
                 return;                  return;
   
         if ( ! (n->flags & MDOC_VALID)) {          if ( ! (n->flags & NODE_VALID)) {
                 secname = NULL;                  secname = NULL;
                 deroff(&secname, n);                  deroff(&secname, n);
   

Legend:
Removed from v.1.2  
changed lines
  Added in v.1.8

CVSweb