1#[allow(dead_code)] const X: u16 = 0xffff;
10
11const FORWARD_TABLE: &[u16] = &[
12 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146,
13 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, X, 162, 163, 164, 165,
14 166, 167, 168, 169, 215, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184,
15 185, 247, 187, 188, 189, 190, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X, X,
16 X, X, X, X, X, X, X, X, X, X, 8215, 1488, 1489, 1490, 1491, 1492, 1493, 1494, 1495, 1496, 1497,
17 1498, 1499, 1500, 1501, 1502, 1503, 1504, 1505, 1506, 1507, 1508, 1509, 1510, 1511, 1512, 1513,
18 1514, X, X, 8206, 8207, X,
19]; #[inline]
23pub fn forward(code: u8) -> u16 {
24 FORWARD_TABLE[(code - 0x80) as usize]
25}
26
27#[cfg(not(feature = "no-optimized-legacy-encoding"))]
28const BACKWARD_TABLE_LOWER: &[u8] = &[
29 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
30 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
31 224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242,
32 243, 244, 245, 246, 247, 248, 249, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
33 0, 0, 0, 253, 254, 0, 0, 0, 0, 0, 0, 0, 223, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
34 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 170, 0, 0, 0, 0, 0, 0, 0,
35 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 186, 0, 0, 0, 0, 0, 0,
36 0, 0, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145,
37 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 0, 162, 163, 164,
38 165, 166, 167, 168, 169, 0, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183,
39 184, 185, 0, 187, 188, 189, 190, 0,
40]; #[cfg(not(feature = "no-optimized-legacy-encoding"))]
43const BACKWARD_TABLE_UPPER: &[u16] = &[
44 0, 0, 203, 139, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 48, 0, 0, 0, 0, 0, 0,
45 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
46 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
47 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
48 0, 0, 98,
49]; #[inline]
53#[cfg(not(feature = "no-optimized-legacy-encoding"))]
54pub fn backward(code: u32) -> u8 {
55 let offset = (code >> 6) as usize;
56 let offset = if offset < 129 {BACKWARD_TABLE_UPPER[offset] as usize} else {0};
57 BACKWARD_TABLE_LOWER[offset + ((code & 63) as usize)]
58}
59
60#[cfg(feature = "no-optimized-legacy-encoding")]
62pub fn backward(code: u32) -> u8 {
63 if code > 8215 || ((0x10005u32 >> (code >> 9)) & 1) == 0 { return 0; }
64 let code = code as u16;
65 for i in 0..0x80 {
66 if FORWARD_TABLE[i as usize] == code { return 0x80 + i; }
67 }
68 0
69}
70
71#[cfg(test)]
72encoding_index_tests::single_byte_tests! {
73}