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

Diff for /mandoc/term.c between version 1.11 and 1.12

version 1.11, 2009/02/23 09:46:59 version 1.12, 2009/02/23 15:19:47
Line 30 
Line 30 
  */   */
   
 /* FIXME: indent/tab. */  /* FIXME: indent/tab. */
   /* FIXME: handle nested lists. */
   
 #define TTYPE_PROG        0  #define TTYPE_PROG        0
 #define TTYPE_CMD_FLAG    1  #define TTYPE_CMD_FLAG    1
Line 72  static int    arg_hasattr(int, size_t, 
Line 73  static int    arg_hasattr(int, size_t, 
                                 const struct mdoc_arg *);                                  const struct mdoc_arg *);
 static  int               arg_getattr(int, size_t,  static  int               arg_getattr(int, size_t,
                                 const struct mdoc_arg *);                                  const struct mdoc_arg *);
 static  size_t            arg_offset(const char *);  static  size_t            arg_offset(const struct mdoc_arg *);
   static  size_t            arg_width(const struct mdoc_arg *);
   
 /*  /*
  * What follows describes prefix and postfix operations for the abstract   * What follows describes prefix and postfix operations for the abstract
Line 94  DECL_POST(name);
Line 96  DECL_POST(name);
   
 DECL_PREPOST(termp_aq);  DECL_PREPOST(termp_aq);
 DECL_PREPOST(termp_ar);  DECL_PREPOST(termp_ar);
   DECL_PREPOST(termp_bd);
 DECL_PREPOST(termp_d1);  DECL_PREPOST(termp_d1);
 DECL_PREPOST(termp_dq);  DECL_PREPOST(termp_dq);
 DECL_PREPOST(termp_em);  DECL_PREPOST(termp_em);
Line 116  DECL_PREPOST(termp_sx);
Line 119  DECL_PREPOST(termp_sx);
 DECL_PREPOST(termp_va);  DECL_PREPOST(termp_va);
 DECL_PREPOST(termp_vt);  DECL_PREPOST(termp_vt);
   
 DECL_PRE(termp_bd);  
 DECL_PRE(termp_bx);  DECL_PRE(termp_bx);
 DECL_PRE(termp_ex);  DECL_PRE(termp_ex);
 DECL_PRE(termp_nd);  DECL_PRE(termp_nd);
Line 139  const struct termact __termacts[MDOC_MAX] = {
Line 141  const struct termact __termacts[MDOC_MAX] = {
         { termp_pp_pre, NULL }, /* Pp */          { termp_pp_pre, NULL }, /* Pp */
         { termp_d1_pre, termp_d1_post }, /* D1 */          { termp_d1_pre, termp_d1_post }, /* D1 */
         { NULL, NULL }, /* Dl */          { NULL, NULL }, /* Dl */
         { termp_bd_pre, NULL }, /* Bd */          { termp_bd_pre, termp_bd_post }, /* Bd */
         { NULL, NULL }, /* Ed */          { NULL, NULL }, /* Ed */
         { NULL, termp_bl_post }, /* Bl */          { NULL, termp_bl_post }, /* Bl */
         { NULL, NULL }, /* El */          { NULL, NULL }, /* El */
Line 242  const struct termact *termacts = __termacts;
Line 244  const struct termact *termacts = __termacts;
   
   
 static size_t  static size_t
 arg_offset(const char *v)  arg_width(const struct mdoc_arg *arg)
 {  {
         if (0 == strcmp(v, "indent"))  
           /* TODO */
           assert(*arg->value);
           return(strlen(*arg->value));
   }
   
   
   static size_t
   arg_offset(const struct mdoc_arg *arg)
   {
   
           /* TODO */
           assert(*arg->value);
           if (0 == strcmp(*arg->value, "indent"))
                 return(INDENT);                  return(INDENT);
         if (0 == strcmp(v, "indent-two"))          if (0 == strcmp(*arg->value, "indent-two"))
                 return(INDENT * 2);                  return(INDENT * 2);
   
         /* TODO */          return(strlen(*arg->value));
         return(0);  
 }  }
   
   
