root/trunk/Updater/ICSharpCode.SharpZipLib/BZip2/BZip2Constants.cs @ 597

Wersja 597, 7.9 KB (wprowadzona przez marek, 17 years temu)

re #165

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