1 | /*
|
---|
2 |
|
---|
3 | gbmcvp.c - Portrait
|
---|
4 |
|
---|
5 | */
|
---|
6 |
|
---|
7 | /*...sincludes:0:*/
|
---|
8 | #include <stdio.h>
|
---|
9 | #include <ctype.h>
|
---|
10 | #include <stddef.h>
|
---|
11 | #include <stdlib.h>
|
---|
12 | #include <string.h>
|
---|
13 | #include "gbm.h"
|
---|
14 | #include "gbmhelp.h"
|
---|
15 |
|
---|
16 | /*...vgbm\46\h:0:*/
|
---|
17 | /*...vgbmhelp\46\h:0:*/
|
---|
18 | /*...e*/
|
---|
19 |
|
---|
20 | static GBMFT cvp_gbmft =
|
---|
21 | {
|
---|
22 | "Portrait",
|
---|
23 | "Portrait",
|
---|
24 | "CVP",
|
---|
25 | GBM_FT_R24|
|
---|
26 | GBM_FT_W24,
|
---|
27 | };
|
---|
28 |
|
---|
29 | #define GBM_ERR_CVP_FSIZE ((GBM_ERR) 1800)
|
---|
30 | #define GBM_ERR_CVP_SIZE ((GBM_ERR) 1801)
|
---|
31 |
|
---|
32 | /*...scvp_qft:0:*/
|
---|
33 | GBM_ERR cvp_qft(GBMFT *gbmft)
|
---|
34 | {
|
---|
35 | *gbmft = cvp_gbmft;
|
---|
36 | return GBM_ERR_OK;
|
---|
37 | }
|
---|
38 | /*...e*/
|
---|
39 | /*...scvp_rhdr:0:*/
|
---|
40 | GBM_ERR cvp_rhdr(const char *fn, int fd, GBM *gbm, const char *opt)
|
---|
41 | {
|
---|
42 | long length;
|
---|
43 |
|
---|
44 | fn=fn; fd=fd; opt=opt; /* Suppress 'unref arg' compiler warnings */
|
---|
45 |
|
---|
46 | length = gbm_file_lseek(fd, 0L, SEEK_END);
|
---|
47 | gbm_file_lseek(fd, 0L, SEEK_SET);
|
---|
48 |
|
---|
49 | if ( length != 512*512*3 )
|
---|
50 | return GBM_ERR_CVP_FSIZE;
|
---|
51 |
|
---|
52 | gbm->w = 512;
|
---|
53 | gbm->h = 512;
|
---|
54 | gbm->bpp = 24;
|
---|
55 |
|
---|
56 | return GBM_ERR_OK;
|
---|
57 | }
|
---|
58 | /*...e*/
|
---|
59 | /*...scvp_rpal:0:*/
|
---|
60 | GBM_ERR cvp_rpal(int fd, GBM *gbm, GBMRGB *gbmrgb)
|
---|
61 | {
|
---|
62 | fd=fd; gbm=gbm; gbmrgb=gbmrgb; /* Suppress 'unref arg' compiler warnings */
|
---|
63 |
|
---|
64 | return GBM_ERR_OK;
|
---|
65 | }
|
---|
66 | /*...e*/
|
---|
67 | /*...scvp_rdata:0:*/
|
---|
68 | GBM_ERR cvp_rdata(int fd, GBM *gbm, byte *data)
|
---|
69 | {
|
---|
70 | int p, stride = ((gbm->w*3+3)&~3);
|
---|
71 | byte *line;
|
---|
72 | if ( (line = malloc((size_t) gbm->w)) == NULL )
|
---|
73 | return GBM_ERR_MEM;
|
---|
74 | for ( p = 2; p >= 0; p-- )
|
---|
75 | {
|
---|
76 | int y;
|
---|
77 | byte *ptr = data + ( (stride * (gbm->h-1)) + p );
|
---|
78 | for ( y = 0; y < gbm->h; y++, ptr-=stride )
|
---|
79 | {
|
---|
80 | int x;
|
---|
81 | if ( gbm_file_read(fd, line, gbm->w) != gbm->w )
|
---|
82 | {
|
---|
83 | free(line);
|
---|
84 | return GBM_ERR_READ;
|
---|
85 | }
|
---|
86 | for ( x = 0; x < gbm->w; x++ )
|
---|
87 | ptr[x*3] = line[gbm->w-1-x];
|
---|
88 | }
|
---|
89 | }
|
---|
90 | free(line);
|
---|
91 | return GBM_ERR_OK;
|
---|
92 | }
|
---|
93 | /*...e*/
|
---|
94 | /*...scvp_w:0:*/
|
---|
95 | GBM_ERR cvp_w(const char *fn, int fd, const GBM *gbm, const GBMRGB *gbmrgb, const byte *data, const char *opt)
|
---|
96 | {
|
---|
97 | int p, stride = ((gbm->w*3+3)&~3);
|
---|
98 | byte *line;
|
---|
99 |
|
---|
100 | fn=fn; gbmrgb=gbmrgb; opt=opt; /* Suppress 'unref arg' compiler warning */
|
---|
101 |
|
---|
102 | if ( gbm->bpp != 24 )
|
---|
103 | return GBM_ERR_NOT_SUPP;
|
---|
104 |
|
---|
105 | if ( gbm->w != 512 || gbm->h != 512 )
|
---|
106 | return GBM_ERR_CVP_SIZE;
|
---|
107 |
|
---|
108 | if ( (line = malloc((size_t) gbm->w)) == NULL )
|
---|
109 | return GBM_ERR_MEM;
|
---|
110 |
|
---|
111 | for ( p = 2; p >= 0; p-- )
|
---|
112 | {
|
---|
113 | int y;
|
---|
114 | const byte *ptr = data + ( (stride * (gbm->h-1)) + p );
|
---|
115 | for ( y = 0; y < gbm->h; y++, ptr-=stride )
|
---|
116 | {
|
---|
117 | int x;
|
---|
118 | for ( x = 0; x < gbm->w; x++ )
|
---|
119 | line[gbm->w-1-x] = ptr[x*3];
|
---|
120 | if ( gbm_file_write(fd, line, gbm->w) != gbm->w )
|
---|
121 | {
|
---|
122 | free(line);
|
---|
123 | return GBM_ERR_WRITE;
|
---|
124 | }
|
---|
125 | }
|
---|
126 | }
|
---|
127 | free(line);
|
---|
128 | return GBM_ERR_OK;
|
---|
129 | }
|
---|
130 | /*...e*/
|
---|
131 | /*...scvp_err:0:*/
|
---|
132 | const char *cvp_err(GBM_ERR rc)
|
---|
133 | {
|
---|
134 | switch ( (int) rc )
|
---|
135 | {
|
---|
136 | case GBM_ERR_CVP_FSIZE:
|
---|
137 | return "file is not correct size";
|
---|
138 | case GBM_ERR_CVP_SIZE:
|
---|
139 | return "portrait files can only hold 512x512 images";
|
---|
140 | }
|
---|
141 | return NULL;
|
---|
142 | }
|
---|
143 | /*...e*/
|
---|