Ver código fonte

LibTextCodec: Add windows-1256 decoder

Simon Wanner 1 ano atrás
pai
commit
c76308c7e6
1 arquivos alterados com 13 adições e 0 exclusões
  1. 13 0
      Userland/Libraries/LibTextCodec/Decoder.cpp

+ 13 - 0
Userland/Libraries/LibTextCodec/Decoder.cpp

@@ -237,6 +237,17 @@ SingleByteDecoder s_windows1253_decoder {{
     0x03B0, 0x03B1, 0x03B2, 0x03B3, 0x03B4, 0x03B5, 0x03B6, 0x03B7, 0x03B8, 0x03B9, 0x03BA, 0x03BB, 0x03BC, 0x03BD, 0x03BE, 0x03BF,
     0x03B0, 0x03B1, 0x03B2, 0x03B3, 0x03B4, 0x03B5, 0x03B6, 0x03B7, 0x03B8, 0x03B9, 0x03BA, 0x03BB, 0x03BC, 0x03BD, 0x03BE, 0x03BF,
     0x03C0, 0x03C1, 0x03C2, 0x03C3, 0x03C4, 0x03C5, 0x03C6, 0x03C7, 0x03C8, 0x03C9, 0x03CA, 0x03CB, 0x03CC, 0x03CD, 0x03CE, 0xFFFD,
     0x03C0, 0x03C1, 0x03C2, 0x03C3, 0x03C4, 0x03C5, 0x03C6, 0x03C7, 0x03C8, 0x03C9, 0x03CA, 0x03CB, 0x03CC, 0x03CD, 0x03CE, 0xFFFD,
 }};
 }};
+// https://encoding.spec.whatwg.org/index-windows-1256.txt
+SingleByteDecoder s_windows1256_decoder {{
+    0x20AC, 0x067E, 0x201A, 0x0192, 0x201E, 0x2026, 0x2020, 0x2021, 0x02C6, 0x2030, 0x0679, 0x2039, 0x0152, 0x0686, 0x0698, 0x0688,
+    0x06AF, 0x2018, 0x2019, 0x201C, 0x201D, 0x2022, 0x2013, 0x2014, 0x06A9, 0x2122, 0x0691, 0x203A, 0x0153, 0x200C, 0x200D, 0x06BA,
+    0x00A0, 0x060C, 0x00A2, 0x00A3, 0x00A4, 0x00A5, 0x00A6, 0x00A7, 0x00A8, 0x00A9, 0x06BE, 0x00AB, 0x00AC, 0x00AD, 0x00AE, 0x00AF,
+    0x00B0, 0x00B1, 0x00B2, 0x00B3, 0x00B4, 0x00B5, 0x00B6, 0x00B7, 0x00B8, 0x00B9, 0x061B, 0x00BB, 0x00BC, 0x00BD, 0x00BE, 0x061F,
+    0x06C1, 0x0621, 0x0622, 0x0623, 0x0624, 0x0625, 0x0626, 0x0627, 0x0628, 0x0629, 0x062A, 0x062B, 0x062C, 0x062D, 0x062E, 0x062F,
+    0x0630, 0x0631, 0x0632, 0x0633, 0x0634, 0x0635, 0x0636, 0x00D7, 0x0637, 0x0638, 0x0639, 0x063A, 0x0640, 0x0641, 0x0642, 0x0643,
+    0x00E0, 0x0644, 0x00E2, 0x0645, 0x0646, 0x0647, 0x0648, 0x00E7, 0x00E8, 0x00E9, 0x00EA, 0x00EB, 0x0649, 0x064A, 0x00EE, 0x00EF,
+    0x064B, 0x064C, 0x064D, 0x064E, 0x00F4, 0x064F, 0x0650, 0x00F7, 0x0651, 0x00F9, 0x0652, 0x00FB, 0x00FC, 0x200E, 0x200F, 0x06D2,
+}};
 // clang-format on
 // clang-format on
 
 
 }
 }
@@ -301,6 +312,8 @@ Optional<Decoder&> decoder_for(StringView a_encoding)
             return s_turkish_decoder;
             return s_turkish_decoder;
         if (encoding.value().equals_ignoring_ascii_case("windows-1255"sv))
         if (encoding.value().equals_ignoring_ascii_case("windows-1255"sv))
             return s_hebrew_decoder;
             return s_hebrew_decoder;
+        if (encoding.value().equals_ignoring_ascii_case("windows-1256"sv))
+            return s_windows1256_decoder;
         if (encoding.value().equals_ignoring_ascii_case("x-user-defined"sv))
         if (encoding.value().equals_ignoring_ascii_case("x-user-defined"sv))
             return s_x_user_defined_decoder;
             return s_x_user_defined_decoder;
     }
     }