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

Diff for /mandoc/Attic/ml.c between version 1.1 and 1.4

version 1.1, 2008/12/02 18:26:57 version 1.4, 2008/12/04 16:19:52
Line 21 
Line 21 
   
 #include "libmdocml.h"  #include "libmdocml.h"
 #include "private.h"  #include "private.h"
   #include "ml.h"
   
   #ifdef __linux__
   extern  size_t            strlcat(char *, const char *, size_t);
   extern  size_t            strlcpy(char *, const char *, size_t);
   #endif
   
 #define MAXINDENT        8  
   
 static ssize_t           ml_puts(struct md_mbuf *, const char *);  int
 static ssize_t           ml_putchar(struct md_mbuf *, char);  ml_nputstring(struct md_mbuf *p,
 static ssize_t           ml_putstring(struct md_mbuf *, const char *);                  const char *buf, size_t sz, size_t *pos)
   
   
 static ssize_t  
 ml_puts(struct md_mbuf *p, const char *buf)  
 {  {
   
         return(ml_nputs(p, buf, strlen(buf)));  
 }  
   
   
 static ssize_t  
 ml_putchar(struct md_mbuf *p, char buf)  
 {  
   
         return(ml_nputs(p, &buf, 1));  
 }  
   
   
 static ssize_t  
 ml_putstring(struct md_mbuf *p, const char *buf)  
 {  
   
         return(ml_nputstring(p, buf, strlen(buf)));  
 }  
   
   
 ssize_t  
 ml_begintag(struct md_mbuf *p, const char *name,  
                 int *argc, char **argv)  
 {  
         int              i;          int              i;
         ssize_t          res, sz;          const char      *seq;
           size_t           ssz;
   
         res = 0;          for (i = 0; i < (int)sz; i++) {
                   switch (buf[i]) {
   
         if (-1 == (sz = ml_nputs(p, "<", 1)))                  /* Ampersand ml-escape. */
                 return(-1);                  case ('&'):
         res += sz;                          seq = "&amp;";
                           ssz = 5;
                           break;
   
         if (-1 == (sz = ml_puts(p, name)))                  /* Quotation ml-escape. */
                 return(-1);                  case ('"'):
         res += sz;                          seq = "&quot;";
                           ssz = 6;
                           break;
   
         for (i = 0; ROFF_ARGMAX != argc[i]; i++) {                  /* Lt ml-escape. */
                 if (-1 == (sz = ml_nputs(p, " ", 1)))                  case ('<'):
                         return(-1);                          seq = "&lt;";
                 res += sz;                          ssz = 4;
                           break;
   
                 if (-1 == (sz = ml_puts(p, tokargnames[argc[i]])))                  /* Gt ml-escape. */
                         return(-1);                  case ('>'):
                 res += sz;                          seq = "&gt;";
                           ssz = 4;
                           break;
   
                 if (-1 == (sz = ml_nputs(p, "=\"", 2)))                  default:
                         return(-1);                          seq = &buf[i];
                 res += sz;                          ssz = 1;
                           break;
                   }
   
                 if (-1 == (sz = ml_putstring(p, argv[i] ?                  if ( ! ml_nputs(p, seq, ssz, pos))
                                                 argv[i] : "true")))  
                         return(-1);                          return(-1);
                 res += sz;  
   
                 if (-1 == (sz = ml_nputs(p, "\"", 1)))  
                         return(-1);  
                 res += sz;  
         }          }
           return(1);
         if (-1 == (sz = ml_nputs(p, ">", 1)))  
                 return(-1);  
   
         return(res + sz);  
 }  }
   
   
 ssize_t  int
 ml_endtag(struct md_mbuf *p, const char *tag)  ml_nputs(struct md_mbuf *p, const char *buf, size_t sz, size_t *pos)
 {  {
         ssize_t          res, sz;  
   
         res = 0;          if (0 == sz)
                   return(1);
   
         if (-1 == (sz = ml_nputs(p, "</", 2)))          if ( ! md_buf_puts(p, buf, sz))
                 return(-1);                  return(0);
         res += sz;  
   
         if (-1 == (sz = ml_puts(p, tag)))          *pos += sz;
                 return(-1);          return(1);
         res += sz;  
   
         if (-1 == (sz = ml_nputs(p, ">", 1)))  
                 return(-1);  
   
         return(res + sz);  
 }  }
   
   
 ssize_t  int
 ml_nputstring(struct md_mbuf *p, const char *buf, size_t bufsz)  ml_puts(struct md_mbuf *p, const char *buf, size_t *pos)
 {  {
         int              i;          size_t           sz;
         ssize_t          res, sz;  
   
         res = 0;          if (0 == (sz = strlen(buf)))
                   return(1);
   
         for (i = 0; i < (int)bufsz; i++) {          if ( ! md_buf_puts(p, buf, sz))
                 switch (buf[i]) {                  return(0);
                 case ('&'):          *pos += sz;
                         if (-1 == (sz = ml_nputs(p, "&amp;", 5)))          return(1);
                                 return(-1);  
                         break;  
                 case ('"'):  
                         if (-1 == (sz = ml_nputs(p, "&quot;", 6)))  
                                 return(-1);  
                         break;  
                 case ('<'):  
                         if (-1 == (sz = ml_nputs(p, "&lt;", 4)))  
                                 return(-1);  
                         break;  
                 case ('>'):  
                         if (-1 == (sz = ml_nputs(p, "&gt;", 4)))  
                                 return(-1);  
                         break;  
                 default:  
                         if (-1 == (sz = ml_putchar(p, buf[i])))  
                                 return(-1);  
                         break;  
                 }  
                 res += sz;  
         }  
         return(res);  
 }  }
   
   
 ssize_t  int
 ml_nputs(struct md_mbuf *p, const char *buf, size_t sz)  ml_putchars(struct md_mbuf *p, char buf, size_t count, size_t *pos)
 {  {
   
         return(0 == md_buf_puts(p, buf, sz) ? -1 : (ssize_t)sz);  
 }  
   
   
 ssize_t  
 ml_indent(struct md_mbuf *p, int indent)  
 {  
         size_t           i;          size_t           i;
         ssize_t          res, sz;  
   
         res = sz  0;          for (i = 0; i < count; i++)
                   if ( ! ml_nputs(p, &buf, 1, pos))
                           return(0);
   
         /* LINTED */          return(1);
         for (i = 0; i < MIN(indent, MAXINDENT); i++, res += sz)  
                 if (-1 == (sz = ml_nputs(p, "    ", 4)))  
                         return(-1);  
         return(res);  
 }  }

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.4

CVSweb