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,24 @@
|
|
|
1
|
+
template <endianness big_endian>
|
|
2
|
+
std::pair<const char *, char16_t *>
|
|
3
|
+
arm_convert_latin1_to_utf16(const char *buf, size_t len,
|
|
4
|
+
char16_t *utf16_output) {
|
|
5
|
+
const char *end = buf + len;
|
|
6
|
+
|
|
7
|
+
while (end - buf >= 16) {
|
|
8
|
+
uint8x16_t in8 = vld1q_u8(reinterpret_cast<const uint8_t *>(buf));
|
|
9
|
+
uint16x8_t inlow = vmovl_u8(vget_low_u8(in8));
|
|
10
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
11
|
+
inlow = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(inlow)));
|
|
12
|
+
}
|
|
13
|
+
vst1q_u16(reinterpret_cast<uint16_t *>(utf16_output), inlow);
|
|
14
|
+
uint16x8_t inhigh = vmovl_u8(vget_high_u8(in8));
|
|
15
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
16
|
+
inhigh = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(inhigh)));
|
|
17
|
+
}
|
|
18
|
+
vst1q_u16(reinterpret_cast<uint16_t *>(utf16_output + 8), inhigh);
|
|
19
|
+
utf16_output += 16;
|
|
20
|
+
buf += 16;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return std::make_pair(buf, utf16_output);
|
|
24
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
std::pair<const char *, char32_t *>
|
|
2
|
+
arm_convert_latin1_to_utf32(const char *buf, size_t len,
|
|
3
|
+
char32_t *utf32_output) {
|
|
4
|
+
const char *end = buf + len;
|
|
5
|
+
|
|
6
|
+
while (end - buf >= 16) {
|
|
7
|
+
uint8x16_t in8 = vld1q_u8(reinterpret_cast<const uint8_t *>(buf));
|
|
8
|
+
uint16x8_t in8low = vmovl_u8(vget_low_u8(in8));
|
|
9
|
+
uint32x4_t in16lowlow = vmovl_u16(vget_low_u16(in8low));
|
|
10
|
+
uint32x4_t in16lowhigh = vmovl_u16(vget_high_u16(in8low));
|
|
11
|
+
uint16x8_t in8high = vmovl_u8(vget_high_u8(in8));
|
|
12
|
+
uint32x4_t in8highlow = vmovl_u16(vget_low_u16(in8high));
|
|
13
|
+
uint32x4_t in8highhigh = vmovl_u16(vget_high_u16(in8high));
|
|
14
|
+
vst1q_u32(reinterpret_cast<uint32_t *>(utf32_output), in16lowlow);
|
|
15
|
+
vst1q_u32(reinterpret_cast<uint32_t *>(utf32_output + 4), in16lowhigh);
|
|
16
|
+
vst1q_u32(reinterpret_cast<uint32_t *>(utf32_output + 8), in8highlow);
|
|
17
|
+
vst1q_u32(reinterpret_cast<uint32_t *>(utf32_output + 12), in8highhigh);
|
|
18
|
+
|
|
19
|
+
utf32_output += 16;
|
|
20
|
+
buf += 16;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return std::make_pair(buf, utf32_output);
|
|
24
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Returns a pair: the first unprocessed byte from buf and utf8_output
|
|
3
|
+
A scalar routing should carry on the conversion of the tail.
|
|
4
|
+
*/
|
|
5
|
+
std::pair<const char *, char *>
|
|
6
|
+
arm_convert_latin1_to_utf8(const char *latin1_input, size_t len,
|
|
7
|
+
char *utf8_out) {
|
|
8
|
+
uint8_t *utf8_output = reinterpret_cast<uint8_t *>(utf8_out);
|
|
9
|
+
const char *end = latin1_input + len;
|
|
10
|
+
const uint16x8_t v_c080 = vmovq_n_u16((uint16_t)0xc080);
|
|
11
|
+
// We always write 16 bytes, of which more than the first 8 bytes
|
|
12
|
+
// are valid. A safety margin of 8 is more than sufficient.
|
|
13
|
+
while (end - latin1_input >= 16 + 8) {
|
|
14
|
+
uint8x16_t in8 = vld1q_u8(reinterpret_cast<const uint8_t *>(latin1_input));
|
|
15
|
+
if (vmaxvq_u8(in8) <= 0x7F) { // ASCII fast path!!!!
|
|
16
|
+
vst1q_u8(utf8_output, in8);
|
|
17
|
+
utf8_output += 16;
|
|
18
|
+
latin1_input += 16;
|
|
19
|
+
continue;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// We just fallback on UTF-16 code. This could be optimized/simplified
|
|
23
|
+
// further.
|
|
24
|
+
uint16x8_t in16 = vmovl_u8(vget_low_u8(in8));
|
|
25
|
+
// 1. prepare 2-byte values
|
|
26
|
+
// input 8-bit word : [aabb|bbbb] x 8
|
|
27
|
+
// expected output : [1100|00aa|10bb|bbbb] x 8
|
|
28
|
+
const uint16x8_t v_1f00 = vmovq_n_u16((int16_t)0x1f00);
|
|
29
|
+
const uint16x8_t v_003f = vmovq_n_u16((int16_t)0x003f);
|
|
30
|
+
|
|
31
|
+
// t0 = [0000|00aa|bbbb|bb00]
|
|
32
|
+
const uint16x8_t t0 = vshlq_n_u16(in16, 2);
|
|
33
|
+
// t1 = [0000|00aa|0000|0000]
|
|
34
|
+
const uint16x8_t t1 = vandq_u16(t0, v_1f00);
|
|
35
|
+
// t2 = [0000|0000|00bb|bbbb]
|
|
36
|
+
const uint16x8_t t2 = vandq_u16(in16, v_003f);
|
|
37
|
+
// t3 = [0000|00aa|00bb|bbbb]
|
|
38
|
+
const uint16x8_t t3 = vorrq_u16(t1, t2);
|
|
39
|
+
// t4 = [1100|00aa|10bb|bbbb]
|
|
40
|
+
const uint16x8_t t4 = vorrq_u16(t3, v_c080);
|
|
41
|
+
// 2. merge ASCII and 2-byte codewords
|
|
42
|
+
const uint16x8_t v_007f = vmovq_n_u16((uint16_t)0x007F);
|
|
43
|
+
const uint16x8_t one_byte_bytemask = vcleq_u16(in16, v_007f);
|
|
44
|
+
const uint8x16_t utf8_unpacked =
|
|
45
|
+
vreinterpretq_u8_u16(vbslq_u16(one_byte_bytemask, in16, t4));
|
|
46
|
+
// 3. prepare bitmask for 8-bit lookup
|
|
47
|
+
#ifdef SIMDUTF_REGULAR_VISUAL_STUDIO
|
|
48
|
+
const uint16x8_t mask = simdutf_make_uint16x8_t(
|
|
49
|
+
0x0001, 0x0004, 0x0010, 0x0040, 0x0002, 0x0008, 0x0020, 0x0080);
|
|
50
|
+
#else
|
|
51
|
+
const uint16x8_t mask = {0x0001, 0x0004, 0x0010, 0x0040,
|
|
52
|
+
0x0002, 0x0008, 0x0020, 0x0080};
|
|
53
|
+
#endif
|
|
54
|
+
uint16_t m2 = vaddvq_u16(vandq_u16(one_byte_bytemask, mask));
|
|
55
|
+
// 4. pack the bytes
|
|
56
|
+
const uint8_t *row =
|
|
57
|
+
&simdutf::tables::utf16_to_utf8::pack_1_2_utf8_bytes[m2][0];
|
|
58
|
+
const uint8x16_t shuffle = vld1q_u8(row + 1);
|
|
59
|
+
const uint8x16_t utf8_packed = vqtbl1q_u8(utf8_unpacked, shuffle);
|
|
60
|
+
|
|
61
|
+
// 5. store bytes
|
|
62
|
+
vst1q_u8(utf8_output, utf8_packed);
|
|
63
|
+
// 6. adjust pointers
|
|
64
|
+
latin1_input += 8;
|
|
65
|
+
utf8_output += row[0];
|
|
66
|
+
|
|
67
|
+
} // while
|
|
68
|
+
|
|
69
|
+
return std::make_pair(latin1_input, reinterpret_cast<char *>(utf8_output));
|
|
70
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
|
|
2
|
+
template <endianness big_endian>
|
|
3
|
+
std::pair<const char16_t *, char *>
|
|
4
|
+
arm_convert_utf16_to_latin1(const char16_t *buf, size_t len,
|
|
5
|
+
char *latin1_output) {
|
|
6
|
+
const char16_t *end = buf + len;
|
|
7
|
+
while (end - buf >= 8) {
|
|
8
|
+
uint16x8_t in = vld1q_u16(reinterpret_cast<const uint16_t *>(buf));
|
|
9
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
10
|
+
in = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(in)));
|
|
11
|
+
}
|
|
12
|
+
if (vmaxvq_u16(in) <= 0xff) {
|
|
13
|
+
// 1. pack the bytes
|
|
14
|
+
uint8x8_t latin1_packed = vmovn_u16(in);
|
|
15
|
+
// 2. store (8 bytes)
|
|
16
|
+
vst1_u8(reinterpret_cast<uint8_t *>(latin1_output), latin1_packed);
|
|
17
|
+
// 3. adjust pointers
|
|
18
|
+
buf += 8;
|
|
19
|
+
latin1_output += 8;
|
|
20
|
+
} else {
|
|
21
|
+
return std::make_pair(nullptr, reinterpret_cast<char *>(latin1_output));
|
|
22
|
+
}
|
|
23
|
+
} // while
|
|
24
|
+
return std::make_pair(buf, latin1_output);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
template <endianness big_endian>
|
|
28
|
+
std::pair<result, char *>
|
|
29
|
+
arm_convert_utf16_to_latin1_with_errors(const char16_t *buf, size_t len,
|
|
30
|
+
char *latin1_output) {
|
|
31
|
+
const char16_t *start = buf;
|
|
32
|
+
const char16_t *end = buf + len;
|
|
33
|
+
while (end - buf >= 8) {
|
|
34
|
+
uint16x8_t in = vld1q_u16(reinterpret_cast<const uint16_t *>(buf));
|
|
35
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
36
|
+
in = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(in)));
|
|
37
|
+
}
|
|
38
|
+
if (vmaxvq_u16(in) <= 0xff) {
|
|
39
|
+
// 1. pack the bytes
|
|
40
|
+
uint8x8_t latin1_packed = vmovn_u16(in);
|
|
41
|
+
// 2. store (8 bytes)
|
|
42
|
+
vst1_u8(reinterpret_cast<uint8_t *>(latin1_output), latin1_packed);
|
|
43
|
+
// 3. adjust pointers
|
|
44
|
+
buf += 8;
|
|
45
|
+
latin1_output += 8;
|
|
46
|
+
} else {
|
|
47
|
+
// Let us do a scalar fallback.
|
|
48
|
+
for (int k = 0; k < 8; k++) {
|
|
49
|
+
uint16_t word = scalar::utf16::swap_if_needed<big_endian>(buf[k]);
|
|
50
|
+
if (word <= 0xff) {
|
|
51
|
+
*latin1_output++ = char(word);
|
|
52
|
+
} else {
|
|
53
|
+
return std::make_pair(result(error_code::TOO_LARGE, buf - start + k),
|
|
54
|
+
latin1_output);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
} // while
|
|
59
|
+
return std::make_pair(result(error_code::SUCCESS, buf - start),
|
|
60
|
+
latin1_output);
|
|
61
|
+
}
|
|
@@ -0,0 +1,185 @@
|
|
|
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
|
+
Returns a pair: the first unprocessed byte from buf and utf8_output
|
|
51
|
+
A scalar routing should carry on the conversion of the tail.
|
|
52
|
+
*/
|
|
53
|
+
template <endianness big_endian>
|
|
54
|
+
std::pair<const char16_t *, char32_t *>
|
|
55
|
+
arm_convert_utf16_to_utf32(const char16_t *buf, size_t len,
|
|
56
|
+
char32_t *utf32_out) {
|
|
57
|
+
uint32_t *utf32_output = reinterpret_cast<uint32_t *>(utf32_out);
|
|
58
|
+
const char16_t *end = buf + len;
|
|
59
|
+
|
|
60
|
+
const uint16x8_t v_f800 = vmovq_n_u16((uint16_t)0xf800);
|
|
61
|
+
const uint16x8_t v_d800 = vmovq_n_u16((uint16_t)0xd800);
|
|
62
|
+
|
|
63
|
+
while (end - buf >= 8) {
|
|
64
|
+
uint16x8_t in = vld1q_u16(reinterpret_cast<const uint16_t *>(buf));
|
|
65
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
66
|
+
in = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(in)));
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const uint16x8_t surrogates_bytemask =
|
|
70
|
+
vceqq_u16(vandq_u16(in, v_f800), v_d800);
|
|
71
|
+
// It might seem like checking for surrogates_bitmask == 0xc000 could help.
|
|
72
|
+
// However, it is likely an uncommon occurrence.
|
|
73
|
+
if (vmaxvq_u16(surrogates_bytemask) == 0) {
|
|
74
|
+
// case: no surrogate pairs, extend all 16-bit code units to 32-bit code
|
|
75
|
+
// units
|
|
76
|
+
vst1q_u32(utf32_output, vmovl_u16(vget_low_u16(in)));
|
|
77
|
+
vst1q_u32(utf32_output + 4, vmovl_high_u16(in));
|
|
78
|
+
utf32_output += 8;
|
|
79
|
+
buf += 8;
|
|
80
|
+
// surrogate pair(s) in a register
|
|
81
|
+
} else {
|
|
82
|
+
// Let us do a scalar fallback.
|
|
83
|
+
// It may seem wasteful to use scalar code, but being efficient with SIMD
|
|
84
|
+
// in the presence of surrogate pairs may require non-trivial tables.
|
|
85
|
+
size_t forward = 15;
|
|
86
|
+
size_t k = 0;
|
|
87
|
+
if (size_t(end - buf) < forward + 1) {
|
|
88
|
+
forward = size_t(end - buf - 1);
|
|
89
|
+
}
|
|
90
|
+
for (; k < forward; k++) {
|
|
91
|
+
uint16_t word = scalar::utf16::swap_if_needed<big_endian>(buf[k]);
|
|
92
|
+
if ((word & 0xF800) != 0xD800) {
|
|
93
|
+
*utf32_output++ = char32_t(word);
|
|
94
|
+
} else {
|
|
95
|
+
// must be a surrogate pair
|
|
96
|
+
uint16_t diff = uint16_t(word - 0xD800);
|
|
97
|
+
uint16_t next_word =
|
|
98
|
+
scalar::utf16::swap_if_needed<big_endian>(buf[k + 1]);
|
|
99
|
+
k++;
|
|
100
|
+
uint16_t diff2 = uint16_t(next_word - 0xDC00);
|
|
101
|
+
if ((diff | diff2) > 0x3FF) {
|
|
102
|
+
return std::make_pair(nullptr,
|
|
103
|
+
reinterpret_cast<char32_t *>(utf32_output));
|
|
104
|
+
}
|
|
105
|
+
uint32_t value = (diff << 10) + diff2 + 0x10000;
|
|
106
|
+
*utf32_output++ = char32_t(value);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
buf += k;
|
|
110
|
+
}
|
|
111
|
+
} // while
|
|
112
|
+
return std::make_pair(buf, reinterpret_cast<char32_t *>(utf32_output));
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/*
|
|
116
|
+
Returns a pair: a result struct and utf8_output.
|
|
117
|
+
If there is an error, the count field of the result is the position of the
|
|
118
|
+
error. Otherwise, it is the position of the first unprocessed byte in buf
|
|
119
|
+
(even if finished). A scalar routing should carry on the conversion of the
|
|
120
|
+
tail if needed.
|
|
121
|
+
*/
|
|
122
|
+
template <endianness big_endian>
|
|
123
|
+
std::pair<result, char32_t *>
|
|
124
|
+
arm_convert_utf16_to_utf32_with_errors(const char16_t *buf, size_t len,
|
|
125
|
+
char32_t *utf32_out) {
|
|
126
|
+
uint32_t *utf32_output = reinterpret_cast<uint32_t *>(utf32_out);
|
|
127
|
+
const char16_t *start = buf;
|
|
128
|
+
const char16_t *end = buf + len;
|
|
129
|
+
|
|
130
|
+
const uint16x8_t v_f800 = vmovq_n_u16((uint16_t)0xf800);
|
|
131
|
+
const uint16x8_t v_d800 = vmovq_n_u16((uint16_t)0xd800);
|
|
132
|
+
|
|
133
|
+
while ((end - buf) >= 8) {
|
|
134
|
+
uint16x8_t in = vld1q_u16(reinterpret_cast<const uint16_t *>(buf));
|
|
135
|
+
if simdutf_constexpr (!match_system(big_endian)) {
|
|
136
|
+
in = vreinterpretq_u16_u8(vrev16q_u8(vreinterpretq_u8_u16(in)));
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
const uint16x8_t surrogates_bytemask =
|
|
140
|
+
vceqq_u16(vandq_u16(in, v_f800), v_d800);
|
|
141
|
+
// It might seem like checking for surrogates_bitmask == 0xc000 could help.
|
|
142
|
+
// However, it is likely an uncommon occurrence.
|
|
143
|
+
if (vmaxvq_u16(surrogates_bytemask) == 0) {
|
|
144
|
+
// case: no surrogate pairs, extend all 16-bit code units to 32-bit code
|
|
145
|
+
// units
|
|
146
|
+
vst1q_u32(utf32_output, vmovl_u16(vget_low_u16(in)));
|
|
147
|
+
vst1q_u32(utf32_output + 4, vmovl_high_u16(in));
|
|
148
|
+
utf32_output += 8;
|
|
149
|
+
buf += 8;
|
|
150
|
+
// surrogate pair(s) in a register
|
|
151
|
+
} else {
|
|
152
|
+
// Let us do a scalar fallback.
|
|
153
|
+
// It may seem wasteful to use scalar code, but being efficient with SIMD
|
|
154
|
+
// in the presence of surrogate pairs may require non-trivial tables.
|
|
155
|
+
size_t forward = 15;
|
|
156
|
+
size_t k = 0;
|
|
157
|
+
if (size_t(end - buf) < forward + 1) {
|
|
158
|
+
forward = size_t(end - buf - 1);
|
|
159
|
+
}
|
|
160
|
+
for (; k < forward; k++) {
|
|
161
|
+
uint16_t word = scalar::utf16::swap_if_needed<big_endian>(buf[k]);
|
|
162
|
+
if ((word & 0xF800) != 0xD800) {
|
|
163
|
+
*utf32_output++ = char32_t(word);
|
|
164
|
+
} else {
|
|
165
|
+
// must be a surrogate pair
|
|
166
|
+
uint16_t diff = uint16_t(word - 0xD800);
|
|
167
|
+
uint16_t next_word =
|
|
168
|
+
scalar::utf16::swap_if_needed<big_endian>(buf[k + 1]);
|
|
169
|
+
k++;
|
|
170
|
+
uint16_t diff2 = uint16_t(next_word - 0xDC00);
|
|
171
|
+
if ((diff | diff2) > 0x3FF) {
|
|
172
|
+
return std::make_pair(
|
|
173
|
+
result(error_code::SURROGATE, buf - start + k - 1),
|
|
174
|
+
reinterpret_cast<char32_t *>(utf32_output));
|
|
175
|
+
}
|
|
176
|
+
uint32_t value = (diff << 10) + diff2 + 0x10000;
|
|
177
|
+
*utf32_output++ = char32_t(value);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
buf += k;
|
|
181
|
+
}
|
|
182
|
+
} // while
|
|
183
|
+
return std::make_pair(result(error_code::SUCCESS, buf - start),
|
|
184
|
+
reinterpret_cast<char32_t *>(utf32_output));
|
|
185
|
+
}
|