1
0
mirror of https://github.com/chylex/Brotli-Builder.git synced 2024-12-23 01:42:46 +01:00
Brotli-Builder/BrotliLib/Brotli/Dictionary/Default/BrotliDefaultDictionary.cs

84 lines
4.1 KiB
C#

using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Text;
using BrotliLib.Brotli.Dictionary.Format;
using BrotliLib.Brotli.Dictionary.Source;
using BrotliLib.Brotli.Dictionary.Transform;
namespace BrotliLib.Brotli.Dictionary.Default{
/// <summary>
/// Defines the format and transformations used for the default Brotli dictionary.
/// https://tools.ietf.org/html/rfc7932#section-8
/// https://tools.ietf.org/html/rfc7932#appendix-B
/// </summary>
public sealed class BrotliDefaultDictionary : BrotliDictionary{
public static BrotliDefaultDictionary Embedded { get; }
private static readonly IDictionaryFormat DefaultFormat = new BitDepthFormat(new int[]{
0, 0, 0, 0, 10, 10, 11, 11, 10, 10, 10, 10, 10, 9, 9, 8, 7, 7, 8, 7, 7, 6, 6, 5, 5
});
private static readonly WordTransform[] DefaultTransforms;
static BrotliDefaultDictionary(){
Stream dict = typeof(BrotliDefaultDictionary).GetTypeInfo().Assembly.GetManifestResourceStream("BrotliLib.Brotli.Dictionary.Default.dict");
StreamSource source = new StreamSource(dict);
DefaultTransforms = Enumerable.Range(0, 121).Select(index => new WordTransform(PrefixMap[index], GetTransformType(index), SuffixMap[index])).ToArray();
Embedded = new BrotliDefaultDictionary(source);
}
public BrotliDefaultDictionary(IDictionarySource source) : base(DefaultFormat, DefaultTransforms, source){}
// Transforms
private static readonly List<byte[]> PrefixMap = "~~ ~~~~ ~s ~~~~~~, ~~ ~~~e ~~~~~~~~~~~~ ~~.~ ~~~~~~~~ the ~~~~~~~~~~~ ~~~~~~~~~~ the ~~~ ~~.~~~~ ~.com/~ the ~~~~.~~~~ ~~ ~~ ~~~~ ~~ ~~~~~ ~~ ~~~~\xc2\xa0~ ~~~~~~ ~ ~ ~~~~ ~~ ~ ~ ~ "
.Split('~').Select(Encoding.GetEncoding(28591).GetBytes).ToList(); // Latin1
private static readonly List<byte[]> SuffixMap = "~ ~ ~~ ~ the ~~ ~ of ~~ and ~~~ ~, ~ ~ in ~ to ~ ~\"~.~\">~\n~~]~ for ~~~ a ~ that ~~. ~~, ~~ with ~\'~ from ~ by ~~~~~. The ~~ on ~ as ~ is ~~ing ~\n\t~:~. ~ed ~~~~(~, ~~ at ~ly ~ of ~~~, ~\"~(~ ~\">~=\"~.~~ of the ~\'~. This ~,~ ~(~.~ not ~=\"~er ~ ~al ~~=\'~\"~. ~(~ful ~. ~ive ~less ~\'~est ~.~\">~=\'~,~ize ~.~~,~=\"~=\"~ous ~, ~=\'~,~=\"~, ~,~(~. ~.~=\'~. ~=\"~=\'~=\'"
.Split('~').Select(Encoding.GetEncoding(28591).GetBytes).ToList(); // Latin1
private static readonly HashSet<int> IndFermentFirst = new HashSet<int>{
4, 9, 15, 30, 58, 65, 66, 69, 74, 78, 79, 88, 91, 96, 99, 104, 108, 109, 118, 120
};
private static readonly HashSet<int> IndFermentAll = new HashSet<int>{
44, 68, 83, 85, 87, 94, 97, 101, 105, 107, 110, 111, 112, 113, 114, 115, 116, 117, 119
};
private static TransformType GetTransformType(int index){
if (IndFermentFirst.Contains(index)){
return TransformType.FermentFirst;
}
if (IndFermentAll.Contains(index)){
return TransformType.FermentAll;
}
return index switch{
3 => TransformType.OmitFirstN + 1,
11 => TransformType.OmitFirstN + 2,
12 => TransformType.OmitLastN + 1,
23 => TransformType.OmitLastN + 3,
26 => TransformType.OmitFirstN + 3,
27 => TransformType.OmitLastN + 2,
34 => TransformType.OmitFirstN + 4,
39 => TransformType.OmitFirstN + 5,
40 => TransformType.OmitFirstN + 6,
42 => TransformType.OmitLastN + 4,
48 => TransformType.OmitLastN + 7,
49 => TransformType.OmitLastN + 1,
54 => TransformType.OmitFirstN + 9,
55 => TransformType.OmitFirstN + 7,
56 => TransformType.OmitLastN + 6,
59 => TransformType.OmitLastN + 8,
63 => TransformType.OmitLastN + 5,
64 => TransformType.OmitLastN + 9,
_ => TransformType.Identity,
};
}
}
}