Line 308  termp_it_post(DECL_ARGS)
Line 322  termp_it_post(DECL_ARGS)
         const struct mdoc_node *n, *it;          const struct mdoc_node *n, *it;
         const struct mdoc_block *bl;          const struct mdoc_block *bl;
         int              i;          int              i;
         size_t           width;          size_t           width, offset;
   
         /*          /*
          * This (and termp_it_pre()) are the most complicated functions           * This (and termp_it_pre()) are the most complicated functions
Line 339  termp_it_post(DECL_ARGS)
Line 353  termp_it_post(DECL_ARGS)
         /* If `-tag', adjust our margins accordingly. */          /* If `-tag', adjust our margins accordingly. */
   
         if (arg_hasattr(MDOC_Tag, bl->argc, bl->argv)) {          if (arg_hasattr(MDOC_Tag, bl->argc, bl->argv)) {
                   flushln(p);
   
                   /* FIXME: this should auto-size. */
                 i = arg_getattr(MDOC_Width, bl->argc, bl->argv);                  i = arg_getattr(MDOC_Width, bl->argc, bl->argv);
                 assert(i >= 0);                  width = i >= 0 ? arg_width(&bl->argv[i]) : 10;
                 assert(1 == bl->argv[i].sz);  
                 width = strlen(*bl->argv[i].value); /* XXX */  
   
                   /* FIXME: nesting!  Should happen at block. */
                   i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
                   offset = i >= 0 ? arg_width(&bl->argv[i]) : 0;
   
                 if (MDOC_HEAD == node->type) {                  if (MDOC_HEAD == node->type) {
                         flushln(p);  
                         /* FIXME: nested lists. */  
                         p->rmargin = p->maxrmargin;                          p->rmargin = p->maxrmargin;
                           p->offset -= offset;
                         p->flags &= ~TERMP_NOBREAK;                          p->flags &= ~TERMP_NOBREAK;
                 } else {                  } else {
                         flushln(p);                          p->offset -= width;
                         p->offset -= width + 1;  
                         p->flags &= ~TERMP_NOLPAD;                          p->flags &= ~TERMP_NOLPAD;
                 }                  }
                 return;  
         }          }
   
         if (arg_hasattr(MDOC_Ohang, bl->argc, bl->argv)) {          if (arg_hasattr(MDOC_Ohang, bl->argc, bl->argv)) {
                 i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);                  i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
                 width = 0;                  offset = i >= 0 ? arg_offset(&bl->argv[i]) : 0;
                 if (i >= 0) {  
                         assert(1 == bl->argv[i].sz);  
                         width = arg_offset(*bl->argv[i].value);  
                 }  
   
                 flushln(p);                  flushln(p);
                 p->offset -= width;                  p->offset -= offset;
                 return;                  return;
         }          }
 }  }
Line 379  termp_it_pre(DECL_ARGS)
Line 391  termp_it_pre(DECL_ARGS)
         const struct mdoc_node *n, *it;          const struct mdoc_node *n, *it;
         const struct mdoc_block *bl;          const struct mdoc_block *bl;
         int              i;          int              i;
         size_t           width;          size_t           width, offset;
   
         /*          /*
          * Also see termp_it_post() for general comments.           * Also see termp_it_post() for general comments.
Line 420  termp_it_pre(DECL_ARGS)
Line 432  termp_it_pre(DECL_ARGS)
         assert(MDOC_HEAD == node->type          assert(MDOC_HEAD == node->type
                         || MDOC_BODY == node->type);                          || MDOC_BODY == node->type);
   
           /* FIXME: see termp_it_post(). */
   
         /* If `-tag', adjust our margins accordingly. */          /* If `-tag', adjust our margins accordingly. */
   
         if (arg_hasattr(MDOC_Tag, bl->argc, bl->argv)) {          if (arg_hasattr(MDOC_Tag, bl->argc, bl->argv)) {
                   p->flags |= TERMP_NOSPACE;
   
                 i = arg_getattr(MDOC_Width, bl->argc, bl->argv);                  i = arg_getattr(MDOC_Width, bl->argc, bl->argv);
                 assert(i >= 0); /* XXX */                  width = i >= 0 ? arg_width(&bl->argv[i]) : 10;
                 assert(1 == bl->argv[i].sz);  
                 width = strlen(*bl->argv[i].value); /* XXX */  
   
                 /* FIXME: nested lists. */                  i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
                   offset = i >= 0 ? arg_offset(&bl->argv[i]) : 0;
   
                 if (MDOC_HEAD == node->type) {                  if (MDOC_HEAD == node->type) {
                         p->flags |= TERMP_NOBREAK;                          p->flags |= TERMP_NOBREAK;
                         p->flags |= TERMP_NOSPACE;                          p->offset += offset;
                         p->rmargin = p->offset + width;                          p->rmargin = p->offset + width;
                 } else {                  } else {
                         p->flags |= TERMP_NOSPACE;                          p->flags |= TERMP_NOSPACE;
                         p->flags |= TERMP_NOLPAD;                          p->flags |= TERMP_NOLPAD;
                         p->offset += width + 1;                          p->offset += width;
                 }                  }
                 return(1);                  return(1);
         }          }
