* roottypes.cs: Rename from tree.cs.
[mono.git] / mcs / class / ICSharpCode.SharpZipLib / ICSharpCode.SharpZipLib / BZip2 / BZip2Constants.cs
1 // BZip2Constants.cs\r
2 // Copyright (C) 2001 Mike Krueger\r
3 //\r
4 // This program is free software; you can redistribute it and/or\r
5 // modify it under the terms of the GNU General Public License\r
6 // as published by the Free Software Foundation; either version 2\r
7 // of the License, or (at your option) any later version.\r
8 //\r
9 // This program is distributed in the hope that it will be useful,\r
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
12 // GNU General Public License for more details.\r
13 //\r
14 // You should have received a copy of the GNU General Public License\r
15 // along with this program; if not, write to the Free Software\r
16 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.\r
17 //\r
18 // Linking this library statically or dynamically with other modules is\r
19 // making a combined work based on this library.  Thus, the terms and\r
20 // conditions of the GNU General Public License cover the whole\r
21 // combination.\r
22 // \r
23 // As a special exception, the copyright holders of this library give you\r
24 // permission to link this library with independent modules to produce an\r
25 // executable, regardless of the license terms of these independent\r
26 // modules, and to copy and distribute the resulting executable under\r
27 // terms of your choice, provided that you also meet, for each linked\r
28 // independent module, the terms and conditions of the license of that\r
29 // module.  An independent module is a module which is not derived from\r
30 // or based on this library.  If you modify this library, you may extend\r
31 // this exception to your version of the library, but you are not\r
32 // obligated to do so.  If you do not wish to do so, delete this\r
33 // exception statement from your version.\r
34 \r
35 namespace ICSharpCode.SharpZipLib.BZip2 \r
36 {\r
37         \r
38         /// <summary>\r
39         /// Defines internal values for both compression and decompression\r
40         /// </summary>\r
41         public sealed class BZip2Constants\r
42         {\r
43                 /// <summary>\r
44                 /// Random numbers used to randomise repetitive blocks\r
45                 /// </summary>\r
46                 public readonly static int[] rNums = {\r
47                         619, 720, 127, 481, 931, 816, 813, 233, 566, 247,\r
48                         985, 724, 205, 454, 863, 491, 741, 242, 949, 214,\r
49                         733, 859, 335, 708, 621, 574,  73, 654, 730, 472,\r
50                         419, 436, 278, 496, 867, 210, 399, 680, 480,  51,\r
51                         878, 465, 811, 169, 869, 675, 611, 697, 867, 561,\r
52                         862, 687, 507, 283, 482, 129, 807, 591, 733, 623,\r
53                         150, 238,  59, 379, 684, 877, 625, 169, 643, 105,\r
54                         170, 607, 520, 932, 727, 476, 693, 425, 174, 647,\r
55                          73, 122, 335, 530, 442, 853, 695, 249, 445, 515,\r
56                         909, 545, 703, 919, 874, 474, 882, 500, 594, 612,\r
57                         641, 801, 220, 162, 819, 984, 589, 513, 495, 799,\r
58                         161, 604, 958, 533, 221, 400, 386, 867, 600, 782,\r
59                         382, 596, 414, 171, 516, 375, 682, 485, 911, 276,\r
60                          98, 553, 163, 354, 666, 933, 424, 341, 533, 870,\r
61                         227, 730, 475, 186, 263, 647, 537, 686, 600, 224,\r
62                         469,  68, 770, 919, 190, 373, 294, 822, 808, 206,\r
63                         184, 943, 795, 384, 383, 461, 404, 758, 839, 887,\r
64                         715,  67, 618, 276, 204, 918, 873, 777, 604, 560,\r
65                         951, 160, 578, 722,  79, 804,  96, 409, 713, 940,\r
66                         652, 934, 970, 447, 318, 353, 859, 672, 112, 785,\r
67                         645, 863, 803, 350, 139,  93, 354,  99, 820, 908,\r
68                         609, 772, 154, 274, 580, 184,  79, 626, 630, 742,\r
69                         653, 282, 762, 623, 680,  81, 927, 626, 789, 125,\r
70                         411, 521, 938, 300, 821,  78, 343, 175, 128, 250,\r
71                         170, 774, 972, 275, 999, 639, 495,  78, 352, 126,\r
72                         857, 956, 358, 619, 580, 124, 737, 594, 701, 612,\r
73                         669, 112, 134, 694, 363, 992, 809, 743, 168, 974,\r
74                         944, 375, 748,  52, 600, 747, 642, 182, 862,  81,\r
75                         344, 805, 988, 739, 511, 655, 814, 334, 249, 515,\r
76                         897, 955, 664, 981, 649, 113, 974, 459, 893, 228,\r
77                         433, 837, 553, 268, 926, 240, 102, 654, 459,  51,\r
78                         686, 754, 806, 760, 493, 403, 415, 394, 687, 700,\r
79                         946, 670, 656, 610, 738, 392, 760, 799, 887, 653,\r
80                         978, 321, 576, 617, 626, 502, 894, 679, 243, 440,\r
81                         680, 879, 194, 572, 640, 724, 926,  56, 204, 700,\r
82                         707, 151, 457, 449, 797, 195, 791, 558, 945, 679,\r
83                         297,  59,  87, 824, 713, 663, 412, 693, 342, 606,\r
84                         134, 108, 571, 364, 631, 212, 174, 643, 304, 329,\r
85                         343,  97, 430, 751, 497, 314, 983, 374, 822, 928,\r
86                         140, 206,  73, 263, 980, 736, 876, 478, 430, 305,\r
87                         170, 514, 364, 692, 829,  82, 855, 953, 676, 246,\r
88                         369, 970, 294, 750, 807, 827, 150, 790, 288, 923,\r
89                         804, 378, 215, 828, 592, 281, 565, 555, 710,  82,\r
90                         896, 831, 547, 261, 524, 462, 293, 465, 502,  56,\r
91                         661, 821, 976, 991, 658, 869, 905, 758, 745, 193,\r
92                         768, 550, 608, 933, 378, 286, 215, 979, 792, 961,\r
93                          61, 688, 793, 644, 986, 403, 106, 366, 905, 644,\r
94                         372, 567, 466, 434, 645, 210, 389, 550, 919, 135,\r
95                         780, 773, 635, 389, 707, 100, 626, 958, 165, 504,\r
96                         920, 176, 193, 713, 857, 265, 203,  50, 668, 108,\r
97                         645, 990, 626, 197, 510, 357, 358, 850, 858, 364,\r
98                         936, 638\r
99                 };\r
100 \r
101                 /// <summary>\r
102                 /// When multiplied by compression parameter (1-9) gives the block size for compression\r
103                 /// 9 gives the best compresssion but uses the most memory.\r
104                 /// </summary>          \r
105                 public readonly static int baseBlockSize = 100000;\r
106                 \r
107                 /// <summary>\r
108                 /// Backend constant\r
109                 /// </summary>\r
110                 public readonly static int MAX_ALPHA_SIZE = 258;\r
111                 \r
112                 /// <summary>\r
113                 /// Backend constant\r
114                 /// </summary>\r
115                 public readonly static int MAX_CODE_LEN = 23;\r
116                 \r
117                 /// <summary>\r
118                 /// Backend constant\r
119                 /// </summary>\r
120                 public readonly static int RUNA = 0;\r
121                 \r
122                 /// <summary>\r
123                 /// Backend constant\r
124                 /// </summary>\r
125                 public readonly static int RUNB = 1;\r
126                 \r
127                 /// <summary>\r
128                 /// Backend constant\r
129                 /// </summary>\r
130                 public readonly static int N_GROUPS = 6;\r
131                 \r
132                 /// <summary>\r
133                 /// Backend constant\r
134                 /// </summary>\r
135                 public readonly static int G_SIZE = 50;\r
136                 \r
137                 /// <summary>\r
138                 /// Backend constant\r
139                 /// </summary>\r
140                 public readonly static int N_ITERS = 4;\r
141                 \r
142                 /// <summary>\r
143                 /// Backend constant\r
144                 /// </summary>\r
145                 public readonly static int MAX_SELECTORS = (2 + (900000 / G_SIZE));\r
146                 \r
147                 /// <summary>\r
148                 /// Backend constant\r
149                 /// </summary>\r
150                 public readonly static int NUM_OVERSHOOT_BYTES = 20;\r
151                 \r
152                 private BZip2Constants()\r
153                 {\r
154                 }\r
155         }\r
156 }\r
157         \r
158 /* This file was derived from a file containing this license:\r
159  * \r
160  * This file is a part of bzip2 and/or libbzip2, a program and\r
161  * library for lossless, block-sorting data compression.\r
162  * \r
163  * Copyright (C) 1996-1998 Julian R Seward.  All rights reserved.\r
164  * \r
165  * Redistribution and use in source and binary forms, with or without\r
166  * modification, are permitted provided that the following conditions\r
167  * are met:\r
168  * \r
169  * 1. Redistributions of source code must retain the above copyright\r
170  * notice, this list of conditions and the following disclaimer.\r
171  * \r
172  * 2. The origin of this software must not be misrepresented; you must \r
173  * not claim that you wrote the original software.  If you use this \r
174  * software in a product, an acknowledgment in the product \r
175  * documentation would be appreciated but is not required.\r
176  * \r
177  * 3. Altered source versions must be plainly marked as such, and must\r
178  * not be misrepresented as being the original software.\r
179  * \r
180  * 4. The name of the author may not be used to endorse or promote \r
181  * products derived from this software without specific prior written \r
182  * permission.\r
183  * \r
184  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS\r
185  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\r
186  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r
187  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY\r
188  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\r
189  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE\r
190  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r
191  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\r
192  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\r
193  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\r
194  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r
195  * \r
196  * Java version ported by Keiron Liddle, Aftex Software <keiron@aftexsw.com> 1999-2001\r
197  */\r