2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
6 % CCCC OOO M M PPPP RRRR EEEEE SSSSS SSSSS %
7 % C O O MM MM P P R R E SS SS %
8 % C O O M M M PPPP RRRR EEE SSS SSS %
9 % C O O M M P R R E SS SS %
10 % CCCC OOO M M P R R EEEEE SSSSS SSSSS %
13 % MagickCore Image Compression/Decompression Methods %
20 % Copyright 1999-2012 ImageMagick Studio LLC, a non-profit organization %
21 % dedicated to making software imaging solutions freely available. %
23 % You may not use this file except in compliance with the License. You may %
24 % obtain a copy of the License at %
26 % http://www.imagemagick.org/script/license.php %
28 % Unless required by applicable law or agreed to in writing, software %
29 % distributed under the License is distributed on an "AS IS" BASIS, %
30 % WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %
31 % See the License for the specific language governing permissions and %
32 % limitations under the License. %
34 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
43 #include "MagickCore/studio.h"
44 #include "MagickCore/attribute.h"
45 #include "MagickCore/blob.h"
46 #include "MagickCore/blob-private.h"
47 #include "MagickCore/color-private.h"
48 #include "MagickCore/cache.h"
49 #include "MagickCore/compress.h"
50 #include "MagickCore/constitute.h"
51 #include "MagickCore/exception.h"
52 #include "MagickCore/exception-private.h"
53 #include "MagickCore/image-private.h"
54 #include "MagickCore/list.h"
55 #include "MagickCore/memory_.h"
56 #include "MagickCore/monitor.h"
57 #include "MagickCore/monitor-private.h"
58 #include "MagickCore/option.h"
59 #include "MagickCore/pixel-accessor.h"
60 #include "MagickCore/resource_.h"
61 #include "MagickCore/string_.h"
62 #if defined(MAGICKCORE_TIFF_DELEGATE)
63 #if defined(MAGICKCORE_HAVE_TIFFCONF_H)
67 #define CCITTParam "-1"
69 #define CCITTParam "0"
71 #if defined(MAGICKCORE_ZLIB_DELEGATE)
88 typedef struct HuffmanTable
98 Huffman coding declarations.
106 static const HuffmanTable
109 { MBId, 0x0f, 10, 64 }, { MBId, 0xc8, 12, 128 },
110 { MBId, 0xc9, 12, 192 }, { MBId, 0x5b, 12, 256 },
111 { MBId, 0x33, 12, 320 }, { MBId, 0x34, 12, 384 },
112 { MBId, 0x35, 12, 448 }, { MBId, 0x6c, 13, 512 },
113 { MBId, 0x6d, 13, 576 }, { MBId, 0x4a, 13, 640 },
114 { MBId, 0x4b, 13, 704 }, { MBId, 0x4c, 13, 768 },
115 { MBId, 0x4d, 13, 832 }, { MBId, 0x72, 13, 896 },
116 { MBId, 0x73, 13, 960 }, { MBId, 0x74, 13, 1024 },
117 { MBId, 0x75, 13, 1088 }, { MBId, 0x76, 13, 1152 },
118 { MBId, 0x77, 13, 1216 }, { MBId, 0x52, 13, 1280 },
119 { MBId, 0x53, 13, 1344 }, { MBId, 0x54, 13, 1408 },
120 { MBId, 0x55, 13, 1472 }, { MBId, 0x5a, 13, 1536 },
121 { MBId, 0x5b, 13, 1600 }, { MBId, 0x64, 13, 1664 },
122 { MBId, 0x65, 13, 1728 }, { MBId, 0x00, 0, 0 }
125 static const HuffmanTable
128 { EXId, 0x08, 11, 1792 }, { EXId, 0x0c, 11, 1856 },
129 { EXId, 0x0d, 11, 1920 }, { EXId, 0x12, 12, 1984 },
130 { EXId, 0x13, 12, 2048 }, { EXId, 0x14, 12, 2112 },
131 { EXId, 0x15, 12, 2176 }, { EXId, 0x16, 12, 2240 },
132 { EXId, 0x17, 12, 2304 }, { EXId, 0x1c, 12, 2368 },
133 { EXId, 0x1d, 12, 2432 }, { EXId, 0x1e, 12, 2496 },
134 { EXId, 0x1f, 12, 2560 }, { EXId, 0x00, 0, 0 }
137 static const HuffmanTable
140 { MWId, 0x1b, 5, 64 }, { MWId, 0x12, 5, 128 },
141 { MWId, 0x17, 6, 192 }, { MWId, 0x37, 7, 256 },
142 { MWId, 0x36, 8, 320 }, { MWId, 0x37, 8, 384 },
143 { MWId, 0x64, 8, 448 }, { MWId, 0x65, 8, 512 },
144 { MWId, 0x68, 8, 576 }, { MWId, 0x67, 8, 640 },
145 { MWId, 0xcc, 9, 704 }, { MWId, 0xcd, 9, 768 },
146 { MWId, 0xd2, 9, 832 }, { MWId, 0xd3, 9, 896 },
147 { MWId, 0xd4, 9, 960 }, { MWId, 0xd5, 9, 1024 },
148 { MWId, 0xd6, 9, 1088 }, { MWId, 0xd7, 9, 1152 },
149 { MWId, 0xd8, 9, 1216 }, { MWId, 0xd9, 9, 1280 },
150 { MWId, 0xda, 9, 1344 }, { MWId, 0xdb, 9, 1408 },
151 { MWId, 0x98, 9, 1472 }, { MWId, 0x99, 9, 1536 },
152 { MWId, 0x9a, 9, 1600 }, { MWId, 0x18, 6, 1664 },
153 { MWId, 0x9b, 9, 1728 }, { MWId, 0x00, 0, 0 }
156 static const HuffmanTable
159 { TBId, 0x37, 10, 0 }, { TBId, 0x02, 3, 1 }, { TBId, 0x03, 2, 2 },
160 { TBId, 0x02, 2, 3 }, { TBId, 0x03, 3, 4 }, { TBId, 0x03, 4, 5 },
161 { TBId, 0x02, 4, 6 }, { TBId, 0x03, 5, 7 }, { TBId, 0x05, 6, 8 },
162 { TBId, 0x04, 6, 9 }, { TBId, 0x04, 7, 10 }, { TBId, 0x05, 7, 11 },
163 { TBId, 0x07, 7, 12 }, { TBId, 0x04, 8, 13 }, { TBId, 0x07, 8, 14 },
164 { TBId, 0x18, 9, 15 }, { TBId, 0x17, 10, 16 }, { TBId, 0x18, 10, 17 },
165 { TBId, 0x08, 10, 18 }, { TBId, 0x67, 11, 19 }, { TBId, 0x68, 11, 20 },
166 { TBId, 0x6c, 11, 21 }, { TBId, 0x37, 11, 22 }, { TBId, 0x28, 11, 23 },
167 { TBId, 0x17, 11, 24 }, { TBId, 0x18, 11, 25 }, { TBId, 0xca, 12, 26 },
168 { TBId, 0xcb, 12, 27 }, { TBId, 0xcc, 12, 28 }, { TBId, 0xcd, 12, 29 },
169 { TBId, 0x68, 12, 30 }, { TBId, 0x69, 12, 31 }, { TBId, 0x6a, 12, 32 },
170 { TBId, 0x6b, 12, 33 }, { TBId, 0xd2, 12, 34 }, { TBId, 0xd3, 12, 35 },
171 { TBId, 0xd4, 12, 36 }, { TBId, 0xd5, 12, 37 }, { TBId, 0xd6, 12, 38 },
172 { TBId, 0xd7, 12, 39 }, { TBId, 0x6c, 12, 40 }, { TBId, 0x6d, 12, 41 },
173 { TBId, 0xda, 12, 42 }, { TBId, 0xdb, 12, 43 }, { TBId, 0x54, 12, 44 },
174 { TBId, 0x55, 12, 45 }, { TBId, 0x56, 12, 46 }, { TBId, 0x57, 12, 47 },
175 { TBId, 0x64, 12, 48 }, { TBId, 0x65, 12, 49 }, { TBId, 0x52, 12, 50 },
176 { TBId, 0x53, 12, 51 }, { TBId, 0x24, 12, 52 }, { TBId, 0x37, 12, 53 },
177 { TBId, 0x38, 12, 54 }, { TBId, 0x27, 12, 55 }, { TBId, 0x28, 12, 56 },
178 { TBId, 0x58, 12, 57 }, { TBId, 0x59, 12, 58 }, { TBId, 0x2b, 12, 59 },
179 { TBId, 0x2c, 12, 60 }, { TBId, 0x5a, 12, 61 }, { TBId, 0x66, 12, 62 },
180 { TBId, 0x67, 12, 63 }, { TBId, 0x00, 0, 0 }
183 static const HuffmanTable
186 { TWId, 0x35, 8, 0 }, { TWId, 0x07, 6, 1 }, { TWId, 0x07, 4, 2 },
187 { TWId, 0x08, 4, 3 }, { TWId, 0x0b, 4, 4 }, { TWId, 0x0c, 4, 5 },
188 { TWId, 0x0e, 4, 6 }, { TWId, 0x0f, 4, 7 }, { TWId, 0x13, 5, 8 },
189 { TWId, 0x14, 5, 9 }, { TWId, 0x07, 5, 10 }, { TWId, 0x08, 5, 11 },
190 { TWId, 0x08, 6, 12 }, { TWId, 0x03, 6, 13 }, { TWId, 0x34, 6, 14 },
191 { TWId, 0x35, 6, 15 }, { TWId, 0x2a, 6, 16 }, { TWId, 0x2b, 6, 17 },
192 { TWId, 0x27, 7, 18 }, { TWId, 0x0c, 7, 19 }, { TWId, 0x08, 7, 20 },
193 { TWId, 0x17, 7, 21 }, { TWId, 0x03, 7, 22 }, { TWId, 0x04, 7, 23 },
194 { TWId, 0x28, 7, 24 }, { TWId, 0x2b, 7, 25 }, { TWId, 0x13, 7, 26 },
195 { TWId, 0x24, 7, 27 }, { TWId, 0x18, 7, 28 }, { TWId, 0x02, 8, 29 },
196 { TWId, 0x03, 8, 30 }, { TWId, 0x1a, 8, 31 }, { TWId, 0x1b, 8, 32 },
197 { TWId, 0x12, 8, 33 }, { TWId, 0x13, 8, 34 }, { TWId, 0x14, 8, 35 },
198 { TWId, 0x15, 8, 36 }, { TWId, 0x16, 8, 37 }, { TWId, 0x17, 8, 38 },
199 { TWId, 0x28, 8, 39 }, { TWId, 0x29, 8, 40 }, { TWId, 0x2a, 8, 41 },
200 { TWId, 0x2b, 8, 42 }, { TWId, 0x2c, 8, 43 }, { TWId, 0x2d, 8, 44 },
201 { TWId, 0x04, 8, 45 }, { TWId, 0x05, 8, 46 }, { TWId, 0x0a, 8, 47 },
202 { TWId, 0x0b, 8, 48 }, { TWId, 0x52, 8, 49 }, { TWId, 0x53, 8, 50 },
203 { TWId, 0x54, 8, 51 }, { TWId, 0x55, 8, 52 }, { TWId, 0x24, 8, 53 },
204 { TWId, 0x25, 8, 54 }, { TWId, 0x58, 8, 55 }, { TWId, 0x59, 8, 56 },
205 { TWId, 0x5a, 8, 57 }, { TWId, 0x5b, 8, 58 }, { TWId, 0x4a, 8, 59 },
206 { TWId, 0x4b, 8, 60 }, { TWId, 0x32, 8, 61 }, { TWId, 0x33, 8, 62 },
207 { TWId, 0x34, 8, 63 }, { TWId, 0x00, 0, 0 }
211 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
215 % A S C I I 8 5 E n c o d e %
219 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
221 % ASCII85Encode() encodes data in ASCII base-85 format. ASCII base-85
222 % encoding produces five ASCII printing characters from every four bytes of
225 % The format of the ASCII85Encode method is:
227 % void Ascii85Encode(Image *image,const size_t code)
229 % A description of each parameter follows:
231 % o code: a binary unsigned char to encode to ASCII 85.
233 % o file: write the encoded ASCII character to this file.
237 #define MaxLineExtent 36
239 static char *Ascii85Tuple(unsigned char *data)
252 code=((((size_t) data[0] << 8) | (size_t) data[1]) << 16) |
253 ((size_t) data[2] << 8) | (size_t) data[3];
260 quantum=85UL*85UL*85UL*85UL;
261 for (i=0; i < 4; i++)
263 x=(ssize_t) (code/quantum);
265 tuple[i]=(char) (x+(int) '!');
268 tuple[4]=(char) ((code % 85L)+(int) '!');
273 MagickExport void Ascii85Initialize(Image *image)
276 Allocate image structure.
278 if (image->ascii85 == (Ascii85Info *) NULL)
279 image->ascii85=(Ascii85Info *) AcquireMagickMemory(sizeof(*image->ascii85));
280 if (image->ascii85 == (Ascii85Info *) NULL)
281 ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
282 (void) ResetMagickMemory(image->ascii85,0,sizeof(*image->ascii85));
283 image->ascii85->line_break=MaxLineExtent << 1;
284 image->ascii85->offset=0;
287 MagickExport void Ascii85Flush(Image *image)
292 assert(image != (Image *) NULL);
293 assert(image->signature == MagickSignature);
294 if (image->debug != MagickFalse)
295 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
296 assert(image->ascii85 != (Ascii85Info *) NULL);
297 if (image->ascii85->offset > 0)
299 image->ascii85->buffer[image->ascii85->offset]='\0';
300 image->ascii85->buffer[image->ascii85->offset+1]='\0';
301 image->ascii85->buffer[image->ascii85->offset+2]='\0';
302 tuple=Ascii85Tuple(image->ascii85->buffer);
303 (void) WriteBlob(image,(size_t) image->ascii85->offset+1,
304 (const unsigned char *) (*tuple == 'z' ? "!!!!" : tuple));
306 (void) WriteBlobByte(image,'~');
307 (void) WriteBlobByte(image,'>');
308 (void) WriteBlobByte(image,'\n');
311 MagickExport void Ascii85Encode(Image *image,const unsigned char code)
316 register unsigned char
322 assert(image != (Image *) NULL);
323 assert(image->signature == MagickSignature);
324 assert(image->ascii85 != (Ascii85Info *) NULL);
325 image->ascii85->buffer[image->ascii85->offset]=code;
326 image->ascii85->offset++;
327 if (image->ascii85->offset < 4)
329 p=image->ascii85->buffer;
330 for (n=image->ascii85->offset; n >= 4; n-=4)
332 for (q=Ascii85Tuple(p); *q != '\0'; q++)
334 image->ascii85->line_break--;
335 if ((image->ascii85->line_break < 0) && (*q != '%'))
337 (void) WriteBlobByte(image,'\n');
338 image->ascii85->line_break=2*MaxLineExtent;
340 (void) WriteBlobByte(image,(unsigned char) *q);
344 image->ascii85->offset=n;
346 for (n=0; n < 4; n++)
347 image->ascii85->buffer[n]=(*p++);
351 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
355 % H u f f m a n D e c o d e I m a g e %
359 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
361 % HuffmanDecodeImage() uncompresses an image via Huffman-coding.
363 % The format of the HuffmanDecodeImage method is:
365 % MagickBooleanType HuffmanDecodeImage(Image *image,
366 % ExceptionInfo *exception)
368 % A description of each parameter follows:
370 % o image: the image.
372 % o exception: return any errors or warnings in this structure.
376 static inline size_t MagickMax(const size_t x,const size_t y)
383 static inline size_t MagickMin(const size_t x,const size_t y)
390 MagickExport MagickBooleanType HuffmanDecodeImage(Image *image,
391 ExceptionInfo *exception)
393 #define HashSize 1021
399 #define InitializeHashTable(hash,table,a,b) \
402 while (entry->code != 0) \
404 hash[((entry->length+a)*(entry->code+b)) % HashSize]=(HuffmanTable *) entry; \
409 #define InputBit(bit) \
411 if ((mask & 0xff) == 0) \
413 byte=ReadBlobByte(image); \
419 bit=(size_t) ((byte & mask) != 0 ? 0x01 : 0x00); \
447 register unsigned char
472 assert(image != (Image *) NULL);
473 assert(image->signature == MagickSignature);
474 if (image->debug != MagickFalse)
475 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
476 mb_hash=(HuffmanTable **) AcquireQuantumMemory(HashSize,sizeof(*mb_hash));
477 mw_hash=(HuffmanTable **) AcquireQuantumMemory(HashSize,sizeof(*mw_hash));
478 scanline=(unsigned char *) AcquireQuantumMemory((size_t) image->columns,
480 if ((mb_hash == (HuffmanTable **) NULL) ||
481 (mw_hash == (HuffmanTable **) NULL) ||
482 (scanline == (unsigned char *) NULL))
483 ThrowBinaryException(ResourceLimitError,"MemoryAllocationFailed",
486 Initialize Huffman tables.
488 for (i=0; i < HashSize; i++)
490 mb_hash[i]=(HuffmanTable *) NULL;
491 mw_hash[i]=(HuffmanTable *) NULL;
493 InitializeHashTable(mw_hash,TWTable,MWHashA,MWHashB);
494 InitializeHashTable(mw_hash,MWTable,MWHashA,MWHashB);
495 InitializeHashTable(mw_hash,EXTable,MWHashA,MWHashB);
496 InitializeHashTable(mb_hash,TBTable,MBHashA,MBHashB);
497 InitializeHashTable(mb_hash,MBTable,MBHashA,MBHashB);
498 InitializeHashTable(mb_hash,EXTable,MBHashA,MBHashB);
500 Uncompress 1D Huffman to runlength encoded pixels.
506 while (runlength < 11)
508 do { InputBit(bit); } while ((int) bit == 0);
509 image->resolution.x=204.0;
510 image->resolution.y=196.0;
511 image->units=PixelsPerInchResolution;
512 image_view=AcquireAuthenticCacheView(image,exception);
513 for (y=0; ((y < (ssize_t) image->rows) && (null_lines < 3)); )
522 Initialize scanline to white.
525 for (x=0; x < (ssize_t) image->columns; x++)
526 *p++=(unsigned char) 0;
528 Decode Huffman encoded scanline.
540 if (x >= (ssize_t) image->columns)
542 while (runlength < 11)
544 do { InputBit(bit); } while ((int) bit == 0);
564 code=(code << 1)+(size_t) bit;
567 if (bail != MagickFalse)
571 while (runlength < 11)
573 do { InputBit(bit); } while ((int) bit == 0);
576 if (color != MagickFalse)
580 entry=mw_hash[((length+MWHashA)*(code+MWHashB)) % HashSize];
586 entry=mb_hash[((length+MBHashA)*(code+MBHashB)) % HashSize];
588 if (entry == (const HuffmanTable *) NULL)
590 if ((entry->length != length) || (entry->code != code))
597 count+=(ssize_t) entry->count;
598 if ((x+count) > (ssize_t) image->columns)
599 count=(ssize_t) image->columns-x;
602 if (color != MagickFalse)
608 for ( ; count > 0; count--)
609 scanline[x++]=(unsigned char) 1;
612 ((color == MagickFalse) ? MagickTrue : MagickFalse);
619 count+=(ssize_t) entry->count;
629 Transfer scanline to image pixels.
632 q=QueueCacheViewAuthenticPixels(image_view,0,y,image->columns,1,exception);
633 if (q == (Quantum *) NULL)
635 for (x=0; x < (ssize_t) image->columns; x++)
637 index=(Quantum) (*p++);
638 SetPixelIndex(image,index,q);
639 SetPixelInfoPixel(image,image->colormap+(ssize_t) index,q);
640 q+=GetPixelChannels(image);
642 if (SyncCacheViewAuthenticPixels(image_view,exception) == MagickFalse)
644 proceed=SetImageProgress(image,LoadImageTag,y,image->rows);
645 if (proceed == MagickFalse)
649 image_view=DestroyCacheView(image_view);
650 image->rows=(size_t) MagickMax((size_t) y-3,1);
651 image->compression=FaxCompression;
655 mw_hash=(HuffmanTable **) RelinquishMagickMemory(mw_hash);
656 mb_hash=(HuffmanTable **) RelinquishMagickMemory(mb_hash);
657 scanline=(unsigned char *) RelinquishMagickMemory(scanline);
662 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
666 % H u f f m a n E n c o d e I m a g e %
670 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
672 % HuffmanEncodeImage() compresses an image via Huffman-coding.
674 % The format of the HuffmanEncodeImage method is:
676 % MagickBooleanType HuffmanEncodeImage(const ImageInfo *image_info,
677 % Image *image,Image *inject_image,ExceptionInfo *exception)
679 % A description of each parameter follows:
681 % o image_info: the image info..
683 % o image: the image.
685 % o inject_image: inject into the image stream.
687 % o exception: return any errors or warnings in this structure.
690 MagickExport MagickBooleanType HuffmanEncodeImage(const ImageInfo *image_info,
691 Image *image,Image *inject_image,ExceptionInfo *exception)
693 #define HuffmanOutputCode(entry) \
695 mask=one << (entry->length-1); \
698 OutputBit(((entry->code & mask) != 0 ? 1 : 0)); \
703 #define OutputBit(count) \
708 if ((int) (bit & 0xff) == 0) \
710 if (LocaleCompare(image_info->magick,"FAX") == 0) \
711 (void) WriteBlobByte(image,(unsigned char) byte); \
713 Ascii85Encode(image,byte); \
715 bit=(unsigned char) 0x80; \
736 register const Quantum
739 register unsigned char
757 Allocate scanline buffer.
759 assert(image_info != (ImageInfo *) NULL);
760 assert(image_info->signature == MagickSignature);
761 assert(image != (Image *) NULL);
762 assert(image->signature == MagickSignature);
763 if (image->debug != MagickFalse)
764 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
765 assert(inject_image != (Image *) NULL);
766 assert(inject_image->signature == MagickSignature);
768 width=inject_image->columns;
769 if (LocaleCompare(image_info->magick,"FAX") == 0)
770 width=(size_t) MagickMax(inject_image->columns,1728);
771 scanline=(unsigned char *) AcquireQuantumMemory((size_t) width+1UL,
773 if (scanline == (unsigned char *) NULL)
774 ThrowBinaryException(ResourceLimitError,"MemoryAllocationFailed",
775 inject_image->filename);
776 (void) ResetMagickMemory(scanline,0,width*sizeof(*scanline));
777 huffman_image=CloneImage(inject_image,0,0,MagickTrue,exception);
778 if (huffman_image == (Image *) NULL)
780 scanline=(unsigned char *) RelinquishMagickMemory(scanline);
783 (void) SetImageType(huffman_image,BilevelType,exception);
785 bit=(unsigned char) 0x80;
786 if (LocaleCompare(image_info->magick,"FAX") != 0)
787 Ascii85Initialize(image);
793 for (k=0; k < 11; k++)
798 Compress to 1D Huffman pixels.
801 for (y=0; y < (ssize_t) huffman_image->rows; y++)
803 p=GetVirtualPixels(huffman_image,0,y,huffman_image->columns,1,exception);
804 if (p == (const Quantum *) NULL)
806 for (x=0; x < (ssize_t) huffman_image->columns; x++)
808 *q++=(unsigned char) (GetPixelIntensity(huffman_image,p) >=
809 ((MagickRealType) QuantumRange/2.0) ? 0 : 1);
810 p+=GetPixelChannels(huffman_image);
813 Huffman encode scanline.
816 for (n=(ssize_t) width; n > 0; )
821 for (runlength=0; ((n > 0) && (*q == 0)); n--)
828 if (runlength < 1792)
829 entry=MWTable+((runlength/64)-1);
831 entry=EXTable+(MagickMin((size_t) runlength,2560)-1792)/64;
832 runlength-=(long) entry->count;
833 HuffmanOutputCode(entry);
835 entry=TWTable+MagickMin((size_t) runlength,63);
836 HuffmanOutputCode(entry);
842 for (runlength=0; ((*q != 0) && (n > 0)); n--)
849 entry=MBTable+((runlength/64)-1);
850 if (runlength >= 1792)
851 entry=EXTable+(MagickMin((size_t) runlength,2560)-1792)/64;
852 runlength-=(long) entry->count;
853 HuffmanOutputCode(entry);
855 entry=TBTable+MagickMin((size_t) runlength,63);
856 HuffmanOutputCode(entry);
862 for (k=0; k < 11; k++)
866 if (GetPreviousImageInList(huffman_image) == (Image *) NULL)
868 proceed=SetImageProgress(huffman_image,LoadImageTag,y,
869 huffman_image->rows);
870 if (proceed == MagickFalse)
877 for (i=0; i < 6; i++)
879 for (k=0; k < 11; k++)
886 if (((int) bit != 0x80) != 0)
888 if (LocaleCompare(image_info->magick,"FAX") == 0)
889 (void) WriteBlobByte(image,byte);
891 Ascii85Encode(image,byte);
893 if (LocaleCompare(image_info->magick,"FAX") != 0)
895 huffman_image=DestroyImage(huffman_image);
896 scanline=(unsigned char *) RelinquishMagickMemory(scanline);
901 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
905 % L Z W E n c o d e I m a g e %
909 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
911 % LZWEncodeImage() compresses an image via LZW-coding specific to Postscript
912 % Level II or Portable Document Format.
914 % The format of the LZWEncodeImage method is:
916 % MagickBooleanType LZWEncodeImage(Image *image,const size_t length,
917 % unsigned char *pixels,ExceptionInfo *exception)
919 % A description of each parameter follows:
921 % o image: the image.
923 % o length: A value that specifies the number of pixels to compress.
925 % o pixels: the address of an unsigned array of characters containing the
926 % pixels to compress.
928 % o exception: return any errors or warnings in this structure.
931 MagickExport MagickBooleanType LZWEncodeImage(Image *image,const size_t length,
932 unsigned char *pixels,ExceptionInfo *exception)
934 #define LZWClr 256UL /* Clear Table Marker */
935 #define LZWEod 257UL /* End of Data marker */
936 #define OutputCode(code) \
938 accumulator+=code << (32-code_width-number_bits); \
939 number_bits+=code_width; \
940 while (number_bits >= 8) \
942 (void) WriteBlobByte(image,(unsigned char) (accumulator >> 24)); \
943 accumulator=accumulator << 8; \
948 typedef struct _TableType
973 Allocate string table.
975 assert(image != (Image *) NULL);
976 assert(image->signature == MagickSignature);
977 if (image->debug != MagickFalse)
978 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
979 assert(pixels != (unsigned char *) NULL);
980 table=(TableType *) AcquireQuantumMemory(1UL << 12,sizeof(*table));
981 if (table == (TableType *) NULL)
984 Initialize variables.
991 for (index=0; index < 256; index++)
993 table[index].prefix=(-1);
994 table[index].suffix=(short) index;
995 table[index].next=(-1);
999 last_code=(size_t) pixels[0];
1000 for (i=1; i < (ssize_t) length; i++)
1005 index=(ssize_t) last_code;
1007 if ((table[index].prefix != (ssize_t) last_code) ||
1008 (table[index].suffix != (ssize_t) pixels[i]))
1009 index=table[index].next;
1012 last_code=(size_t) index;
1015 if (last_code != (size_t) index)
1020 OutputCode(last_code);
1021 table[next_index].prefix=(ssize_t) last_code;
1022 table[next_index].suffix=(short) pixels[i];
1023 table[next_index].next=table[last_code].next;
1024 table[last_code].next=(ssize_t) next_index;
1027 Did we just move up to next bit width?
1029 if ((next_index >> code_width) != 0)
1032 if (code_width > 12)
1035 Did we overflow the max bit width?
1039 for (index=0; index < 256; index++)
1041 table[index].prefix=(-1);
1042 table[index].suffix=index;
1043 table[index].next=(-1);
1045 next_index=LZWEod+1;
1049 last_code=(size_t) pixels[i];
1055 OutputCode(last_code);
1057 if (number_bits != 0)
1058 (void) WriteBlobByte(image,(unsigned char) (accumulator >> 24));
1059 table=(TableType *) RelinquishMagickMemory(table);
1064 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1068 % P a c k b i t s E n c o d e I m a g e %
1072 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1074 % PackbitsEncodeImage() compresses an image via Macintosh Packbits encoding
1075 % specific to Postscript Level II or Portable Document Format. To ensure
1076 % portability, the binary Packbits bytes are encoded as ASCII Base-85.
1078 % The format of the PackbitsEncodeImage method is:
1080 % MagickBooleanType PackbitsEncodeImage(Image *image,const size_t length,
1081 % unsigned char *pixels)
1083 % A description of each parameter follows:
1085 % o image: the image.
1087 % o length: A value that specifies the number of pixels to compress.
1089 % o pixels: the address of an unsigned array of characters containing the
1090 % pixels to compress.
1093 MagickExport MagickBooleanType PackbitsEncodeImage(Image *image,
1094 const size_t length,unsigned char *pixels,ExceptionInfo *exception)
1107 Compress pixels with Packbits encoding.
1109 assert(image != (Image *) NULL);
1110 assert(image->signature == MagickSignature);
1111 if (image->debug != MagickFalse)
1112 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
1113 assert(pixels != (unsigned char *) NULL);
1114 packbits=(unsigned char *) AcquireQuantumMemory(128UL,sizeof(*packbits));
1115 if (packbits == (unsigned char *) NULL)
1116 ThrowBinaryException(ResourceLimitError,"MemoryAllocationFailed",
1118 for (i=(ssize_t) length; i != 0; )
1125 (void) WriteBlobByte(image,(unsigned char) 0);
1126 (void) WriteBlobByte(image,*pixels);
1132 (void) WriteBlobByte(image,(unsigned char) 1);
1133 (void) WriteBlobByte(image,*pixels);
1134 (void) WriteBlobByte(image,pixels[1]);
1140 if ((*pixels == *(pixels+1)) && (*(pixels+1) == *(pixels+2)))
1142 (void) WriteBlobByte(image,(unsigned char) ((256-3)+1));
1143 (void) WriteBlobByte(image,*pixels);
1146 (void) WriteBlobByte(image,(unsigned char) 2);
1147 (void) WriteBlobByte(image,*pixels);
1148 (void) WriteBlobByte(image,pixels[1]);
1149 (void) WriteBlobByte(image,pixels[2]);
1154 if ((*pixels == *(pixels+1)) && (*(pixels+1) == *(pixels+2)))
1160 while (((ssize_t) count < i) && (*pixels == *(pixels+count)))
1167 (void) WriteBlobByte(image,(unsigned char) ((256-count)+1));
1168 (void) WriteBlobByte(image,*pixels);
1176 while ((*(pixels+count) != *(pixels+count+1)) ||
1177 (*(pixels+count+1) != *(pixels+count+2)))
1179 packbits[count+1]=pixels[count];
1181 if (((ssize_t) count >= (i-3)) || (count >= 127))
1185 *packbits=(unsigned char) (count-1);
1186 for (j=0; j <= (ssize_t) count; j++)
1187 (void) WriteBlobByte(image,packbits[j]);
1193 (void) WriteBlobByte(image,(unsigned char) 128); /* EOD marker */
1194 packbits=(unsigned char *) RelinquishMagickMemory(packbits);
1198 #if defined(MAGICKCORE_ZLIB_DELEGATE)
1200 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1204 % Z L I B E n c o d e I m a g e %
1208 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1210 % ZLIBEncodeImage compresses an image via ZLIB-coding specific to
1211 % Postscript Level II or Portable Document Format.
1213 % The format of the ZLIBEncodeImage method is:
1215 % MagickBooleanType ZLIBEncodeImage(Image *image,const size_t length,
1216 % unsigned char *pixels,ExceptionInfo *exception)
1218 % A description of each parameter follows:
1220 % o file: the address of a structure of type FILE. ZLIB encoded pixels
1221 % are written to this file.
1223 % o length: A value that specifies the number of pixels to compress.
1225 % o pixels: the address of an unsigned array of characters containing the
1226 % pixels to compress.
1228 % o exception: return any errors or warnings in this structure.
1232 static voidpf AcquireZIPMemory(voidpf context,unsigned int items,
1236 return((voidpf) AcquireQuantumMemory(items,size));
1239 static void RelinquishZIPMemory(voidpf context,voidpf memory)
1242 memory=RelinquishMagickMemory(memory);
1245 MagickExport MagickBooleanType ZLIBEncodeImage(Image *image,const size_t length,
1246 unsigned char *pixels,ExceptionInfo *exception)
1263 assert(image != (Image *) NULL);
1264 assert(image->signature == MagickSignature);
1265 if (image->debug != MagickFalse)
1266 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
1267 compress_packets=(size_t) (1.001*length+12);
1268 compress_pixels=(unsigned char *) AcquireQuantumMemory(compress_packets,
1269 sizeof(*compress_pixels));
1270 if (compress_pixels == (unsigned char *) NULL)
1271 ThrowBinaryException(ResourceLimitError,"MemoryAllocationFailed",
1273 stream.next_in=pixels;
1274 stream.avail_in=(unsigned int) length;
1275 stream.next_out=compress_pixels;
1276 stream.avail_out=(unsigned int) compress_packets;
1277 stream.zalloc=AcquireZIPMemory;
1278 stream.zfree=RelinquishZIPMemory;
1279 stream.opaque=(voidpf) NULL;
1280 status=deflateInit(&stream,(int) (image->quality ==
1281 UndefinedCompressionQuality ? 7 : MagickMin(image->quality/10,9)));
1284 status=deflate(&stream,Z_FINISH);
1285 if (status == Z_STREAM_END)
1286 status=deflateEnd(&stream);
1288 (void) deflateEnd(&stream);
1289 compress_packets=(size_t) stream.total_out;
1292 ThrowBinaryException(CoderError,"UnableToZipCompressImage",image->filename)
1294 for (i=0; i < (ssize_t) compress_packets; i++)
1295 (void) WriteBlobByte(image,compress_pixels[i]);
1296 compress_pixels=(unsigned char *) RelinquishMagickMemory(compress_pixels);
1297 return(status == Z_OK ? MagickTrue : MagickFalse);
1300 MagickExport MagickBooleanType ZLIBEncodeImage(Image *image,
1301 const size_t magick_unused(length),unsigned char *magick_unused(pixels),
1302 ExceptionInfo *exception)
1304 assert(image != (Image *) NULL);
1305 assert(image->signature == MagickSignature);
1306 if (image->debug != MagickFalse)
1307 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
1308 (void) ThrowMagickException(exception,GetMagickModule(),MissingDelegateError,
1309 "DelegateLibrarySupportNotBuiltIn","'%s' (ZIP)",image->filename);
1310 return(MagickFalse);