-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrle_raw_alc.c
154 lines (142 loc) · 3.97 KB
/
rle_raw_alc.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
/*
* This software is copyrighted as noted below. It may be freely copied,
* modified, and redistributed, provided that the copyright notice is
* preserved on all copies.
*
* There is no warranty or other guarantee of fitness for this software,
* it is provided solely "as is". Bug reports or fixes may be sent
* to the author, who may or may not act on them as he desires.
*
* You may not include this software in a program or other software product
* without supplying the source, or without informing the end-user that the
* source is available for no extra charge.
*
* If you modify this software, you should include a notice giving the
* name of the person performing the modification, the date of modification,
* and the reason for such modification.
*
* Modified at BRL 16-May-88 by Mike Muuss to avoid Alliant STDC desire
* to have all "void" functions so declared.
*/
/*
* rle_raw_alc.c - Allocate buffers for rle_getraw/rle_putraw.
*
* Author: Spencer W. Thomas
* Computer Science Dept.
* University of Utah
* Date: Fri Nov 14 1986
* Copyright (c) 1986, Spencer W. Thomas
*/
#include <stdio.h>
#include "rle.h"
#include "rle_raw.h"
/*****************************************************************
* TAG( rle_raw_alloc )
*
* Allocate buffer space for use by rle_getraw and rle_putraw.
* Inputs:
* the_hdr: Header structure for RLE file to be read or
* written.
* Outputs:
* scanp: Pointer to pointer to created opcode buffer.
* nrawp: Pointer to pointer to created length buffer.
* These pointers are adjusted for the alpha channel,
* if present.
* Returns 0 for success, -1 if malloc failed.
* Assumptions:
* Since buffers are built to have as many slots as there are pixels
* in the input scanline, it is assumed that no input scanline will
* have more data elements than this.
* Algorithm:
* Count number of channels actually used (check bitmap).
* Allocate nchan*rowlength elements, allocate a buffer
* to hold (ncolors+alpha) pointers.
* Also allocate a buffer of ncolors+alpha
* integers for the length buffer.
*/
int
rle_raw_alloc( the_hdr, scanp, nrawp )
rle_hdr *the_hdr;
rle_op ***scanp;
int **nrawp;
{
rle_op ** scanbuf = NULL;
rle_op *opbuf = NULL;
int rowlen, nchan = 0, i, ncol;
rowlen = the_hdr->xmax - the_hdr->xmin + 1;
if ( the_hdr->alpha && RLE_BIT( *the_hdr, RLE_ALPHA ) )
nchan++;
for ( i = 0; i < the_hdr->ncolors; i++ )
if ( RLE_BIT( *the_hdr, i ) )
nchan++;
ncol = the_hdr->ncolors + the_hdr->alpha;
if ( (scanbuf = (rle_op **) malloc( ncol * sizeof(rle_op *) )) == 0 )
return -1;
if ( (opbuf = (rle_op *)malloc( nchan * rowlen * sizeof(rle_op) )) == 0 )
{
free( scanbuf );
return -1;
}
if ( nrawp && (*nrawp = (int *)malloc( ncol * sizeof(int) )) == 0 )
{
free( scanbuf );
free( opbuf );
return -1;
}
if ( the_hdr->alpha )
{
scanbuf++;
if ( nrawp )
(*nrawp)++;
}
for ( i = -the_hdr->alpha; i < the_hdr->ncolors; i++ )
if ( RLE_BIT( *the_hdr, i ) )
{
scanbuf[i] = opbuf;
opbuf += rowlen;
}
else
scanbuf[i] = 0;
*scanp = scanbuf;
free( opbuf );
return 0;
}
/*****************************************************************
* TAG( rle_raw_free )
*
* Free storage allocated by rle_raw_alloc().
* Inputs:
* the_hdr: Header structure as above.
* scanp: Pointer to scanbuf above.
* nrawp: Pointer to length buffer.
* Outputs:
* Frees storage referenced by scanp and nrawp.
* Assumptions:
* Storage was allocated by rle_raw_alloc, or by use of same
* algorithm, at least.
* Algorithm:
* free scanp[0], scanp, and nrawp.
*/
void
rle_raw_free( the_hdr, scanp, nrawp )
rle_hdr *the_hdr;
rle_op **scanp;
int *nrawp ;
{
int i;
if ( the_hdr->alpha )
{
scanp--;
if ( nrawp )
nrawp--;
}
for ( i = 0; i < the_hdr->ncolors + the_hdr->alpha; i++ )
if ( scanp[i] != 0 )
{
free( (char *)scanp[i] );
break;
}
free( (char *)scanp );
if ( nrawp )
free( (char *)nrawp );
}