]>
git.saurik.com Git - wxWidgets.git/blob - src/tiff/libtiff/mkg3states.c
4 * Copyright (c) 1991-1997 Sam Leffler
5 * Copyright (c) 1991-1997 Silicon Graphics, Inc.
7 * Permission to use, copy, modify, distribute, and sell this software and
8 * its documentation for any purpose is hereby granted without fee, provided
9 * that (i) the above copyright notices and this permission notice appear in
10 * all copies of the software and related documentation, and (ii) the names of
11 * Sam Leffler and Silicon Graphics may not be used in any advertising or
12 * publicity relating to the software without the specific, prior written
13 * permission of Sam Leffler and Silicon Graphics.
15 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
17 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
19 * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
20 * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
21 * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
22 * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
23 * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
27 /* Initialise fax decoder tables
28 * Decoder support is derived, with permission, from the code
29 * in Frank Cringle's viewfax program;
30 * Copyright (C) 1990, 1995 Frank D. Cringle.
32 #include "tif_config.h"
44 #define streq(a,b) (strcmp(a,b) == 0)
46 /* NB: can't use names in tif_fax3.h 'cuz they are declared const */
47 TIFFFaxTabEnt MainTable
[128];
48 TIFFFaxTabEnt WhiteTable
[4096];
49 TIFFFaxTabEnt BlackTable
[8192];
52 uint16 code
; /* right justified, lsb-first, zero filled */
53 uint16 val
; /* (pixel count)<<4 + code width */
56 static struct proto Pass
[] = {
61 static struct proto Horiz
[] = {
66 static struct proto V0
[] = {
71 static struct proto VR
[] = {
78 static struct proto VL
[] = {
85 static struct proto Ext
[] = {
90 static struct proto EOLV
[] = {
95 static struct proto MakeUpW
[] = {
126 static struct proto MakeUpB
[] = {
157 static struct proto MakeUp
[] = {
174 static struct proto TermW
[] = {
242 static struct proto TermB
[] = {
310 static struct proto EOLH
[] = {
316 FillTable(TIFFFaxTabEnt
*T
, int Size
, struct proto
*P
, int State
)
318 int limit
= 1 << Size
;
321 int width
= P
->val
& 15;
322 int param
= P
->val
>> 4;
323 int incr
= 1 << width
;
325 for (code
= P
->code
; code
< limit
; code
+= incr
) {
326 TIFFFaxTabEnt
*E
= T
+code
;
335 static char* storage_class
= "";
336 static char* const_class
= "";
337 static int packoutput
= 1;
338 static char* prebrace
= "";
339 static char* postbrace
= "";
342 WriteTable(FILE* fd
, const TIFFFaxTabEnt
* T
, int Size
, const char* name
)
347 fprintf(fd
, "%s %s TIFFFaxTabEnt %s[%d] = {",
348 storage_class
, const_class
, name
, Size
);
351 for (i
= 0; i
< Size
; i
++) {
352 fprintf(fd
, "%s%s%d,%d,%d%s",
353 sep
, prebrace
, T
->State
, T
->Width
, (int) T
->Param
, postbrace
);
354 if (((i
+1) % 10) == 0)
362 for (i
= 0; i
< Size
; i
++) {
363 fprintf(fd
, "%s%s%3d,%3d,%4d%s",
364 sep
, prebrace
, T
->State
, T
->Width
, (int) T
->Param
, postbrace
);
365 if (((i
+1) % 6) == 0)
372 fprintf(fd
, "\n};\n");
375 /* initialise the huffman code tables */
377 main(int argc
, char* argv
[])
385 while ((c
= getopt(argc
, argv
, "c:s:bp")) != -1)
388 const_class
= optarg
;
391 storage_class
= optarg
;
402 "usage: %s [-c const] [-s storage] [-p] [-b] file\n",
406 outputfile
= optind
< argc
? argv
[optind
] : "g3states.h";
407 fd
= fopen(outputfile
, "w");
409 fprintf(stderr
, "%s: %s: Cannot create output file.\n",
410 argv
[0], outputfile
);
413 FillTable(MainTable
, 7, Pass
, S_Pass
);
414 FillTable(MainTable
, 7, Horiz
, S_Horiz
);
415 FillTable(MainTable
, 7, V0
, S_V0
);
416 FillTable(MainTable
, 7, VR
, S_VR
);
417 FillTable(MainTable
, 7, VL
, S_VL
);
418 FillTable(MainTable
, 7, Ext
, S_Ext
);
419 FillTable(MainTable
, 7, EOLV
, S_EOL
);
420 FillTable(WhiteTable
, 12, MakeUpW
, S_MakeUpW
);
421 FillTable(WhiteTable
, 12, MakeUp
, S_MakeUp
);
422 FillTable(WhiteTable
, 12, TermW
, S_TermW
);
423 FillTable(WhiteTable
, 12, EOLH
, S_EOL
);
424 FillTable(BlackTable
, 13, MakeUpB
, S_MakeUpB
);
425 FillTable(BlackTable
, 13, MakeUp
, S_MakeUp
);
426 FillTable(BlackTable
, 13, TermB
, S_TermB
);
427 FillTable(BlackTable
, 13, EOLH
, S_EOL
);
429 fprintf(fd
, "/* WARNING, this file was automatically generated by the\n");
430 fprintf(fd
, " mkg3states program */\n");
431 fprintf(fd
, "#include \"tiff.h\"\n");
432 fprintf(fd
, "#include \"tif_fax3.h\"\n");
433 WriteTable(fd
, MainTable
, 128, "TIFFFaxMainTable");
434 WriteTable(fd
, WhiteTable
, 4096, "TIFFFaxWhiteTable");
435 WriteTable(fd
, BlackTable
, 8192, "TIFFFaxBlackTable");
440 /* vim: set ts=8 sts=8 sw=8 noet: */