ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/px/pflip.c
(Generate patch)

Comparing ray/src/px/pflip.c (file contents):
Revision 1.3 by greg, Wed Jan 9 12:21:09 1991 UTC vs.
Revision 2.9 by greg, Tue Aug 8 18:04:41 2006 UTC

# Line 1 | Line 1
1 /* Copyright (c) 1991 Regents of the University of California */
2
1   #ifndef lint
2 < static char SCCSid[] = "$SunId$ LBL";
2 > static const char       RCSid[] = "$Id$";
3   #endif
6
4   /*
5   * flip picture file horizontally and/or vertically
6   */
7  
8   #include <stdio.h>
9 + #include  <time.h>
10 + #include  <string.h>
11  
12 + #include "platform.h"
13   #include "color.h"
14 + #include "resolu.h"
15  
16 < int     xres, yres;                     /* input resolution */
16 > int     order;                          /* input orientation */
17 > int     xres, yres;                     /* resolution (scanlen, nscans) */
18  
19   long    *scanpos;                       /* scanline positions */
20  
21 < int     fhoriz, fvert;                  /* flip flags */
21 > int     fhoriz=0, fvert=0;              /* flip flags */
22  
23 + int     correctorder = 0;               /* correcting orientation? */
24 +
25   FILE    *fin;                           /* input file */
26  
27   char    *progname;
28  
29  
30 < main(argc, argv)
31 < int     argc;
32 < char    *argv[];
30 > static void memerr(void);
31 > static void scanfile(void);
32 > static void flip(void);
33 >
34 >
35 > static int
36 > neworder(void)                  /* figure out new order from old */
37   {
38 <        int     i;
38 >        register int  no;
39  
40 +        if (correctorder)
41 +                return(order);          /* just leave it */
42 +        if ((no = order) & YMAJOR) {
43 +                if (fhoriz) no ^= XDECR;
44 +                if (fvert) no ^= YDECR;
45 +        } else {
46 +                if (fhoriz) no ^= YDECR;
47 +                if (fvert) no ^= XDECR;
48 +        }
49 +        return(no);
50 + }
51 +
52 + int
53 + main(
54 +        int     argc,
55 +        char    *argv[]
56 + )
57 + {
58 +        static char     picfmt[LPICFMT+1] = PICFMT;
59 +        int     i, rval;
60 +        SET_DEFAULT_BINARY();
61 +        SET_FILE_BINARY(stdout);
62          progname = argv[0];
63  
64          for (i = 1; i < argc; i++)
# Line 36 | Line 66 | char   *argv[];
66                          fhoriz++;
67                  else if (!strcmp(argv[i], "-v"))
68                          fvert++;
69 +                else if (!strcmp(argv[i], "-c"))
70 +                        correctorder++;
71                  else
72                          break;
73          if (i >= argc || argv[i][0] == '-') {
74 <                fprintf(stderr, "Usage: %s [-h][-v] infile [outfile]\n",
74 >                fprintf(stderr, "Usage: %s [-h][-v][-c] infile [outfile]\n",
75                                  progname);
76                  exit(1);
77          }
78          if ((fin = fopen(argv[i], "r")) == NULL) {
79 <                fprintf(stderr, "%s: cannot open\n", argv[1]);
79 >                fprintf(stderr, "%s: cannot open\n", argv[i]);
80                  exit(1);
81          }
82          if (i < argc-1 && freopen(argv[i+1], "w", stdout) == NULL) {
# Line 52 | Line 84 | char   *argv[];
84                  exit(1);
85          }
86                                          /* transfer header */
87 <        copyheader(fin, stdout);
87 >        if ((rval = checkheader(fin, picfmt, stdout)) < 0) {
88 >                fprintf(stderr, "%s: input not a Radiance picture\n",
89 >                                progname);
90 >                exit(1);
91 >        }
92 >        if (rval)
93 >                fputformat(picfmt, stdout);
94                                          /* add new header info. */
95          printargs(i, argv, stdout);
96          putchar('\n');
97                                          /* get picture size */
98 <        if (fgetresolu(&xres, &yres, fin) != (YMAJOR|YDECR)) {
98 >        if ((order = fgetresolu(&xres, &yres, fin)) < 0) {
99                  fprintf(stderr, "%s: bad picture size\n", progname);
100                  exit(1);
101          }
102                                          /* write new picture size */
103 <        fputresolu(YMAJOR|YDECR, xres, yres, stdout);
103 >        fputresolu(neworder(), xres, yres, stdout);
104                                          /* goto end if vertical flip */
105          if (fvert)
106                  scanfile();
# Line 71 | Line 109 | char   *argv[];
109   }
110  
111  
112 < memerr()
112 > static void
113 > memerr(void)
114   {
115          fprintf(stderr, "%s: out of memory\n", progname);
116          exit(1);
117   }
118  
119  
120 < scanfile()                              /* scan to the end of file */
120 > static void
121 > scanfile(void)                          /* scan to the end of file */
122   {
123          extern long     ftell();
124          COLR    *scanin;
# Line 88 | Line 128 | scanfile()                             /* scan to the end of file */
128                  memerr();
129          if ((scanin = (COLR *)malloc(xres*sizeof(COLR))) == NULL)
130                  memerr();
131 <        for (y = yres-1; y >= 0; y--) {
131 >        for (y = yres-1; y > 0; y--) {
132                  scanpos[y] = ftell(fin);
133                  if (freadcolrs(scanin, xres, fin) < 0) {
134                          fprintf(stderr, "%s: read error\n", progname);
135                          exit(1);
136                  }
137          }
138 <        free((char *)scanin);
138 >        scanpos[0] = ftell(fin);
139 >        free((void *)scanin);
140   }
141  
142  
143 < flip()                                  /* flip the picture */
143 > static void
144 > flip(void)                                      /* flip the picture */
145   {
146          COLR    *scanin, *scanout;
147          int     y;
# Line 129 | Line 171 | flip()                                 /* flip the picture */
171                          exit(1);
172                  }
173          }
174 <        free((char *)scanin);
175 <        free((char *)scanout);
174 >        free((void *)scanin);
175 >        if (fhoriz)
176 >                free((void *)scanout);
177   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines