react-native-quick-crypto 1.0.19 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/QuickCrypto.podspec +12 -38
- package/README.md +2 -0
- package/android/CMakeLists.txt +3 -0
- package/android/build.gradle +5 -1
- package/cpp/argon2/HybridArgon2.cpp +10 -3
- package/cpp/blake3/HybridBlake3.cpp +5 -3
- package/cpp/cipher/CCMCipher.cpp +29 -16
- package/cpp/cipher/CCMCipher.hpp +2 -4
- package/cpp/cipher/ChaCha20Cipher.cpp +14 -18
- package/cpp/cipher/ChaCha20Cipher.hpp +2 -4
- package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +34 -23
- package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +2 -4
- package/cpp/cipher/GCMCipher.cpp +14 -15
- package/cpp/cipher/HybridCipher.cpp +39 -36
- package/cpp/cipher/HybridCipher.hpp +17 -1
- package/cpp/cipher/HybridRsaCipher.cpp +74 -29
- package/cpp/cipher/OCBCipher.cpp +4 -3
- package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +14 -13
- package/cpp/cipher/XSalsa20Cipher.cpp +72 -6
- package/cpp/cipher/XSalsa20Cipher.hpp +25 -3
- package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +21 -25
- package/cpp/dh/HybridDiffieHellman.cpp +29 -0
- package/cpp/ec/HybridEcKeyPair.cpp +35 -33
- package/cpp/ec/HybridEcKeyPair.hpp +3 -7
- package/cpp/ecdh/HybridECDH.cpp +23 -0
- package/cpp/ed25519/HybridEdKeyPair.cpp +73 -117
- package/cpp/ed25519/HybridEdKeyPair.hpp +5 -9
- package/cpp/hash/HybridHash.cpp +5 -7
- package/cpp/hkdf/HybridHkdf.cpp +6 -4
- package/cpp/hmac/HybridHmac.cpp +4 -6
- package/cpp/kmac/HybridKmac.cpp +4 -4
- package/cpp/mldsa/HybridMlDsaKeyPair.cpp +37 -49
- package/cpp/mlkem/HybridMlKemKeyPair.cpp +39 -43
- package/cpp/pbkdf2/HybridPbkdf2.cpp +7 -8
- package/cpp/rsa/HybridRsaKeyPair.cpp +5 -8
- package/cpp/rsa/HybridRsaKeyPair.hpp +4 -7
- package/cpp/scrypt/HybridScrypt.cpp +6 -4
- package/cpp/sign/HybridSignHandle.cpp +25 -68
- package/cpp/sign/HybridVerifyHandle.cpp +23 -60
- package/cpp/utils/HybridUtils.cpp +213 -111
- package/cpp/utils/HybridUtils.hpp +9 -2
- package/cpp/utils/QuickCryptoUtils.hpp +72 -0
- package/deps/simdutf/LICENSE-APACHE +201 -0
- package/deps/simdutf/LICENSE-MIT +18 -0
- package/deps/simdutf/README.md +2782 -0
- package/deps/simdutf/include/simdutf/avx512.h +79 -0
- package/deps/simdutf/include/simdutf/base64_implementation.h +158 -0
- package/deps/simdutf/include/simdutf/base64_tables.h +887 -0
- package/deps/simdutf/include/simdutf/common_defs.h +186 -0
- package/deps/simdutf/include/simdutf/compiler_check.h +50 -0
- package/deps/simdutf/include/simdutf/constexpr_ptr.h +138 -0
- package/deps/simdutf/include/simdutf/encoding_types.h +189 -0
- package/deps/simdutf/include/simdutf/error.h +126 -0
- package/deps/simdutf/include/simdutf/implementation.h +7081 -0
- package/deps/simdutf/include/simdutf/internal/isadetection.h +325 -0
- package/deps/simdutf/include/simdutf/portability.h +285 -0
- package/deps/simdutf/include/simdutf/scalar/ascii.h +86 -0
- package/deps/simdutf/include/simdutf/scalar/atomic_util.h +105 -0
- package/deps/simdutf/include/simdutf/scalar/base64.h +911 -0
- package/deps/simdutf/include/simdutf/scalar/latin1.h +26 -0
- package/deps/simdutf/include/simdutf/scalar/latin1_to_utf16/latin1_to_utf16.h +52 -0
- package/deps/simdutf/include/simdutf/scalar/latin1_to_utf32/latin1_to_utf32.h +27 -0
- package/deps/simdutf/include/simdutf/scalar/latin1_to_utf8/latin1_to_utf8.h +191 -0
- package/deps/simdutf/include/simdutf/scalar/swap_bytes.h +35 -0
- package/deps/simdutf/include/simdutf/scalar/utf16.h +226 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_latin1/utf16_to_latin1.h +108 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_latin1/valid_utf16_to_latin1.h +40 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_utf32/utf16_to_utf32.h +86 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_utf32/valid_utf16_to_utf32.h +44 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_utf8/utf16_to_utf8.h +295 -0
- package/deps/simdutf/include/simdutf/scalar/utf16_to_utf8/valid_utf16_to_utf8.h +91 -0
- package/deps/simdutf/include/simdutf/scalar/utf32.h +82 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_latin1/utf32_to_latin1.h +68 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_latin1/valid_utf32_to_latin1.h +67 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_utf16/utf32_to_utf16.h +84 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_utf16/valid_utf32_to_utf16.h +44 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_utf8/utf32_to_utf8.h +142 -0
- package/deps/simdutf/include/simdutf/scalar/utf32_to_utf8/valid_utf32_to_utf8.h +72 -0
- package/deps/simdutf/include/simdutf/scalar/utf8.h +326 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_latin1/utf8_to_latin1.h +225 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_latin1/valid_utf8_to_latin1.h +87 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_utf16/utf8_to_utf16.h +342 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_utf16/valid_utf8_to_utf16.h +106 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_utf32/utf8_to_utf32.h +299 -0
- package/deps/simdutf/include/simdutf/scalar/utf8_to_utf32/valid_utf8_to_utf32.h +83 -0
- package/deps/simdutf/include/simdutf/simdutf_version.h +26 -0
- package/deps/simdutf/include/simdutf.h +26 -0
- package/deps/simdutf/include/simdutf_c.h +342 -0
- package/deps/simdutf/src/arm64/arm_base64.cpp +791 -0
- package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf16.cpp +24 -0
- package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf32.cpp +24 -0
- package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf8.cpp +70 -0
- package/deps/simdutf/src/arm64/arm_convert_utf16_to_latin1.cpp +61 -0
- package/deps/simdutf/src/arm64/arm_convert_utf16_to_utf32.cpp +185 -0
- package/deps/simdutf/src/arm64/arm_convert_utf16_to_utf8.cpp +780 -0
- package/deps/simdutf/src/arm64/arm_convert_utf32_to_latin1.cpp +60 -0
- package/deps/simdutf/src/arm64/arm_convert_utf32_to_utf16.cpp +208 -0
- package/deps/simdutf/src/arm64/arm_convert_utf32_to_utf8.cpp +505 -0
- package/deps/simdutf/src/arm64/arm_convert_utf8_to_latin1.cpp +69 -0
- package/deps/simdutf/src/arm64/arm_convert_utf8_to_utf16.cpp +313 -0
- package/deps/simdutf/src/arm64/arm_convert_utf8_to_utf32.cpp +179 -0
- package/deps/simdutf/src/arm64/arm_find.cpp +199 -0
- package/deps/simdutf/src/arm64/arm_utf16fix.cpp +185 -0
- package/deps/simdutf/src/arm64/arm_validate_utf16.cpp +165 -0
- package/deps/simdutf/src/arm64/arm_validate_utf32le.cpp +65 -0
- package/deps/simdutf/src/arm64/implementation.cpp +1442 -0
- package/deps/simdutf/src/encoding_types.cpp +67 -0
- package/deps/simdutf/src/error.cpp +3 -0
- package/deps/simdutf/src/fallback/implementation.cpp +589 -0
- package/deps/simdutf/src/generic/ascii_validation.h +50 -0
- package/deps/simdutf/src/generic/base64.h +233 -0
- package/deps/simdutf/src/generic/base64lengths.h +63 -0
- package/deps/simdutf/src/generic/buf_block_reader.h +109 -0
- package/deps/simdutf/src/generic/find.h +75 -0
- package/deps/simdutf/src/generic/utf16/change_endianness.h +24 -0
- package/deps/simdutf/src/generic/utf16/count_code_points_bytemask.h +58 -0
- package/deps/simdutf/src/generic/utf16/to_well_formed.h +93 -0
- package/deps/simdutf/src/generic/utf16/utf32_length_from_utf16.h +15 -0
- package/deps/simdutf/src/generic/utf16/utf8_length_from_utf16.h +35 -0
- package/deps/simdutf/src/generic/utf16/utf8_length_from_utf16_bytemask.h +199 -0
- package/deps/simdutf/src/generic/utf16.h +73 -0
- package/deps/simdutf/src/generic/utf32.h +136 -0
- package/deps/simdutf/src/generic/utf8/utf16_length_from_utf8_bytemask.h +53 -0
- package/deps/simdutf/src/generic/utf8.h +92 -0
- package/deps/simdutf/src/generic/utf8_to_latin1/utf8_to_latin1.h +316 -0
- package/deps/simdutf/src/generic/utf8_to_latin1/valid_utf8_to_latin1.h +78 -0
- package/deps/simdutf/src/generic/utf8_to_utf16/utf8_to_utf16.h +332 -0
- package/deps/simdutf/src/generic/utf8_to_utf16/valid_utf8_to_utf16.h +74 -0
- package/deps/simdutf/src/generic/utf8_to_utf32/utf8_to_utf32.h +318 -0
- package/deps/simdutf/src/generic/utf8_to_utf32/valid_utf8_to_utf32.h +42 -0
- package/deps/simdutf/src/generic/utf8_validation/utf8_lookup4_algorithm.h +223 -0
- package/deps/simdutf/src/generic/utf8_validation/utf8_validator.h +84 -0
- package/deps/simdutf/src/generic/validate_utf16.h +164 -0
- package/deps/simdutf/src/generic/validate_utf32.h +99 -0
- package/deps/simdutf/src/haswell/avx2_base64.cpp +837 -0
- package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf16.cpp +28 -0
- package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf32.cpp +20 -0
- package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf8.cpp +83 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf16_to_latin1.cpp +83 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf16_to_utf32.cpp +210 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf16_to_utf8.cpp +602 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf32_to_latin1.cpp +116 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf32_to_utf16.cpp +164 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf32_to_utf8.cpp +569 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf8_to_latin1.cpp +60 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf8_to_utf16.cpp +195 -0
- package/deps/simdutf/src/haswell/avx2_convert_utf8_to_utf32.cpp +135 -0
- package/deps/simdutf/src/haswell/avx2_utf16fix.cpp +173 -0
- package/deps/simdutf/src/haswell/avx2_validate_utf16.cpp +17 -0
- package/deps/simdutf/src/haswell/implementation.cpp +1447 -0
- package/deps/simdutf/src/icelake/icelake_ascii_validation.inl.cpp +19 -0
- package/deps/simdutf/src/icelake/icelake_base64.inl.cpp +630 -0
- package/deps/simdutf/src/icelake/icelake_common.inl.cpp +37 -0
- package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf16.inl.cpp +36 -0
- package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf32.inl.cpp +23 -0
- package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf8.inl.cpp +107 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf16_to_latin1.inl.cpp +103 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf16_to_utf32.inl.cpp +136 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf16_to_utf8.inl.cpp +206 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf32_to_latin1.inl.cpp +74 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf32_to_utf16.inl.cpp +338 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf32_to_utf8.inl.cpp +574 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf8_to_latin1.inl.cpp +104 -0
- package/deps/simdutf/src/icelake/icelake_convert_utf8_to_utf16.inl.cpp +75 -0
- package/deps/simdutf/src/icelake/icelake_convert_valid_utf8_to_latin1.inl.cpp +69 -0
- package/deps/simdutf/src/icelake/icelake_find.inl.cpp +146 -0
- package/deps/simdutf/src/icelake/icelake_from_utf8.inl.cpp +266 -0
- package/deps/simdutf/src/icelake/icelake_from_valid_utf8.inl.cpp +136 -0
- package/deps/simdutf/src/icelake/icelake_macros.inl.cpp +143 -0
- package/deps/simdutf/src/icelake/icelake_utf16fix.cpp +138 -0
- package/deps/simdutf/src/icelake/icelake_utf32_validation.inl.cpp +63 -0
- package/deps/simdutf/src/icelake/icelake_utf8_common.inl.cpp +753 -0
- package/deps/simdutf/src/icelake/icelake_utf8_length_from_utf16.inl.cpp +269 -0
- package/deps/simdutf/src/icelake/icelake_utf8_validation.inl.cpp +116 -0
- package/deps/simdutf/src/icelake/implementation.cpp +1903 -0
- package/deps/simdutf/src/implementation.cpp +2526 -0
- package/deps/simdutf/src/lasx/implementation.cpp +1531 -0
- package/deps/simdutf/src/lasx/lasx_base64.cpp +695 -0
- package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf16.cpp +76 -0
- package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf32.cpp +55 -0
- package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf8.cpp +65 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf16_to_latin1.cpp +64 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf16_to_utf32.cpp +183 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf16_to_utf8.cpp +550 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf32_to_latin1.cpp +73 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf32_to_utf16.cpp +218 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf32_to_utf8.cpp +589 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf8_to_latin1.cpp +72 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf8_to_utf16.cpp +296 -0
- package/deps/simdutf/src/lasx/lasx_convert_utf8_to_utf32.cpp +190 -0
- package/deps/simdutf/src/lasx/lasx_find.cpp +64 -0
- package/deps/simdutf/src/lasx/lasx_validate_utf16.cpp +13 -0
- package/deps/simdutf/src/lasx/lasx_validate_utf32le.cpp +84 -0
- package/deps/simdutf/src/lsx/implementation.cpp +1417 -0
- package/deps/simdutf/src/lsx/lsx_base64.cpp +675 -0
- package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf16.cpp +39 -0
- package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf32.cpp +27 -0
- package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf8.cpp +56 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf16_to_latin1.cpp +64 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf16_to_utf32.cpp +133 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf16_to_utf8.cpp +518 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf32_to_latin1.cpp +66 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf32_to_utf16.cpp +155 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf32_to_utf8.cpp +459 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf8_to_latin1.cpp +75 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf8_to_utf16.cpp +291 -0
- package/deps/simdutf/src/lsx/lsx_convert_utf8_to_utf32.cpp +179 -0
- package/deps/simdutf/src/lsx/lsx_find.cpp +60 -0
- package/deps/simdutf/src/lsx/lsx_validate_utf16.cpp +13 -0
- package/deps/simdutf/src/lsx/lsx_validate_utf32le.cpp +68 -0
- package/deps/simdutf/src/ppc64/implementation.cpp +992 -0
- package/deps/simdutf/src/ppc64/ppc64_base64.cpp +480 -0
- package/deps/simdutf/src/ppc64/ppc64_base64_internal_tests.cpp +401 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf16.cpp +12 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf32.cpp +12 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf8.cpp +149 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_latin1.cpp +67 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_utf32.cpp +87 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_utf8.cpp +296 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_latin1.cpp +57 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_utf16.cpp +117 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_utf8.cpp +166 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_latin1.cpp +69 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_utf16.cpp +211 -0
- package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_utf32.cpp +153 -0
- package/deps/simdutf/src/ppc64/ppc64_utf16_to_utf8_tables.h +1011 -0
- package/deps/simdutf/src/ppc64/ppc64_utf8_length_from_latin1.cpp +37 -0
- package/deps/simdutf/src/ppc64/ppc64_validate_utf16.cpp +19 -0
- package/deps/simdutf/src/ppc64/templates.cpp +91 -0
- package/deps/simdutf/src/rvv/implementation.cpp +138 -0
- package/deps/simdutf/src/rvv/rvv_find.cpp +27 -0
- package/deps/simdutf/src/rvv/rvv_helpers.inl.cpp +23 -0
- package/deps/simdutf/src/rvv/rvv_latin1_to.inl.cpp +71 -0
- package/deps/simdutf/src/rvv/rvv_length_from.inl.cpp +164 -0
- package/deps/simdutf/src/rvv/rvv_utf16_to.inl.cpp +399 -0
- package/deps/simdutf/src/rvv/rvv_utf16fix.cpp +110 -0
- package/deps/simdutf/src/rvv/rvv_utf32_to.inl.cpp +307 -0
- package/deps/simdutf/src/rvv/rvv_utf8_to.inl.cpp +435 -0
- package/deps/simdutf/src/rvv/rvv_validate.inl.cpp +275 -0
- package/deps/simdutf/src/simdutf/arm64/begin.h +2 -0
- package/deps/simdutf/src/simdutf/arm64/bitmanipulation.h +34 -0
- package/deps/simdutf/src/simdutf/arm64/end.h +2 -0
- package/deps/simdutf/src/simdutf/arm64/implementation.h +307 -0
- package/deps/simdutf/src/simdutf/arm64/intrinsics.h +10 -0
- package/deps/simdutf/src/simdutf/arm64/simd.h +547 -0
- package/deps/simdutf/src/simdutf/arm64/simd16-inl.h +403 -0
- package/deps/simdutf/src/simdutf/arm64/simd32-inl.h +129 -0
- package/deps/simdutf/src/simdutf/arm64/simd64-inl.h +28 -0
- package/deps/simdutf/src/simdutf/arm64.h +43 -0
- package/deps/simdutf/src/simdutf/fallback/begin.h +1 -0
- package/deps/simdutf/src/simdutf/fallback/bitmanipulation.h +13 -0
- package/deps/simdutf/src/simdutf/fallback/end.h +1 -0
- package/deps/simdutf/src/simdutf/fallback/implementation.h +331 -0
- package/deps/simdutf/src/simdutf/fallback.h +42 -0
- package/deps/simdutf/src/simdutf/haswell/begin.h +15 -0
- package/deps/simdutf/src/simdutf/haswell/bitmanipulation.h +35 -0
- package/deps/simdutf/src/simdutf/haswell/end.h +13 -0
- package/deps/simdutf/src/simdutf/haswell/implementation.h +338 -0
- package/deps/simdutf/src/simdutf/haswell/intrinsics.h +67 -0
- package/deps/simdutf/src/simdutf/haswell/simd.h +363 -0
- package/deps/simdutf/src/simdutf/haswell/simd16-inl.h +261 -0
- package/deps/simdutf/src/simdutf/haswell/simd32-inl.h +111 -0
- package/deps/simdutf/src/simdutf/haswell/simd64-inl.h +34 -0
- package/deps/simdutf/src/simdutf/haswell.h +63 -0
- package/deps/simdutf/src/simdutf/icelake/begin.h +14 -0
- package/deps/simdutf/src/simdutf/icelake/bitmanipulation.h +44 -0
- package/deps/simdutf/src/simdutf/icelake/end.h +12 -0
- package/deps/simdutf/src/simdutf/icelake/implementation.h +346 -0
- package/deps/simdutf/src/simdutf/icelake/intrinsics.h +138 -0
- package/deps/simdutf/src/simdutf/icelake/simd.h +17 -0
- package/deps/simdutf/src/simdutf/icelake/simd16-inl.h +90 -0
- package/deps/simdutf/src/simdutf/icelake/simd32-inl.h +47 -0
- package/deps/simdutf/src/simdutf/icelake.h +81 -0
- package/deps/simdutf/src/simdutf/lasx/begin.h +8 -0
- package/deps/simdutf/src/simdutf/lasx/bitmanipulation.h +25 -0
- package/deps/simdutf/src/simdutf/lasx/end.h +8 -0
- package/deps/simdutf/src/simdutf/lasx/implementation.h +310 -0
- package/deps/simdutf/src/simdutf/lasx/intrinsics.h +319 -0
- package/deps/simdutf/src/simdutf/lasx/simd.h +551 -0
- package/deps/simdutf/src/simdutf/lasx/simd16-inl.h +234 -0
- package/deps/simdutf/src/simdutf/lasx/simd32-inl.h +74 -0
- package/deps/simdutf/src/simdutf/lasx/simd64-inl.h +52 -0
- package/deps/simdutf/src/simdutf/lasx.h +49 -0
- package/deps/simdutf/src/simdutf/lsx/begin.h +2 -0
- package/deps/simdutf/src/simdutf/lsx/bitmanipulation.h +25 -0
- package/deps/simdutf/src/simdutf/lsx/end.h +2 -0
- package/deps/simdutf/src/simdutf/lsx/implementation.h +309 -0
- package/deps/simdutf/src/simdutf/lsx/intrinsics.h +196 -0
- package/deps/simdutf/src/simdutf/lsx/simd.h +421 -0
- package/deps/simdutf/src/simdutf/lsx/simd16-inl.h +242 -0
- package/deps/simdutf/src/simdutf/lsx/simd32-inl.h +69 -0
- package/deps/simdutf/src/simdutf/lsx/simd64-inl.h +50 -0
- package/deps/simdutf/src/simdutf/lsx.h +52 -0
- package/deps/simdutf/src/simdutf/ppc64/begin.h +1 -0
- package/deps/simdutf/src/simdutf/ppc64/bitmanipulation.h +29 -0
- package/deps/simdutf/src/simdutf/ppc64/end.h +1 -0
- package/deps/simdutf/src/simdutf/ppc64/implementation.h +348 -0
- package/deps/simdutf/src/simdutf/ppc64/intrinsics.h +19 -0
- package/deps/simdutf/src/simdutf/ppc64/simd.h +177 -0
- package/deps/simdutf/src/simdutf/ppc64/simd16-inl.h +327 -0
- package/deps/simdutf/src/simdutf/ppc64/simd32-inl.h +247 -0
- package/deps/simdutf/src/simdutf/ppc64/simd8-inl.h +618 -0
- package/deps/simdutf/src/simdutf/ppc64.h +40 -0
- package/deps/simdutf/src/simdutf/rvv/begin.h +7 -0
- package/deps/simdutf/src/simdutf/rvv/end.h +7 -0
- package/deps/simdutf/src/simdutf/rvv/implementation.h +321 -0
- package/deps/simdutf/src/simdutf/rvv/intrinsics.h +131 -0
- package/deps/simdutf/src/simdutf/rvv.h +41 -0
- package/deps/simdutf/src/simdutf/westmere/begin.h +8 -0
- package/deps/simdutf/src/simdutf/westmere/bitmanipulation.h +37 -0
- package/deps/simdutf/src/simdutf/westmere/end.h +8 -0
- package/deps/simdutf/src/simdutf/westmere/implementation.h +338 -0
- package/deps/simdutf/src/simdutf/westmere/intrinsics.h +38 -0
- package/deps/simdutf/src/simdutf/westmere/simd.h +379 -0
- package/deps/simdutf/src/simdutf/westmere/simd16-inl.h +242 -0
- package/deps/simdutf/src/simdutf/westmere/simd32-inl.h +151 -0
- package/deps/simdutf/src/simdutf/westmere/simd64-inl.h +33 -0
- package/deps/simdutf/src/simdutf/westmere.h +59 -0
- package/deps/simdutf/src/simdutf.cpp +152 -0
- package/deps/simdutf/src/simdutf_c.cpp +525 -0
- package/deps/simdutf/src/tables/utf16_to_utf8_tables.h +768 -0
- package/deps/simdutf/src/tables/utf32_to_utf16_tables.h +53 -0
- package/deps/simdutf/src/tables/utf8_to_utf16_tables.h +826 -0
- package/deps/simdutf/src/westmere/implementation.cpp +1479 -0
- package/deps/simdutf/src/westmere/internal/loader.cpp +7 -0
- package/deps/simdutf/src/westmere/internal/write_v_u16_11bits_to_utf8.cpp +66 -0
- package/deps/simdutf/src/westmere/sse_base64.cpp +672 -0
- package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf16.cpp +21 -0
- package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf32.cpp +31 -0
- package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf8.cpp +71 -0
- package/deps/simdutf/src/westmere/sse_convert_utf16_to_latin1.cpp +70 -0
- package/deps/simdutf/src/westmere/sse_convert_utf16_to_utf32.cpp +206 -0
- package/deps/simdutf/src/westmere/sse_convert_utf16_to_utf8.cpp +504 -0
- package/deps/simdutf/src/westmere/sse_convert_utf32_to_latin1.cpp +82 -0
- package/deps/simdutf/src/westmere/sse_convert_utf32_to_utf16.cpp +209 -0
- package/deps/simdutf/src/westmere/sse_convert_utf32_to_utf8.cpp +589 -0
- package/deps/simdutf/src/westmere/sse_convert_utf8_to_latin1.cpp +58 -0
- package/deps/simdutf/src/westmere/sse_convert_utf8_to_utf16.cpp +197 -0
- package/deps/simdutf/src/westmere/sse_convert_utf8_to_utf32.cpp +141 -0
- package/deps/simdutf/src/westmere/sse_utf16fix.cpp +82 -0
- package/deps/simdutf/src/westmere/sse_validate_utf16.cpp +17 -0
- package/lib/commonjs/argon2.js +51 -2
- package/lib/commonjs/argon2.js.map +1 -1
- package/lib/commonjs/cipher.js +109 -11
- package/lib/commonjs/cipher.js.map +1 -1
- package/lib/commonjs/dsa.js +8 -2
- package/lib/commonjs/dsa.js.map +1 -1
- package/lib/commonjs/hash.js +15 -5
- package/lib/commonjs/hash.js.map +1 -1
- package/lib/commonjs/hkdf.js +33 -6
- package/lib/commonjs/hkdf.js.map +1 -1
- package/lib/commonjs/hmac.js +15 -5
- package/lib/commonjs/hmac.js.map +1 -1
- package/lib/commonjs/keys/publicCipher.js +10 -4
- package/lib/commonjs/keys/publicCipher.js.map +1 -1
- package/lib/commonjs/random.js +11 -2
- package/lib/commonjs/random.js.map +1 -1
- package/lib/commonjs/rsa.js +12 -5
- package/lib/commonjs/rsa.js.map +1 -1
- package/lib/commonjs/scrypt.js +47 -6
- package/lib/commonjs/scrypt.js.map +1 -1
- package/lib/commonjs/subtle.js +76 -5
- package/lib/commonjs/subtle.js.map +1 -1
- package/lib/commonjs/utils/cipher.js +18 -7
- package/lib/commonjs/utils/cipher.js.map +1 -1
- package/lib/commonjs/utils/conversion.js +33 -9
- package/lib/commonjs/utils/conversion.js.map +1 -1
- package/lib/commonjs/utils/timingSafeEqual.js +7 -2
- package/lib/commonjs/utils/timingSafeEqual.js.map +1 -1
- package/lib/commonjs/x509certificate.js +6 -6
- package/lib/commonjs/x509certificate.js.map +1 -1
- package/lib/module/argon2.js +51 -2
- package/lib/module/argon2.js.map +1 -1
- package/lib/module/cipher.js +109 -11
- package/lib/module/cipher.js.map +1 -1
- package/lib/module/dsa.js +8 -2
- package/lib/module/dsa.js.map +1 -1
- package/lib/module/hash.js +15 -5
- package/lib/module/hash.js.map +1 -1
- package/lib/module/hkdf.js +33 -6
- package/lib/module/hkdf.js.map +1 -1
- package/lib/module/hmac.js +15 -5
- package/lib/module/hmac.js.map +1 -1
- package/lib/module/keys/publicCipher.js +10 -4
- package/lib/module/keys/publicCipher.js.map +1 -1
- package/lib/module/random.js +11 -2
- package/lib/module/random.js.map +1 -1
- package/lib/module/rsa.js +11 -4
- package/lib/module/rsa.js.map +1 -1
- package/lib/module/scrypt.js +47 -6
- package/lib/module/scrypt.js.map +1 -1
- package/lib/module/subtle.js +76 -5
- package/lib/module/subtle.js.map +1 -1
- package/lib/module/utils/cipher.js +18 -7
- package/lib/module/utils/cipher.js.map +1 -1
- package/lib/module/utils/conversion.js +33 -9
- package/lib/module/utils/conversion.js.map +1 -1
- package/lib/module/utils/timingSafeEqual.js +8 -3
- package/lib/module/utils/timingSafeEqual.js.map +1 -1
- package/lib/module/x509certificate.js +6 -6
- package/lib/module/x509certificate.js.map +1 -1
- package/lib/typescript/argon2.d.ts.map +1 -1
- package/lib/typescript/cipher.d.ts +2 -2
- package/lib/typescript/cipher.d.ts.map +1 -1
- package/lib/typescript/dsa.d.ts.map +1 -1
- package/lib/typescript/hash.d.ts +2 -2
- package/lib/typescript/hash.d.ts.map +1 -1
- package/lib/typescript/hkdf.d.ts.map +1 -1
- package/lib/typescript/hmac.d.ts +2 -2
- package/lib/typescript/hmac.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +1 -1
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/keys/publicCipher.d.ts.map +1 -1
- package/lib/typescript/random.d.ts.map +1 -1
- package/lib/typescript/rsa.d.ts.map +1 -1
- package/lib/typescript/scrypt.d.ts.map +1 -1
- package/lib/typescript/specs/utils.nitro.d.ts +0 -2
- package/lib/typescript/specs/utils.nitro.d.ts.map +1 -1
- package/lib/typescript/subtle.d.ts.map +1 -1
- package/lib/typescript/utils/cipher.d.ts +13 -1
- package/lib/typescript/utils/cipher.d.ts.map +1 -1
- package/lib/typescript/utils/conversion.d.ts +9 -6
- package/lib/typescript/utils/conversion.d.ts.map +1 -1
- package/lib/typescript/utils/timingSafeEqual.d.ts.map +1 -1
- package/lib/typescript/x509certificate.d.ts.map +1 -1
- package/nitrogen/generated/shared/c++/HybridUtilsSpec.cpp +0 -2
- package/nitrogen/generated/shared/c++/HybridUtilsSpec.hpp +0 -3
- package/package.json +38 -6
- package/src/argon2.ts +80 -2
- package/src/cipher.ts +139 -15
- package/src/dsa.ts +11 -2
- package/src/hash.ts +17 -7
- package/src/hkdf.ts +44 -6
- package/src/hmac.ts +17 -7
- package/src/keys/publicCipher.ts +10 -4
- package/src/random.ts +11 -2
- package/src/rsa.ts +18 -4
- package/src/scrypt.ts +73 -6
- package/src/specs/utils.nitro.ts +0 -2
- package/src/subtle.ts +90 -8
- package/src/utils/cipher.ts +30 -8
- package/src/utils/conversion.ts +58 -20
- package/src/utils/timingSafeEqual.ts +8 -3
- package/src/x509certificate.ts +5 -6
- package/deps/blake3/.cargo/config.toml +0 -2
- package/deps/blake3/.git-blame-ignore-revs +0 -2
- package/deps/blake3/.github/workflows/build_b3sum.py +0 -38
- package/deps/blake3/.github/workflows/ci.yml +0 -491
- package/deps/blake3/.github/workflows/tag.yml +0 -43
- package/deps/blake3/.github/workflows/upload_github_release_asset.py +0 -73
- package/deps/blake3/CONTRIBUTING.md +0 -31
- package/deps/blake3/Cargo.toml +0 -135
- package/deps/blake3/b3sum/Cargo.lock +0 -513
- package/deps/blake3/b3sum/Cargo.toml +0 -26
- package/deps/blake3/b3sum/README.md +0 -72
- package/deps/blake3/b3sum/src/main.rs +0 -564
- package/deps/blake3/b3sum/src/unit_tests.rs +0 -235
- package/deps/blake3/b3sum/tests/cli_tests.rs +0 -680
- package/deps/blake3/b3sum/what_does_check_do.md +0 -176
- package/deps/blake3/benches/bench.rs +0 -623
- package/deps/blake3/build.rs +0 -389
- package/deps/blake3/c/CMakeLists.txt +0 -383
- package/deps/blake3/c/CMakePresets.json +0 -73
- package/deps/blake3/c/Makefile.testing +0 -82
- package/deps/blake3/c/blake3-config.cmake.in +0 -14
- package/deps/blake3/c/blake3_avx2.c +0 -326
- package/deps/blake3/c/blake3_avx2_x86-64_unix.S +0 -1815
- package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +0 -1817
- package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +0 -1828
- package/deps/blake3/c/blake3_avx512.c +0 -1388
- package/deps/blake3/c/blake3_avx512_x86-64_unix.S +0 -4824
- package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +0 -2615
- package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +0 -2634
- package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +0 -32
- package/deps/blake3/c/blake3_c_rust_bindings/README.md +0 -4
- package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +0 -477
- package/deps/blake3/c/blake3_c_rust_bindings/build.rs +0 -253
- package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +0 -31
- package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +0 -333
- package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +0 -696
- package/deps/blake3/c/blake3_sse2.c +0 -566
- package/deps/blake3/c/blake3_sse2_x86-64_unix.S +0 -2291
- package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +0 -2332
- package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +0 -2350
- package/deps/blake3/c/blake3_sse41.c +0 -560
- package/deps/blake3/c/blake3_sse41_x86-64_unix.S +0 -2028
- package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +0 -2069
- package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +0 -2089
- package/deps/blake3/c/blake3_tbb.cpp +0 -37
- package/deps/blake3/c/dependencies/CMakeLists.txt +0 -3
- package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +0 -28
- package/deps/blake3/c/example.c +0 -36
- package/deps/blake3/c/example_tbb.c +0 -57
- package/deps/blake3/c/libblake3.pc.in +0 -12
- package/deps/blake3/c/main.c +0 -166
- package/deps/blake3/c/test.py +0 -97
- package/deps/blake3/media/B3.svg +0 -70
- package/deps/blake3/media/BLAKE3.svg +0 -85
- package/deps/blake3/media/speed.svg +0 -1474
- package/deps/blake3/reference_impl/Cargo.toml +0 -8
- package/deps/blake3/reference_impl/README.md +0 -14
- package/deps/blake3/reference_impl/reference_impl.rs +0 -374
- package/deps/blake3/src/ffi_avx2.rs +0 -65
- package/deps/blake3/src/ffi_avx512.rs +0 -169
- package/deps/blake3/src/ffi_neon.rs +0 -82
- package/deps/blake3/src/ffi_sse2.rs +0 -126
- package/deps/blake3/src/ffi_sse41.rs +0 -126
- package/deps/blake3/src/guts.rs +0 -60
- package/deps/blake3/src/hazmat.rs +0 -704
- package/deps/blake3/src/io.rs +0 -64
- package/deps/blake3/src/join.rs +0 -92
- package/deps/blake3/src/lib.rs +0 -1835
- package/deps/blake3/src/platform.rs +0 -587
- package/deps/blake3/src/portable.rs +0 -198
- package/deps/blake3/src/rust_avx2.rs +0 -474
- package/deps/blake3/src/rust_sse2.rs +0 -775
- package/deps/blake3/src/rust_sse41.rs +0 -766
- package/deps/blake3/src/test.rs +0 -1049
- package/deps/blake3/src/traits.rs +0 -227
- package/deps/blake3/src/wasm32_simd.rs +0 -794
- package/deps/blake3/test_vectors/Cargo.toml +0 -19
- package/deps/blake3/test_vectors/cross_test.sh +0 -25
- package/deps/blake3/test_vectors/src/bin/generate.rs +0 -4
- package/deps/blake3/test_vectors/src/lib.rs +0 -350
- package/deps/blake3/test_vectors/test_vectors.json +0 -217
- package/deps/blake3/tools/compiler_version/Cargo.toml +0 -7
- package/deps/blake3/tools/compiler_version/build.rs +0 -6
- package/deps/blake3/tools/compiler_version/src/main.rs +0 -27
- package/deps/blake3/tools/instruction_set_support/Cargo.toml +0 -6
- package/deps/blake3/tools/instruction_set_support/src/main.rs +0 -10
- package/deps/blake3/tools/release.md +0 -16
- package/deps/ncrypto/.bazelignore +0 -4
- package/deps/ncrypto/.bazelrc +0 -1
- package/deps/ncrypto/.bazelversion +0 -1
- package/deps/ncrypto/.clang-format +0 -111
- package/deps/ncrypto/.github/workflows/bazel.yml +0 -58
- package/deps/ncrypto/.github/workflows/commitlint.yml +0 -16
- package/deps/ncrypto/.github/workflows/linter.yml +0 -38
- package/deps/ncrypto/.github/workflows/macos.yml +0 -43
- package/deps/ncrypto/.github/workflows/release-please.yml +0 -16
- package/deps/ncrypto/.github/workflows/ubuntu.yml +0 -128
- package/deps/ncrypto/.github/workflows/visual-studio.yml +0 -49
- package/deps/ncrypto/.python-version +0 -1
- package/deps/ncrypto/.release-please-manifest.json +0 -3
- package/deps/ncrypto/BUILD.bazel +0 -44
- package/deps/ncrypto/CHANGELOG.md +0 -37
- package/deps/ncrypto/CMakeLists.txt +0 -79
- package/deps/ncrypto/MODULE.bazel +0 -16
- package/deps/ncrypto/MODULE.bazel.lock +0 -461
- package/deps/ncrypto/cmake/CPM.cmake +0 -1225
- package/deps/ncrypto/cmake/ncrypto-flags.cmake +0 -17
- package/deps/ncrypto/ncrypto.pc.in +0 -10
- package/deps/ncrypto/patches/0001-Expose-libdecrepit-so-NodeJS-can-use-it-for-ncrypto.patch +0 -28
- package/deps/ncrypto/pyproject.toml +0 -38
- package/deps/ncrypto/release-please-config.json +0 -11
- package/deps/ncrypto/src/CMakeLists.txt +0 -40
- package/deps/ncrypto/tests/BUILD.bazel +0 -11
- package/deps/ncrypto/tests/CMakeLists.txt +0 -7
- package/deps/ncrypto/tests/basic.cpp +0 -856
- package/deps/ncrypto/tools/run-clang-format.sh +0 -42
- package/lib/tsconfig.tsbuildinfo +0 -1
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
struct utf16_to_utf32_t {
|
|
2
|
+
error_code err; // error code
|
|
3
|
+
const char16_t *input; // last position in input buffer
|
|
4
|
+
char32_t *output; // last position in output buffer
|
|
5
|
+
};
|
|
6
|
+
|
|
7
|
+
template <endianness big_endian>
|
|
8
|
+
utf16_to_utf32_t ppc64_convert_utf16_to_utf32(const char16_t *buf, size_t len,
|
|
9
|
+
char32_t *utf32_output) {
|
|
10
|
+
const char16_t *end = buf + len;
|
|
11
|
+
|
|
12
|
+
const auto v_f800 = vector_u16::splat(0xf800);
|
|
13
|
+
const auto v_d800 = vector_u16::splat(0xd800);
|
|
14
|
+
const auto zero = vector_u8::zero();
|
|
15
|
+
|
|
16
|
+
while (end - buf >= vector_u16::ELEMENTS) {
|
|
17
|
+
auto in = vector_u16::load(buf);
|
|
18
|
+
if (not match_system(big_endian)) {
|
|
19
|
+
in = in.swap_bytes();
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// 1. Check if there are any surrogate word in the input chunk.
|
|
23
|
+
// We have also deal with situation when there is a surrogate word
|
|
24
|
+
// at the end of a chunk.
|
|
25
|
+
const auto surrogates_bytemask = (in & v_f800) == v_d800;
|
|
26
|
+
|
|
27
|
+
// bitmask = 0x0000 if there are no surrogates
|
|
28
|
+
const uint16_t surrogates_bitmask = surrogates_bytemask.to_bitmask();
|
|
29
|
+
|
|
30
|
+
// It might seem like checking for surrogates_bitmask == 0xc000 could help.
|
|
31
|
+
// However, it is likely an uncommon occurrence.
|
|
32
|
+
if (surrogates_bitmask == 0x0000) {
|
|
33
|
+
// case: no surrogate pairs, extend 16-bit code units to 32-bit code units
|
|
34
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
35
|
+
const auto lo =
|
|
36
|
+
vector_u8(16, 16, 0, 1, 16, 16, 2, 3, 16, 16, 4, 5, 16, 16, 6, 7);
|
|
37
|
+
const auto hi = vector_u8(16, 16, 8 + 0, 8 + 1, 16, 16, 8 + 2, 8 + 3, 16,
|
|
38
|
+
16, 8 + 4, 8 + 5, 16, 16, 8 + 6, 8 + 7);
|
|
39
|
+
#else
|
|
40
|
+
const auto lo =
|
|
41
|
+
vector_u8(0, 1, 16, 16, 2, 3, 16, 16, 4, 5, 16, 16, 6, 7, 16, 16);
|
|
42
|
+
const auto hi = vector_u8(8 + 0, 8 + 1, 16, 16, 8 + 2, 8 + 3, 16, 16,
|
|
43
|
+
8 + 4, 8 + 5, 16, 16, 8 + 6, 8 + 7, 16, 16);
|
|
44
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
45
|
+
|
|
46
|
+
const auto utf32_0 = lo.lookup_32(as_vector_u8(in), zero);
|
|
47
|
+
const auto utf32_1 = hi.lookup_32(as_vector_u8(in), zero);
|
|
48
|
+
|
|
49
|
+
utf32_0.store(utf32_output);
|
|
50
|
+
utf32_1.store(utf32_output + 4);
|
|
51
|
+
utf32_output += 8;
|
|
52
|
+
buf += 8;
|
|
53
|
+
// surrogate pair(s) in a register
|
|
54
|
+
} else {
|
|
55
|
+
// Let us do a scalar fallback.
|
|
56
|
+
// It may seem wasteful to use scalar code, but being efficient with SIMD
|
|
57
|
+
// in the presence of surrogate pairs may require non-trivial tables.
|
|
58
|
+
size_t forward = 15;
|
|
59
|
+
size_t k = 0;
|
|
60
|
+
if (size_t(end - buf) < forward + 1) {
|
|
61
|
+
forward = size_t(end - buf - 1);
|
|
62
|
+
}
|
|
63
|
+
for (; k < forward; k++) {
|
|
64
|
+
const uint16_t word = scalar::utf16::swap_if_needed<big_endian>(buf[k]);
|
|
65
|
+
if ((word & 0xF800) != 0xD800) {
|
|
66
|
+
*utf32_output++ = char32_t(word);
|
|
67
|
+
} else {
|
|
68
|
+
// must be a surrogate pair
|
|
69
|
+
uint16_t diff = uint16_t(word - 0xD800);
|
|
70
|
+
uint16_t next_word =
|
|
71
|
+
scalar::utf16::swap_if_needed<big_endian>(buf[k + 1]);
|
|
72
|
+
k++;
|
|
73
|
+
uint16_t diff2 = uint16_t(next_word - 0xDC00);
|
|
74
|
+
if ((diff | diff2) > 0x3FF) {
|
|
75
|
+
return utf16_to_utf32_t{error_code::SURROGATE, buf + k - 1,
|
|
76
|
+
utf32_output};
|
|
77
|
+
}
|
|
78
|
+
uint32_t value = (diff << 10) + diff2 + 0x10000;
|
|
79
|
+
*utf32_output++ = char32_t(value);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
buf += k;
|
|
83
|
+
}
|
|
84
|
+
} // while
|
|
85
|
+
|
|
86
|
+
return utf16_to_utf32_t{error_code::SUCCESS, buf, utf32_output};
|
|
87
|
+
}
|
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
/*
|
|
2
|
+
The vectorized algorithm works on single SSE register i.e., it
|
|
3
|
+
loads eight 16-bit code units.
|
|
4
|
+
|
|
5
|
+
We consider three cases:
|
|
6
|
+
1. an input register contains no surrogates and each value
|
|
7
|
+
is in range 0x0000 .. 0x07ff.
|
|
8
|
+
2. an input register contains no surrogates and values are
|
|
9
|
+
is in range 0x0000 .. 0xffff.
|
|
10
|
+
3. an input register contains surrogates --- i.e. codepoints
|
|
11
|
+
can have 16 or 32 bits.
|
|
12
|
+
|
|
13
|
+
Ad 1.
|
|
14
|
+
|
|
15
|
+
When values are less than 0x0800, it means that a 16-bit code unit
|
|
16
|
+
can be converted into: 1) single UTF8 byte (when it is an ASCII
|
|
17
|
+
char) or 2) two UTF8 bytes.
|
|
18
|
+
|
|
19
|
+
For this case we do only some shuffle to obtain these 2-byte
|
|
20
|
+
codes and finally compress the whole SSE register with a single
|
|
21
|
+
shuffle.
|
|
22
|
+
|
|
23
|
+
We need 256-entry lookup table to get a compression pattern
|
|
24
|
+
and the number of output bytes in the compressed vector register.
|
|
25
|
+
Each entry occupies 17 bytes.
|
|
26
|
+
|
|
27
|
+
Ad 2.
|
|
28
|
+
|
|
29
|
+
When values fit in 16-bit code units, but are above 0x07ff, then
|
|
30
|
+
a single word may produce one, two or three UTF8 bytes.
|
|
31
|
+
|
|
32
|
+
We prepare data for all these three cases in two registers.
|
|
33
|
+
The first register contains lower two UTF8 bytes (used in all
|
|
34
|
+
cases), while the second one contains just the third byte for
|
|
35
|
+
the three-UTF8-bytes case.
|
|
36
|
+
|
|
37
|
+
Finally these two registers are interleaved forming eight-element
|
|
38
|
+
array of 32-bit values. The array spans two SSE registers.
|
|
39
|
+
The bytes from the registers are compressed using two shuffles.
|
|
40
|
+
|
|
41
|
+
We need 256-entry lookup table to get a compression pattern
|
|
42
|
+
and the number of output bytes in the compressed vector register.
|
|
43
|
+
Each entry occupies 17 bytes.
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
To summarize:
|
|
47
|
+
- We need two 256-entry tables that have 8704 bytes in total.
|
|
48
|
+
*/
|
|
49
|
+
|
|
50
|
+
// Auxiliary procedure used by UTF-16 and UTF-32 into UTF-8.
|
|
51
|
+
// Note the pointer is passed by reference, it is updated by the procedure.
|
|
52
|
+
template <typename T>
|
|
53
|
+
simdutf_really_inline void ppc64_convert_utf16_to_1_2_3_bytes_of_utf8(
|
|
54
|
+
const vector_u16 in, uint16_t one_byte_bitmask,
|
|
55
|
+
const T one_or_two_bytes_bytemask, uint16_t one_or_two_bytes_bitmask,
|
|
56
|
+
char *&utf8_output) {
|
|
57
|
+
// case: code units from register produce either 1, 2 or 3 UTF-8 bytes
|
|
58
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
59
|
+
const auto dup_lsb =
|
|
60
|
+
vector_u8(1, 1, 3, 3, 5, 5, 7, 7, 9, 9, 11, 11, 13, 13, 15, 15);
|
|
61
|
+
#else
|
|
62
|
+
const auto dup_lsb =
|
|
63
|
+
vector_u8(0, 0, 2, 2, 4, 4, 6, 6, 8, 8, 10, 10, 12, 12, 14, 14);
|
|
64
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
65
|
+
|
|
66
|
+
/* In this branch we handle three cases:
|
|
67
|
+
1. [0000|0000|0ccc|cccc] => [0ccc|cccc] -
|
|
68
|
+
single UFT-8 byte
|
|
69
|
+
2. [0000|0bbb|bbcc|cccc] => [110b|bbbb], [10cc|cccc] - two
|
|
70
|
+
UTF-8 bytes
|
|
71
|
+
3. [aaaa|bbbb|bbcc|cccc] => [1110|aaaa], [10bb|bbbb], [10cc|cccc] -
|
|
72
|
+
three UTF-8 bytes
|
|
73
|
+
|
|
74
|
+
We expand the input word (16-bit) into two code units (32-bit), thus
|
|
75
|
+
we have room for four bytes. However, we need five distinct bit
|
|
76
|
+
layouts. Note that the last byte in cases #2 and #3 is the same.
|
|
77
|
+
|
|
78
|
+
We precompute byte 1 for case #1 and the common byte for cases #2 & #3
|
|
79
|
+
in register t2.
|
|
80
|
+
|
|
81
|
+
We precompute byte 1 for case #3 and -- **conditionally** -- precompute
|
|
82
|
+
either byte 1 for case #2 or byte 2 for case #3. Note that they
|
|
83
|
+
differ by exactly one bit.
|
|
84
|
+
|
|
85
|
+
Finally from these two code units we build proper UTF-8 sequence, taking
|
|
86
|
+
into account the case (i.e, the number of bytes to write).
|
|
87
|
+
*/
|
|
88
|
+
/**
|
|
89
|
+
* Given [aaaa|bbbb|bbcc|cccc] our goal is to produce:
|
|
90
|
+
* t2 => [0ccc|cccc] [10cc|cccc]
|
|
91
|
+
* s4 => [1110|aaaa] ([110b|bbbb] OR [10bb|bbbb])
|
|
92
|
+
*/
|
|
93
|
+
// [aaaa|bbbb|bbcc|cccc] => [bbcc|cccc|bbcc|cccc]
|
|
94
|
+
const auto t0 = as_vector_u16(dup_lsb.lookup_16(as_vector_u8(in)));
|
|
95
|
+
|
|
96
|
+
// [bbcc|cccc|bbcc|cccc] => [00cc|cccc|0bcc|cccc]
|
|
97
|
+
const auto t1 = t0 & uint16_t(0b0011111101111111);
|
|
98
|
+
// [00cc|cccc|0bcc|cccc] => [10cc|cccc|0bcc|cccc]
|
|
99
|
+
const auto t2 = t1 | uint16_t(0b1000000000000000);
|
|
100
|
+
|
|
101
|
+
// in = [aaaa|bbbb|bbcc|cccc]
|
|
102
|
+
// a0 = [0000|0000|0000|aaaa]
|
|
103
|
+
const auto a0 = in.shr<12>();
|
|
104
|
+
// b0 = [aabb|bbbb|cccc|cc00]
|
|
105
|
+
const auto b0 = in.shl<2>();
|
|
106
|
+
// s0 = [00bb|bbbb|00cc|cccc]
|
|
107
|
+
const auto s0 = select(uint16_t(0x3f00), b0, a0);
|
|
108
|
+
|
|
109
|
+
// s3 = [11bb|bbbb|1110|aaaa]
|
|
110
|
+
const auto s3 = s0 | uint16_t(0b1100000011100000);
|
|
111
|
+
|
|
112
|
+
const auto m0 =
|
|
113
|
+
~as_vector_u16(one_or_two_bytes_bytemask) & uint16_t(0b0100000000000000);
|
|
114
|
+
const auto s4 = s3 ^ m0;
|
|
115
|
+
|
|
116
|
+
// 4. compress 32-bit code units into 1, 2 or 3 bytes -- 2 x shuffle
|
|
117
|
+
const uint16_t mask =
|
|
118
|
+
(one_byte_bitmask & 0x5555) | (one_or_two_bytes_bitmask & 0xaaaa);
|
|
119
|
+
if (mask == 0) {
|
|
120
|
+
// We only have three-byte code units. Use fast path.
|
|
121
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
122
|
+
// Lookups produced by scripts/ppc64_convert_utf16_to_utf8.py
|
|
123
|
+
const auto shuffle0 =
|
|
124
|
+
vector_u8(1, 0, 16, 3, 2, 18, 5, 4, 20, 7, 6, 22, 9, 8, 24, 11);
|
|
125
|
+
const auto shuffle1 = vector_u8(10, 26, 13, 12, 28, 15, 14, 30, -1, -1, -1,
|
|
126
|
+
-1, -1, -1, -1, -1);
|
|
127
|
+
#else
|
|
128
|
+
const auto shuffle0 =
|
|
129
|
+
vector_u8(0, 1, 17, 2, 3, 19, 4, 5, 21, 6, 7, 23, 8, 9, 25, 10);
|
|
130
|
+
const auto shuffle1 = vector_u8(11, 27, 12, 13, 29, 14, 15, 31, -1, -1, -1,
|
|
131
|
+
-1, -1, -1, -1, -1);
|
|
132
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
133
|
+
const auto utf8_0 = shuffle0.lookup_32(as_vector_u8(s4), as_vector_u8(t2));
|
|
134
|
+
const auto utf8_1 = shuffle1.lookup_32(as_vector_u8(s4), as_vector_u8(t2));
|
|
135
|
+
|
|
136
|
+
utf8_0.store(utf8_output);
|
|
137
|
+
utf8_output += 16;
|
|
138
|
+
utf8_1.store(utf8_output);
|
|
139
|
+
utf8_output += 8;
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
const uint8_t mask0 = uint8_t(mask);
|
|
144
|
+
|
|
145
|
+
const uint8_t *row0 =
|
|
146
|
+
&simdutf::tables::ppc64_utf16_to_utf8::pack_1_2_3_utf8_bytes[mask0][0];
|
|
147
|
+
const auto shuffle0 = vector_u8::load(row0 + 1);
|
|
148
|
+
|
|
149
|
+
const auto utf8_0 = shuffle0.lookup_32(as_vector_u8(s4), as_vector_u8(t2));
|
|
150
|
+
const uint8_t mask1 = static_cast<uint8_t>(mask >> 8);
|
|
151
|
+
|
|
152
|
+
const uint8_t *row1 =
|
|
153
|
+
&simdutf::tables::ppc64_utf16_to_utf8::pack_1_2_3_utf8_bytes[mask1][0];
|
|
154
|
+
const auto shuffle1 = vector_u8::load(row1 + 1) + uint8_t(8);
|
|
155
|
+
const auto utf8_1 = shuffle1.lookup_32(as_vector_u8(s4), as_vector_u8(t2));
|
|
156
|
+
|
|
157
|
+
utf8_0.store(utf8_output);
|
|
158
|
+
utf8_output += row0[0];
|
|
159
|
+
utf8_1.store(utf8_output);
|
|
160
|
+
utf8_output += row1[0];
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
struct utf16_to_utf8_t {
|
|
164
|
+
error_code err;
|
|
165
|
+
const char16_t *input;
|
|
166
|
+
char *output;
|
|
167
|
+
};
|
|
168
|
+
|
|
169
|
+
/*
|
|
170
|
+
Returns utf16_to_utf8_t value
|
|
171
|
+
A scalar routine should carry on the conversion of the tail,
|
|
172
|
+
iff there was no error.
|
|
173
|
+
*/
|
|
174
|
+
template <endianness big_endian>
|
|
175
|
+
utf16_to_utf8_t ppc64_convert_utf16_to_utf8(const char16_t *buf, size_t len,
|
|
176
|
+
char *utf8_output) {
|
|
177
|
+
|
|
178
|
+
const char16_t *end = buf + len;
|
|
179
|
+
|
|
180
|
+
const auto v_f800 = vector_u16(0xf800);
|
|
181
|
+
const auto v_d800 = vector_u16(0xd800);
|
|
182
|
+
const size_t safety_margin =
|
|
183
|
+
12; // to avoid overruns, see issue
|
|
184
|
+
// https://github.com/simdutf/simdutf/issues/92
|
|
185
|
+
|
|
186
|
+
while (end - buf >= std::ptrdiff_t(16 + safety_margin)) {
|
|
187
|
+
auto in = vector_u16::load(buf);
|
|
188
|
+
if (not match_system(big_endian)) {
|
|
189
|
+
in = in.swap_bytes();
|
|
190
|
+
}
|
|
191
|
+
// a single 16-bit UTF-16 word can yield 1, 2 or 3 UTF-8 bytes
|
|
192
|
+
if (in.is_ascii()) {
|
|
193
|
+
auto nextin = vector_u16::load(buf + vector_u16::ELEMENTS);
|
|
194
|
+
if (not match_system(big_endian)) {
|
|
195
|
+
nextin = nextin.swap_bytes();
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
if (nextin.is_ascii()) {
|
|
199
|
+
// 1. pack the bytes
|
|
200
|
+
const auto utf8_packed = vector_u16::pack(in, nextin);
|
|
201
|
+
// 2. store (16 bytes)
|
|
202
|
+
utf8_packed.store(utf8_output);
|
|
203
|
+
// 3. adjust pointers
|
|
204
|
+
buf += 16;
|
|
205
|
+
utf8_output += 16;
|
|
206
|
+
continue; // we are done for this round!
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
// next block is not ASCII
|
|
210
|
+
const auto utf8_packed = vector_u16::pack(in, in);
|
|
211
|
+
// 2. store (16 bytes)
|
|
212
|
+
utf8_packed.store(utf8_output);
|
|
213
|
+
// 3. adjust pointers
|
|
214
|
+
buf += 8;
|
|
215
|
+
utf8_output += 8;
|
|
216
|
+
in = nextin;
|
|
217
|
+
// fallback
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// no bits set above 7th bit
|
|
221
|
+
const auto one_byte_bytemask = in < uint16_t(1 << 7);
|
|
222
|
+
const uint16_t one_byte_bitmask = one_byte_bytemask.to_bitmask();
|
|
223
|
+
|
|
224
|
+
// no bits set above 11th bit
|
|
225
|
+
const auto one_or_two_bytes_bytemask = in < uint16_t(1 << 11);
|
|
226
|
+
const uint16_t one_or_two_bytes_bitmask =
|
|
227
|
+
one_or_two_bytes_bytemask.to_bitmask();
|
|
228
|
+
|
|
229
|
+
if (one_or_two_bytes_bitmask == 0xffff) {
|
|
230
|
+
write_v_u16_11bits_to_utf8(
|
|
231
|
+
in, utf8_output, as_vector_u8(one_byte_bytemask), one_byte_bitmask);
|
|
232
|
+
buf += 8;
|
|
233
|
+
continue;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
// 1. Check if there are any surrogate word in the input chunk.
|
|
237
|
+
// We have also to deal with situation when there is a surrogate word
|
|
238
|
+
// at the end of a chunk.
|
|
239
|
+
const auto surrogates_bytemask = (in & v_f800) == v_d800;
|
|
240
|
+
|
|
241
|
+
// bitmask = 0x0000 if there are no surrogates
|
|
242
|
+
// = 0xc000 if the last word is a surrogate
|
|
243
|
+
const uint16_t surrogates_bitmask = surrogates_bytemask.to_bitmask();
|
|
244
|
+
// It might seem like checking for surrogates_bitmask == 0xc000 could help.
|
|
245
|
+
// However, it is likely an uncommon occurrence.
|
|
246
|
+
if (surrogates_bitmask == 0x0000) {
|
|
247
|
+
ppc64_convert_utf16_to_1_2_3_bytes_of_utf8(
|
|
248
|
+
in, one_byte_bitmask, one_or_two_bytes_bytemask,
|
|
249
|
+
one_or_two_bytes_bitmask, utf8_output);
|
|
250
|
+
|
|
251
|
+
buf += 8;
|
|
252
|
+
// surrogate pair(s) in a register
|
|
253
|
+
} else {
|
|
254
|
+
// Let us do a scalar fallback.
|
|
255
|
+
// It may seem wasteful to use scalar code, but being efficient with SIMD
|
|
256
|
+
// in the presence of surrogate pairs may require non-trivial tables.
|
|
257
|
+
size_t forward = 15;
|
|
258
|
+
size_t k = 0;
|
|
259
|
+
if (size_t(end - buf) < forward + 1) {
|
|
260
|
+
forward = size_t(end - buf - 1);
|
|
261
|
+
}
|
|
262
|
+
for (; k < forward; k++) {
|
|
263
|
+
uint16_t word = scalar::utf16::swap_if_needed<big_endian>(buf[k]);
|
|
264
|
+
if ((word & 0xFF80) == 0) {
|
|
265
|
+
*utf8_output++ = uint8_t(word);
|
|
266
|
+
} else if ((word & 0xF800) == 0) {
|
|
267
|
+
*utf8_output++ = uint8_t((word >> 6) | 0b11000000);
|
|
268
|
+
*utf8_output++ = uint8_t((word & 0b111111) | 0b10000000);
|
|
269
|
+
} else if ((word & 0xF800) != 0xD800) {
|
|
270
|
+
*utf8_output++ = uint8_t((word >> 12) | 0b11100000);
|
|
271
|
+
*utf8_output++ = uint8_t(((word >> 6) & 0b111111) | 0b10000000);
|
|
272
|
+
*utf8_output++ = uint8_t((word & 0b111111) | 0b10000000);
|
|
273
|
+
} else {
|
|
274
|
+
// must be a surrogate pair
|
|
275
|
+
uint16_t diff = uint16_t(word - 0xD800);
|
|
276
|
+
uint16_t next_word =
|
|
277
|
+
scalar::utf16::swap_if_needed<big_endian>(buf[k + 1]);
|
|
278
|
+
k++;
|
|
279
|
+
uint16_t diff2 = uint16_t(next_word - 0xDC00);
|
|
280
|
+
if ((diff | diff2) > 0x3FF) {
|
|
281
|
+
return utf16_to_utf8_t{error_code::SURROGATE, buf + k - 1,
|
|
282
|
+
utf8_output};
|
|
283
|
+
}
|
|
284
|
+
uint32_t value = (diff << 10) + diff2 + 0x10000;
|
|
285
|
+
*utf8_output++ = uint8_t((value >> 18) | 0b11110000);
|
|
286
|
+
*utf8_output++ = uint8_t(((value >> 12) & 0b111111) | 0b10000000);
|
|
287
|
+
*utf8_output++ = uint8_t(((value >> 6) & 0b111111) | 0b10000000);
|
|
288
|
+
*utf8_output++ = uint8_t((value & 0b111111) | 0b10000000);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
buf += k;
|
|
292
|
+
}
|
|
293
|
+
} // while
|
|
294
|
+
|
|
295
|
+
return utf16_to_utf8_t{error_code::SUCCESS, buf, utf8_output};
|
|
296
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
enum class ErrorChecking { disabled, enabled };
|
|
2
|
+
|
|
3
|
+
struct utf32_to_latin1_t {
|
|
4
|
+
error_code err;
|
|
5
|
+
const char32_t *input;
|
|
6
|
+
char *output;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
template <ErrorChecking ec>
|
|
10
|
+
utf32_to_latin1_t simdutf_really_inline ppc64_convert_utf32_to_latin1(
|
|
11
|
+
const char32_t *buf, size_t len, char *latin1_output) {
|
|
12
|
+
constexpr size_t N = vector_u32::ELEMENTS;
|
|
13
|
+
const size_t rounded_len = align_down<4 * N>(len);
|
|
14
|
+
|
|
15
|
+
const auto high_bytes_mask = vector_u32::splat(0xFFFFFF00);
|
|
16
|
+
|
|
17
|
+
for (size_t i = 0; i < rounded_len; i += 4 * N) {
|
|
18
|
+
const auto in1 = vector_u32::load(buf + 0 * N);
|
|
19
|
+
const auto in2 = vector_u32::load(buf + 1 * N);
|
|
20
|
+
const auto in3 = vector_u32::load(buf + 2 * N);
|
|
21
|
+
const auto in4 = vector_u32::load(buf + 3 * N);
|
|
22
|
+
|
|
23
|
+
if (ec == ErrorChecking::enabled) {
|
|
24
|
+
const auto combined = in1 | in2 | in3 | in4;
|
|
25
|
+
const auto too_big = (combined & high_bytes_mask) != uint32_t(0);
|
|
26
|
+
|
|
27
|
+
if (simdutf_unlikely(too_big.any())) {
|
|
28
|
+
// Scalar code will carry on from the beginning of the current block
|
|
29
|
+
// and report the exact error position.
|
|
30
|
+
return utf32_to_latin1_t{error_code::OTHER, buf, latin1_output};
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// Note: element #1 contains 0, and is used to mask-out elements
|
|
35
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
36
|
+
const auto shlo = vector_u8(0 + 3, 4 + 3, 8 + 3, 12 + 3, 16 + 3, 20 + 3,
|
|
37
|
+
24 + 3, 28 + 3, 1, 1, 1, 1, 1, 1, 1, 1);
|
|
38
|
+
const auto shhi = vector_u8(1, 1, 1, 1, 1, 1, 1, 1, 0 + 3, 4 + 3, 8 + 3,
|
|
39
|
+
12 + 3, 16 + 3, 20 + 3, 24 + 3, 28 + 3);
|
|
40
|
+
#else
|
|
41
|
+
const auto shlo =
|
|
42
|
+
vector_u8(0, 4, 8, 12, 16, 20, 24, 28, 1, 1, 1, 1, 1, 1, 1, 1);
|
|
43
|
+
const auto shhi =
|
|
44
|
+
vector_u8(1, 1, 1, 1, 1, 1, 1, 1, 0, 4, 8, 12, 16, 20, 24, 28);
|
|
45
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
46
|
+
const auto lo = shlo.lookup_32(as_vector_u8(in1), as_vector_u8(in2));
|
|
47
|
+
const auto hi = shhi.lookup_32(as_vector_u8(in3), as_vector_u8(in4));
|
|
48
|
+
|
|
49
|
+
const auto merged = lo | hi;
|
|
50
|
+
|
|
51
|
+
merged.store(latin1_output);
|
|
52
|
+
latin1_output += 4 * N;
|
|
53
|
+
buf += 4 * N;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return utf32_to_latin1_t{error_code::SUCCESS, buf, latin1_output};
|
|
57
|
+
}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
struct utf32_to_utf16_t {
|
|
2
|
+
error_code err;
|
|
3
|
+
const char32_t *input;
|
|
4
|
+
char16_t *output;
|
|
5
|
+
};
|
|
6
|
+
|
|
7
|
+
template <endianness big_endian, ErrorReporting er>
|
|
8
|
+
utf32_to_utf16_t ppc64_convert_utf32_to_utf16(const char32_t *buf, size_t len,
|
|
9
|
+
char16_t *utf16_output) {
|
|
10
|
+
|
|
11
|
+
const char32_t *end = buf + len;
|
|
12
|
+
|
|
13
|
+
const auto zero = vector_u32::zero();
|
|
14
|
+
const auto v_ffff0000 = vector_u32::splat(0xffff0000);
|
|
15
|
+
|
|
16
|
+
auto forbidden_global = simd16<bool>();
|
|
17
|
+
|
|
18
|
+
while (end - buf >= 8) {
|
|
19
|
+
const auto in0 = vector_u32::load(buf);
|
|
20
|
+
const auto in1 = vector_u32::load(buf + vector_u32::ELEMENTS);
|
|
21
|
+
|
|
22
|
+
const auto any_surrogate = ((in0 | in1) & v_ffff0000) != zero;
|
|
23
|
+
|
|
24
|
+
// Check if no bits set above 15th
|
|
25
|
+
if (any_surrogate.is_zero()) {
|
|
26
|
+
// Pack UTF-32 to UTF-16
|
|
27
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
28
|
+
const auto sh = big_endian ? vector_u8(2, 3, 6, 7, 10, 11, 14, 15, 18, 19,
|
|
29
|
+
22, 23, 26, 27, 30, 31)
|
|
30
|
+
: vector_u8(3, 2, 7, 6, 11, 10, 15, 14, 19, 18,
|
|
31
|
+
23, 22, 27, 26, 31, 30);
|
|
32
|
+
#else
|
|
33
|
+
const auto sh = big_endian ? vector_u8(1, 0, 5, 4, 9, 8, 13, 12, 17, 16,
|
|
34
|
+
21, 20, 25, 24, 29, 28)
|
|
35
|
+
: vector_u8(0, 1, 4, 5, 8, 9, 12, 13, 16, 17,
|
|
36
|
+
20, 21, 24, 25, 28, 29);
|
|
37
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
38
|
+
const auto packed0 = sh.lookup_32(as_vector_u8(in0), as_vector_u8(in1));
|
|
39
|
+
const auto packed = as_vector_u16(packed0);
|
|
40
|
+
|
|
41
|
+
#if SIMDUTF_IS_BIG_ENDIAN
|
|
42
|
+
const auto v_f800 =
|
|
43
|
+
big_endian ? vector_u16::splat(0xf800) : vector_u16::splat(0x00f8);
|
|
44
|
+
const auto v_d800 =
|
|
45
|
+
big_endian ? vector_u16::splat(0xd800) : vector_u16::splat(0x00d8);
|
|
46
|
+
#else
|
|
47
|
+
const auto v_f800 =
|
|
48
|
+
big_endian ? vector_u16::splat(0x00f8) : vector_u16::splat(0xf800);
|
|
49
|
+
const auto v_d800 =
|
|
50
|
+
big_endian ? vector_u16::splat(0x00d8) : vector_u16::splat(0xd800);
|
|
51
|
+
#endif // SIMDUTF_IS_BIG_ENDIAN
|
|
52
|
+
const auto forbidden = (packed & v_f800) == v_d800;
|
|
53
|
+
|
|
54
|
+
switch (er) {
|
|
55
|
+
case ErrorReporting::precise:
|
|
56
|
+
if (not forbidden.is_zero()) {
|
|
57
|
+
// scalar procedure will rescan the portion of buffer we've just
|
|
58
|
+
// analysed
|
|
59
|
+
return utf32_to_utf16_t{error_code::OTHER, buf, utf16_output};
|
|
60
|
+
}
|
|
61
|
+
break;
|
|
62
|
+
case ErrorReporting::at_the_end:
|
|
63
|
+
forbidden_global |= forbidden;
|
|
64
|
+
break;
|
|
65
|
+
case ErrorReporting::none:
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
packed.store(utf16_output);
|
|
70
|
+
utf16_output += 8;
|
|
71
|
+
buf += 8;
|
|
72
|
+
} else {
|
|
73
|
+
size_t forward = 7;
|
|
74
|
+
size_t k = 0;
|
|
75
|
+
if (size_t(end - buf) < forward + 1) {
|
|
76
|
+
forward = size_t(end - buf - 1);
|
|
77
|
+
}
|
|
78
|
+
for (; k < forward; k++) {
|
|
79
|
+
uint32_t word = buf[k];
|
|
80
|
+
if ((word & 0xFFFF0000) == 0) {
|
|
81
|
+
// will not generate a surrogate pair
|
|
82
|
+
if (word >= 0xD800 && word <= 0xDFFF) {
|
|
83
|
+
return utf32_to_utf16_t{error_code::SURROGATE, buf + k,
|
|
84
|
+
utf16_output};
|
|
85
|
+
}
|
|
86
|
+
*utf16_output++ =
|
|
87
|
+
scalar::utf16::swap_if_needed<big_endian>(uint16_t(word));
|
|
88
|
+
} else {
|
|
89
|
+
// will generate a surrogate pair
|
|
90
|
+
if (word > 0x10FFFF) {
|
|
91
|
+
return utf32_to_utf16_t{error_code::TOO_LARGE, buf + k,
|
|
92
|
+
utf16_output};
|
|
93
|
+
}
|
|
94
|
+
word -= 0x10000;
|
|
95
|
+
uint16_t high_surrogate = uint16_t(0xD800 + (word >> 10));
|
|
96
|
+
uint16_t low_surrogate = uint16_t(0xDC00 + (word & 0x3FF));
|
|
97
|
+
high_surrogate =
|
|
98
|
+
scalar::utf16::swap_if_needed<big_endian>(high_surrogate);
|
|
99
|
+
low_surrogate =
|
|
100
|
+
scalar::utf16::swap_if_needed<big_endian>(low_surrogate);
|
|
101
|
+
*utf16_output++ = char16_t(high_surrogate);
|
|
102
|
+
*utf16_output++ = char16_t(low_surrogate);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
buf += k;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
if (er == ErrorReporting::at_the_end) {
|
|
110
|
+
// check for invalid input
|
|
111
|
+
if (not forbidden_global.is_zero()) {
|
|
112
|
+
return utf32_to_utf16_t{error_code::SURROGATE, buf, utf16_output};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return utf32_to_utf16_t{error_code::SUCCESS, buf, utf16_output};
|
|
117
|
+
}
|