Line 445  termp_it_pre(DECL_ARGS)
Line 460  termp_it_pre(DECL_ARGS)
         /* If `-ohang', adjust left-margin. */          /* If `-ohang', adjust left-margin. */
   
         if (arg_hasattr(MDOC_Ohang, bl->argc, bl->argv)) {          if (arg_hasattr(MDOC_Ohang, bl->argc, bl->argv)) {
                 width = 0;  
                 i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);                  i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
                 if (i >= 0) {                  offset = i >= 0 ? arg_offset(&bl->argv[i]) : 0;
                         assert(1 == bl->argv[i].sz);  
                         width = arg_offset(*bl->argv[i].value);  
                 }  
   
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE;
                 p->offset += width;                  p->offset += offset;
                 return(1);                  return(1);
         }          }
   
Line 922  termp_bd_pre(DECL_ARGS)
Line 933  termp_bd_pre(DECL_ARGS)
 {  {
         const struct mdoc_block *bl;          const struct mdoc_block *bl;
         const struct mdoc_node *n;          const struct mdoc_node *n;
           int              i;
   
         if (MDOC_BLOCK == node->type) {          if (MDOC_BLOCK == node->type) {
                 vspace(p);                  vspace(p);
Line 932  termp_bd_pre(DECL_ARGS)
Line 944  termp_bd_pre(DECL_ARGS)
         assert(MDOC_BLOCK == node->parent->type);          assert(MDOC_BLOCK == node->parent->type);
   
         bl = &node->parent->data.block;          bl = &node->parent->data.block;
   
           i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
           if (-1 != i) {
                   assert(1 == bl->argv[i].sz);
                   p->offset += arg_offset(&bl->argv[i]);
           }
   
         if ( ! arg_hasattr(MDOC_Literal, bl->argc, bl->argv))          if ( ! arg_hasattr(MDOC_Literal, bl->argc, bl->argv))
                 return(1);                  return(1);
   
Line 949  termp_bd_pre(DECL_ARGS)
Line 968  termp_bd_pre(DECL_ARGS)
   
         p->flags &= ~TERMP_LITERAL;          p->flags &= ~TERMP_LITERAL;
         return(0);          return(0);
   }
   
   
   /* ARGSUSED */
   static void
   termp_bd_post(DECL_ARGS)
   {
           int              i;
           const struct mdoc_block *bl;
   
           if (MDOC_BODY != node->type)
                   return;
   
           assert(MDOC_BLOCK == node->parent->type);
           bl = &node->parent->data.block;
   
           i = arg_getattr(MDOC_Offset, bl->argc, bl->argv);
           if (-1 != i) {
                   assert(1 == bl->argv[i].sz);
                   p->offset -= arg_offset(&bl->argv[i]);
           }
 }  }
   
   

Legend:
Removed from v.1.11  
changed lines
  Added in v.1.12

CVSweb