1 /******************************************************************************
2 
3 gif_lib.h - service library for decoding and encoding GIF images
4 
5 *****************************************************************************/
6 
7 #ifndef _GIF_LIB_H_
8 #define _GIF_LIB_H_ 1
9 
10 #ifdef __cplusplus
11 extern "C" {
12 #endif /* __cplusplus */
13 
14 #define GIFLIB_MAJOR 5
15 #define GIFLIB_MINOR 1
16 #define GIFLIB_RELEASE 4
17 
18 #define GIF_ERROR   0
19 #define GIF_OK      1
20 
21 #include <stddef.h>
22 #include <stdbool.h>
23 
24 #define GIF_STAMP "GIFVER"          /* First chars in file - GIF stamp.  */
25 #define GIF_STAMP_LEN sizeof(GIF_STAMP) - 1
26 #define GIF_VERSION_POS 3           /* Version first character in stamp. */
27 #define GIF87_STAMP "GIF87a"        /* First chars in file - GIF stamp.  */
28 #define GIF89_STAMP "GIF89a"        /* First chars in file - GIF stamp.  */
29 
30 typedef unsigned char GifPixelType;
31 typedef unsigned char *GifRowType;
32 typedef unsigned char GifByteType;
33 typedef unsigned int GifPrefixType;
34 typedef int GifWord;
35 
36 typedef struct GifColorType {
37     GifByteType Red, Green, Blue;
38 } GifColorType;
39 
40 typedef struct ColorMapObject {
41     int ColorCount;
42     int BitsPerPixel;
43     bool SortFlag;
44     GifColorType *Colors;    /* on malloc(3) heap */
45 } ColorMapObject;
46 
47 typedef struct GifImageDesc {
48     GifWord Left, Top, Width, Height;   /* Current image dimensions. */
49     bool Interlace;                     /* Sequential/Interlaced lines. */
50     ColorMapObject *ColorMap;           /* The local color map */
51 } GifImageDesc;
52 
53 typedef struct ExtensionBlock {
54     int ByteCount;
55     GifByteType *Bytes; /* on malloc(3) heap */
56     int Function;       /* The block function code */
57 #define CONTINUE_EXT_FUNC_CODE    0x00    /* continuation subblock */
58 #define COMMENT_EXT_FUNC_CODE     0xfe    /* comment */
59 #define GRAPHICS_EXT_FUNC_CODE    0xf9    /* graphics control (GIF89) */
60 #define PLAINTEXT_EXT_FUNC_CODE   0x01    /* plaintext */
61 #define APPLICATION_EXT_FUNC_CODE 0xff    /* application block */
62 } ExtensionBlock;
63 
64 typedef struct SavedImage {
65     GifImageDesc ImageDesc;
66     GifByteType *RasterBits;         /* on malloc(3) heap */
67     int ExtensionBlockCount;         /* Count of extensions before image */
68     ExtensionBlock *ExtensionBlocks; /* Extensions before image */
69 } SavedImage;
70 
71 typedef struct GifFileType {
72     GifWord SWidth, SHeight;         /* Size of virtual canvas */
73     GifWord SColorResolution;        /* How many colors can we generate? */
74     GifWord SBackGroundColor;        /* Background color for virtual canvas */
75     GifByteType AspectByte;	     /* Used to compute pixel aspect ratio */
76     ColorMapObject *SColorMap;       /* Global colormap, NULL if nonexistent. */
77     int ImageCount;                  /* Number of current image (both APIs) */
78     GifImageDesc Image;              /* Current image (low-level API) */
79     SavedImage *SavedImages;         /* Image sequence (high-level API) */
80     int ExtensionBlockCount;         /* Count extensions past last image */
81     ExtensionBlock *ExtensionBlocks; /* Extensions past last image */
82     int Error;			     /* Last error condition reported */
83     void *UserData;                  /* hook to attach user data (TVT) */
84     void *Private;                   /* Don't mess with this! */
85 } GifFileType;
86 
87 #define GIF_ASPECT_RATIO(n)	((n)+15.0/64.0)
88 
89 typedef enum {
90     UNDEFINED_RECORD_TYPE,
91     SCREEN_DESC_RECORD_TYPE,
92     IMAGE_DESC_RECORD_TYPE, /* Begin with ',' */
93     EXTENSION_RECORD_TYPE,  /* Begin with '!' */
94     TERMINATE_RECORD_TYPE   /* Begin with ';' */
95 } GifRecordType;
96 
97 /* func type to read gif data from arbitrary sources (TVT) */
98 typedef int (*InputFunc) (GifFileType *, GifByteType *, int);
99 
100 /* func type to write gif data to arbitrary targets.
101  * Returns count of bytes written. (MRB)
102  */
103 typedef int (*OutputFunc) (GifFileType *, const GifByteType *, int);
104 
105 /******************************************************************************
106  GIF89 structures
107 ******************************************************************************/
108 
109 typedef struct GraphicsControlBlock {
110     int DisposalMode;
111 #define DISPOSAL_UNSPECIFIED      0       /* No disposal specified. */
112 #define DISPOSE_DO_NOT            1       /* Leave image in place */
113 #define DISPOSE_BACKGROUND        2       /* Set area too background color */
114 #define DISPOSE_PREVIOUS          3       /* Restore to previous content */
115     bool UserInputFlag;      /* User confirmation required before disposal */
116     int DelayTime;           /* pre-display delay in 0.01sec units */
117     int TransparentColor;    /* Palette index for transparency, -1 if none */
118 #define NO_TRANSPARENT_COLOR	-1
119 } GraphicsControlBlock;
120 
121 /******************************************************************************
122  GIF encoding routines
123 ******************************************************************************/
124 
125 /* Main entry points */
126 GifFileType *EGifOpenFileName(const char *GifFileName,
127                               const bool GifTestExistence, int *Error);
128 GifFileType *EGifOpenFileHandle(const int GifFileHandle, int *Error);
129 GifFileType *EGifOpen(void *userPtr, OutputFunc writeFunc, int *Error);
130 int EGifSpew(GifFileType * GifFile);
131 const char *EGifGetGifVersion(GifFileType *GifFile); /* new in 5.x */
132 int EGifCloseFile(GifFileType *GifFile, int *ErrorCode);
133 
134 #define E_GIF_SUCCEEDED          0
135 #define E_GIF_ERR_OPEN_FAILED    1    /* And EGif possible errors. */
136 #define E_GIF_ERR_WRITE_FAILED   2
137 #define E_GIF_ERR_HAS_SCRN_DSCR  3
138 #define E_GIF_ERR_HAS_IMAG_DSCR  4
139 #define E_GIF_ERR_NO_COLOR_MAP   5
140 #define E_GIF_ERR_DATA_TOO_BIG   6
141 #define E_GIF_ERR_NOT_ENOUGH_MEM 7
142 #define E_GIF_ERR_DISK_IS_FULL   8
143 #define E_GIF_ERR_CLOSE_FAILED   9
144 #define E_GIF_ERR_NOT_WRITEABLE  10
145 
146 /* These are legacy.  You probably do not want to call them directly */
147 int EGifPutScreenDesc(GifFileType *GifFile,
148                       const int GifWidth, const int GifHeight,
149 		      const int GifColorRes,
150                       const int GifBackGround,
151                       const ColorMapObject *GifColorMap);
152 int EGifPutImageDesc(GifFileType *GifFile,
153 		     const int GifLeft, const int GifTop,
154                      const int GifWidth, const int GifHeight,
155 		     const bool GifInterlace,
156                      const ColorMapObject *GifColorMap);
157 void EGifSetGifVersion(GifFileType *GifFile, const bool gif89);
158 int EGifPutLine(GifFileType *GifFile, GifPixelType *GifLine,
159                 int GifLineLen);
160 int EGifPutPixel(GifFileType *GifFile, const GifPixelType GifPixel);
161 int EGifPutComment(GifFileType *GifFile, const char *GifComment);
162 int EGifPutExtensionLeader(GifFileType *GifFile, const int GifExtCode);
163 int EGifPutExtensionBlock(GifFileType *GifFile,
164                          const int GifExtLen, const void *GifExtension);
165 int EGifPutExtensionTrailer(GifFileType *GifFile);
166 int EGifPutExtension(GifFileType *GifFile, const int GifExtCode,
167 		     const int GifExtLen,
168                      const void *GifExtension);
169 int EGifPutCode(GifFileType *GifFile, int GifCodeSize,
170                 const GifByteType *GifCodeBlock);
171 int EGifPutCodeNext(GifFileType *GifFile,
172                     const GifByteType *GifCodeBlock);
173 
174 /******************************************************************************
175  GIF decoding routines
176 ******************************************************************************/
177 
178 /* Main entry points */
179 GifFileType *DGifOpenFileName(const char *GifFileName, int *Error);
180 GifFileType *DGifOpenFileHandle(int GifFileHandle, int *Error);
181 int DGifSlurp(GifFileType * GifFile);
182 GifFileType *DGifOpen(void *userPtr, InputFunc readFunc, int *Error);    /* new one (TVT) */
183     int DGifCloseFile(GifFileType * GifFile, int *ErrorCode);
184 
185 #define D_GIF_SUCCEEDED          0
186 #define D_GIF_ERR_OPEN_FAILED    101    /* And DGif possible errors. */
187 #define D_GIF_ERR_READ_FAILED    102
188 #define D_GIF_ERR_NOT_GIF_FILE   103
189 #define D_GIF_ERR_NO_SCRN_DSCR   104
190 #define D_GIF_ERR_NO_IMAG_DSCR   105
191 #define D_GIF_ERR_NO_COLOR_MAP   106
192 #define D_GIF_ERR_WRONG_RECORD   107
193 #define D_GIF_ERR_DATA_TOO_BIG   108
194 #define D_GIF_ERR_NOT_ENOUGH_MEM 109
195 #define D_GIF_ERR_CLOSE_FAILED   110
196 #define D_GIF_ERR_NOT_READABLE   111
197 #define D_GIF_ERR_IMAGE_DEFECT   112
198 #define D_GIF_ERR_EOF_TOO_SOON   113
199 
200 /* These are legacy.  You probably do not want to call them directly */
201 int DGifGetScreenDesc(GifFileType *GifFile);
202 int DGifGetRecordType(GifFileType *GifFile, GifRecordType *GifType);
203 int DGifGetImageDesc(GifFileType *GifFile);
204 int DGifGetLine(GifFileType *GifFile, GifPixelType *GifLine, int GifLineLen);
205 int DGifGetPixel(GifFileType *GifFile, GifPixelType GifPixel);
206 int DGifGetComment(GifFileType *GifFile, char *GifComment);
207 int DGifGetExtension(GifFileType *GifFile, int *GifExtCode,
208                      GifByteType **GifExtension);
209 int DGifGetExtensionNext(GifFileType *GifFile, GifByteType **GifExtension);
210 int DGifGetCode(GifFileType *GifFile, int *GifCodeSize,
211                 GifByteType **GifCodeBlock);
212 int DGifGetCodeNext(GifFileType *GifFile, GifByteType **GifCodeBlock);
213 int DGifGetLZCodes(GifFileType *GifFile, int *GifCode);
214 
215 
216 /******************************************************************************
217  Color table quantization (deprecated)
218 ******************************************************************************/
219 int GifQuantizeBuffer(unsigned int Width, unsigned int Height,
220                    int *ColorMapSize, GifByteType * RedInput,
221                    GifByteType * GreenInput, GifByteType * BlueInput,
222                    GifByteType * OutputBuffer,
223                    GifColorType * OutputColorMap);
224 
225 /******************************************************************************
226  Error handling and reporting.
227 ******************************************************************************/
228 extern const char *GifErrorString(int ErrorCode);     /* new in 2012 - ESR */
229 
230 /*****************************************************************************
231  Everything below this point is new after version 1.2, supporting `slurp
232  mode' for doing I/O in two big belts with all the image-bashing in core.
233 ******************************************************************************/
234 
235 /******************************************************************************
236  Color map handling from gif_alloc.c
237 ******************************************************************************/
238 
239 extern ColorMapObject *GifMakeMapObject(int ColorCount,
240                                      const GifColorType *ColorMap);
241 extern void GifFreeMapObject(ColorMapObject *Object);
242 extern ColorMapObject *GifUnionColorMap(const ColorMapObject *ColorIn1,
243                                      const ColorMapObject *ColorIn2,
244                                      GifPixelType ColorTransIn2[]);
245 extern int GifBitSize(int n);
246 
247 extern void *
248 reallocarray(void *optr, size_t nmemb, size_t size);
249 
250 /******************************************************************************
251  Support for the in-core structures allocation (slurp mode).
252 ******************************************************************************/
253 
254 extern void GifApplyTranslation(SavedImage *Image, GifPixelType Translation[]);
255 extern int GifAddExtensionBlock(int *ExtensionBlock_Count,
256 				ExtensionBlock **ExtensionBlocks,
257 				int Function,
258 				unsigned int Len, unsigned char ExtData[]);
259 extern void GifFreeExtensions(int *ExtensionBlock_Count,
260 			      ExtensionBlock **ExtensionBlocks);
261 extern SavedImage *GifMakeSavedImage(GifFileType *GifFile,
262                                   const SavedImage *CopyFrom);
263 extern void GifFreeSavedImages(GifFileType *GifFile);
264 
265 /******************************************************************************
266  5.x functions for GIF89 graphics control blocks
267 ******************************************************************************/
268 
269 int DGifExtensionToGCB(const size_t GifExtensionLength,
270 		       const GifByteType *GifExtension,
271 		       GraphicsControlBlock *GCB);
272 size_t EGifGCBToExtension(const GraphicsControlBlock *GCB,
273 		       GifByteType *GifExtension);
274 
275 int DGifSavedExtensionToGCB(GifFileType *GifFile,
276 			    int ImageIndex,
277 			    GraphicsControlBlock *GCB);
278 int EGifGCBToSavedExtension(const GraphicsControlBlock *GCB,
279 			    GifFileType *GifFile,
280 			    int ImageIndex);
281 
282 /******************************************************************************
283  The library's internal utility font
284 ******************************************************************************/
285 
286 #define GIF_FONT_WIDTH  8
287 #define GIF_FONT_HEIGHT 8
288 extern const unsigned char GifAsciiTable8x8[][GIF_FONT_WIDTH];
289 
290 extern void GifDrawText8x8(SavedImage *Image,
291                      const int x, const int y,
292                      const char *legend, const int color);
293 
294 extern void GifDrawBox(SavedImage *Image,
295                     const int x, const int y,
296                     const int w, const int d, const int color);
297 
298 extern void GifDrawRectangle(SavedImage *Image,
299                    const int x, const int y,
300                    const int w, const int d, const int color);
301 
302 extern void GifDrawBoxedText8x8(SavedImage *Image,
303                           const int x, const int y,
304                           const char *legend,
305                           const int border, const int bg, const int fg);
306 
307 #ifdef __cplusplus
308 }
309 #endif /* __cplusplus */
310 #endif /* _GIF_LIB_H */
311 
312 /* end */
313