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

Diff for /mandoc/mdoc_man.c between version 1.43 and 1.45

version 1.43, 2012/11/18 18:02:23 version 1.45, 2012/11/19 02:08:33
Line 253  static int  outflags;
Line 253  static int  outflags;
 #define MMAN_Bk         (1 << 7)  /* word keep mode */  #define MMAN_Bk         (1 << 7)  /* word keep mode */
 #define MMAN_An_split   (1 << 8)  /* author mode is "split" */  #define MMAN_An_split   (1 << 8)  /* author mode is "split" */
 #define MMAN_An_nosplit (1 << 9)  /* author mode is "nosplit" */  #define MMAN_An_nosplit (1 << 9)  /* author mode is "nosplit" */
   #define MMAN_PD         (1 << 10) /* inter-paragraph spacing disabled */
   
 #define BL_STACK_MAX    32  #define BL_STACK_MAX    32
   
Line 304  print_word(const char *s)
Line 305  print_word(const char *s)
                  * If we need a newline, print it now and start afresh.                   * If we need a newline, print it now and start afresh.
                  */                   */
                 if (MMAN_PP & outflags) {                  if (MMAN_PP & outflags) {
                         if ( ! (MMAN_sp & outflags))                          if (MMAN_sp & outflags) {
                                 printf("\n.sp -1v");                                  if (MMAN_PD & outflags) {
                                           printf("\n.PD");
                                           outflags &= ~MMAN_PD;
                                   }
                           } else if ( ! (MMAN_PD & outflags)) {
                                   printf("\n.PD 0");
                                   outflags |= MMAN_PD;
                           }
                         printf("\n.PP\n");                          printf("\n.PP\n");
                 } else if (MMAN_sp & outflags)                  } else if (MMAN_sp & outflags)
                         printf("\n.sp\n");                          printf("\n.sp\n");
Line 326  print_word(const char *s)
Line 334  print_word(const char *s)
                  */                   */
                 if (MMAN_spc_force & outflags || '\0' == s[0] ||                  if (MMAN_spc_force & outflags || '\0' == s[0] ||
                     NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1]) {                      NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1]) {
                         if (MMAN_Bk & outflags) {                          if (MMAN_Bk & outflags)
                                 putchar('\\');                                  putchar('\\');
                                 putchar('~');                          putchar(' ');
                         } else  
                                 putchar(' ');  
                         if (TPremain)                          if (TPremain)
                                 TPremain--;                                  TPremain--;
                 }                  }
Line 350  print_word(const char *s)
Line 356  print_word(const char *s)
         for ( ; *s; s++) {          for ( ; *s; s++) {
                 switch (*s) {                  switch (*s) {
                 case (ASCII_NBRSP):                  case (ASCII_NBRSP):
                         printf("\\~");                          printf("\\ ");
                         break;                          break;
                 case (ASCII_HYPH):                  case (ASCII_HYPH):
                         putchar('-');                          putchar('-');
Line 379  print_block(const char *s, int newflags)
Line 385  print_block(const char *s, int newflags)
 {  {
   
         outflags &= ~MMAN_PP;          outflags &= ~MMAN_PP;
         if (MMAN_sp & outflags)          if (MMAN_sp & outflags) {
                 outflags &= ~(MMAN_sp | MMAN_br);                  outflags &= ~(MMAN_sp | MMAN_br);
         else                  if (MMAN_PD & outflags) {
                 print_line(".sp -1v", 0);                          print_line(".PD", 0);
                           outflags &= ~MMAN_PD;
                   }
           } else if (! (MMAN_PD & outflags)) {
                   print_line(".PD 0", 0);
                   outflags |= MMAN_PD;
           }
         outflags |= MMAN_nl;          outflags |= MMAN_nl;
         print_word(s);          print_word(s);
         outflags |= newflags;          outflags |= newflags;
Line 521  man_mdoc(void *arg, const struct mdoc *mdoc)
Line 533  man_mdoc(void *arg, const struct mdoc *mdoc)
         meta = mdoc_meta(mdoc);          meta = mdoc_meta(mdoc);
         n = mdoc_node(mdoc);          n = mdoc_node(mdoc);
   
         printf(".TH \"%s\" \"%s\" \"%s\" \"%s\" \"%s\"",          printf(".TH \"%s\" \"%s\" \"%s\" \"%s\" \"%s\"\n",
                         meta->title, meta->msec, meta->date,                          meta->title, meta->msec, meta->date,
                         meta->os, meta->vol);                          meta->os, meta->vol);
   
           /* Disable hyphenation and if nroff, disable justification. */
           printf(".nh\n.if n .ad l");
   
         outflags = MMAN_nl | MMAN_Sm;          outflags = MMAN_nl | MMAN_Sm;
         if (0 == fontqueue.size) {          if (0 == fontqueue.size) {
                 fontqueue.size = 8;                  fontqueue.size = 8;
Line 1039  pre_fl(DECL_ARGS)
Line 1054  pre_fl(DECL_ARGS)
 {  {
   
         font_push('B');          font_push('B');
         print_word("-");          print_word("\\-");
         outflags &= ~MMAN_spc;          outflags &= ~MMAN_spc;
         return(1);          return(1);
 }  }
Line 1517  pre_ux(DECL_ARGS)
Line 1532  pre_ux(DECL_ARGS)
         if (NULL == n->child)          if (NULL == n->child)
                 return(0);                  return(0);
         outflags &= ~MMAN_spc;          outflags &= ~MMAN_spc;
         print_word("\\~");          print_word("\\ ");
         outflags &= ~MMAN_spc;          outflags &= ~MMAN_spc;
         return(1);          return(1);
 }  }

Legend:
Removed from v.1.43  
changed lines
  Added in v.1.45

CVSweb