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

Diff for /mandoc/Attic/mdocml.c between version 1.8 and 1.16

version 1.8, 2008/11/23 22:30:53 version 1.16, 2008/12/03 19:21:58
Line 30 
Line 30 
   
 #include "libmdocml.h"  #include "libmdocml.h"
   
 #define BUFFER_IN_DEF   BUFSIZ  #define BUFFER_IN_DEF   BUFSIZ   /* See begin_bufs. */
 #define BUFFER_OUT_DEF  BUFSIZ  #define BUFFER_OUT_DEF  BUFSIZ   /* See begin_bufs. */
   
 static void              usage(void);  static  void             usage(void);
 static int               begin_io(const struct md_args *,  
   static  int              begin_io(const struct md_args *,
                                 char *, char *);                                  char *, char *);
 static int               leave_io(const struct md_buf *,  static  int              leave_io(const struct md_buf *,
                                 const struct md_buf *, int);                                  const struct md_buf *, int);
 static int               begin_bufs(const struct md_args *,  static  int              begin_bufs(const struct md_args *,
                                 struct md_buf *, struct md_buf *);                                  struct md_buf *, struct md_buf *);
 static int               leave_bufs(const struct md_buf *,  static int               leave_bufs(const struct md_buf *,
                                 const struct md_buf *, int);                                  const struct md_buf *, int);
Line 47  int
Line 48  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
 {  {
         int              c;          int              c;
         char            *out, *in;          char            *out, *in, *filter;
         struct md_args   args;          struct md_args   args;
   
         extern char     *optarg;          extern char     *optarg;
         extern int       optind;          extern int       optind;
   
         out = in = NULL;          out = in = filter = NULL;
   
           (void)memset(&args, 0, sizeof(struct md_args));
   
         while (-1 != (c = getopt(argc, argv, "o:")))          while (-1 != (c = getopt(argc, argv, "f:o:vW")))
                 switch (c) {                  switch (c) {
                   case ('f'):
                           filter = optarg;
                           break;
                 case ('o'):                  case ('o'):
                         out = optarg;                          out = optarg;
                         break;                          break;
                   case ('v'):
                           args.verbosity++;
                           break;
                   case ('W'):
                           args.warnings |= MD_WARN_ALL;
                           break;
                 default:                  default:
                         usage();                          usage();
                         return(1);                          return(1);
Line 71  main(int argc, char *argv[])
Line 83  main(int argc, char *argv[])
         if (1 == argc)          if (1 == argc)
                 in = *argv++;                  in = *argv++;
   
         args.type = MD_HTML4_STRICT;          if (filter) {
         args.dbg = MD_DBG_TREE;                  if (0 == strcmp(filter, "html"))
                           args.type = MD_HTML;
                   else if (0 == strcmp(filter, "xml"))
                           args.type = MD_XML;
                   else
                           errx(1, "invalid filter type");
           } else
                   args.type = MD_XML;
   
         return(begin_io(&args, out ? out : "-", in ? in : "-"));          return(begin_io(&args, out ? out : "-", in ? in : "-"));
 }  }
   
   
   /*
    * Close out file descriptors opened in begin_io.  If the descriptor
    * refers to stdin/stdout, then do nothing.
    */
 static int  static int
 leave_io(const struct md_buf *out,  leave_io(const struct md_buf *out,
                 const struct md_buf *in, int c)                  const struct md_buf *in, int c)
Line 96  leave_io(const struct md_buf *out, 
Line 119  leave_io(const struct md_buf *out, 
                 warn("%s", out->name);                  warn("%s", out->name);
                 c = 1;                  c = 1;
         }          }
           if (1 == c && STDOUT_FILENO != out->fd)
                   if (-1 == unlink(out->name))
                           warn("%s", out->name);
   
         return(c);          return(c);
 }  }
   
   
   /*
    * Open file descriptors or assign stdin/stdout, if dictated by the "-"
    * token instead of a filename.
    */
 static int  static int
 begin_io(const struct md_args *args, char *out, char *in)  begin_io(const struct md_args *args, char *out, char *in)
 {  {
Line 139  begin_io(const struct md_args *args, char *out, char *
Line 169  begin_io(const struct md_args *args, char *out, char *
 }  }
   
   
   /*
    * Free buffers allocated in begin_bufs.
    */
 static int  static int
 leave_bufs(const struct md_buf *out,  leave_bufs(const struct md_buf *out,
                 const struct md_buf *in, int c)                  const struct md_buf *in, int c)
Line 153  leave_bufs(const struct md_buf *out, 
Line 186  leave_bufs(const struct md_buf *out, 
 }  }
   
   
   /*
    * Allocate buffers to the maximum of either the input file's blocksize
    * or BUFFER_IN_DEF/BUFFER_OUT_DEF, which should be around BUFSIZE.
    */
 static int  static int
 begin_bufs(const struct md_args *args,  begin_bufs(const struct md_args *args,
                 struct md_buf *out, struct md_buf *in)                  struct md_buf *out, struct md_buf *in)
Line 167  begin_bufs(const struct md_args *args, 
Line 204  begin_bufs(const struct md_args *args, 
         if (-1 == fstat(in->fd, &stin)) {          if (-1 == fstat(in->fd, &stin)) {
                 warn("%s", in->name);                  warn("%s", in->name);
                 return(1);                  return(1);
         } else if (0 == stin.st_size) {          } else if (STDIN_FILENO != in->fd && 0 == stin.st_size) {
                 warnx("%s: empty file", in->name);                  warnx("%s: empty file", in->name);
                 return(1);                  return(1);
         } else if (-1 == fstat(out->fd, &stout)) {          } else if (-1 == fstat(out->fd, &stout)) {
Line 196  usage(void)
Line 233  usage(void)
 {  {
         extern char     *__progname;          extern char     *__progname;
   
         (void)printf("usage: %s [-o outfile] [infile]\n", __progname);          (void)printf("usage: %s [-vW] [-f filter] [-o outfile] "
                           "[infile]\n", __progname);
 }  }

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

CVSweb