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.
Files changed (561) hide show
  1. package/QuickCrypto.podspec +12 -38
  2. package/README.md +2 -0
  3. package/android/CMakeLists.txt +3 -0
  4. package/android/build.gradle +5 -1
  5. package/cpp/argon2/HybridArgon2.cpp +10 -3
  6. package/cpp/blake3/HybridBlake3.cpp +5 -3
  7. package/cpp/cipher/CCMCipher.cpp +29 -16
  8. package/cpp/cipher/CCMCipher.hpp +2 -4
  9. package/cpp/cipher/ChaCha20Cipher.cpp +14 -18
  10. package/cpp/cipher/ChaCha20Cipher.hpp +2 -4
  11. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +34 -23
  12. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +2 -4
  13. package/cpp/cipher/GCMCipher.cpp +14 -15
  14. package/cpp/cipher/HybridCipher.cpp +39 -36
  15. package/cpp/cipher/HybridCipher.hpp +17 -1
  16. package/cpp/cipher/HybridRsaCipher.cpp +74 -29
  17. package/cpp/cipher/OCBCipher.cpp +4 -3
  18. package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +14 -13
  19. package/cpp/cipher/XSalsa20Cipher.cpp +72 -6
  20. package/cpp/cipher/XSalsa20Cipher.hpp +25 -3
  21. package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +21 -25
  22. package/cpp/dh/HybridDiffieHellman.cpp +29 -0
  23. package/cpp/ec/HybridEcKeyPair.cpp +35 -33
  24. package/cpp/ec/HybridEcKeyPair.hpp +3 -7
  25. package/cpp/ecdh/HybridECDH.cpp +23 -0
  26. package/cpp/ed25519/HybridEdKeyPair.cpp +73 -117
  27. package/cpp/ed25519/HybridEdKeyPair.hpp +5 -9
  28. package/cpp/hash/HybridHash.cpp +5 -7
  29. package/cpp/hkdf/HybridHkdf.cpp +6 -4
  30. package/cpp/hmac/HybridHmac.cpp +4 -6
  31. package/cpp/kmac/HybridKmac.cpp +4 -4
  32. package/cpp/mldsa/HybridMlDsaKeyPair.cpp +37 -49
  33. package/cpp/mlkem/HybridMlKemKeyPair.cpp +39 -43
  34. package/cpp/pbkdf2/HybridPbkdf2.cpp +7 -8
  35. package/cpp/rsa/HybridRsaKeyPair.cpp +5 -8
  36. package/cpp/rsa/HybridRsaKeyPair.hpp +4 -7
  37. package/cpp/scrypt/HybridScrypt.cpp +6 -4
  38. package/cpp/sign/HybridSignHandle.cpp +25 -68
  39. package/cpp/sign/HybridVerifyHandle.cpp +23 -60
  40. package/cpp/utils/HybridUtils.cpp +213 -111
  41. package/cpp/utils/HybridUtils.hpp +9 -2
  42. package/cpp/utils/QuickCryptoUtils.hpp +72 -0
  43. package/deps/simdutf/LICENSE-APACHE +201 -0
  44. package/deps/simdutf/LICENSE-MIT +18 -0
  45. package/deps/simdutf/README.md +2782 -0
  46. package/deps/simdutf/include/simdutf/avx512.h +79 -0
  47. package/deps/simdutf/include/simdutf/base64_implementation.h +158 -0
  48. package/deps/simdutf/include/simdutf/base64_tables.h +887 -0
  49. package/deps/simdutf/include/simdutf/common_defs.h +186 -0
  50. package/deps/simdutf/include/simdutf/compiler_check.h +50 -0
  51. package/deps/simdutf/include/simdutf/constexpr_ptr.h +138 -0
  52. package/deps/simdutf/include/simdutf/encoding_types.h +189 -0
  53. package/deps/simdutf/include/simdutf/error.h +126 -0
  54. package/deps/simdutf/include/simdutf/implementation.h +7081 -0
  55. package/deps/simdutf/include/simdutf/internal/isadetection.h +325 -0
  56. package/deps/simdutf/include/simdutf/portability.h +285 -0
  57. package/deps/simdutf/include/simdutf/scalar/ascii.h +86 -0
  58. package/deps/simdutf/include/simdutf/scalar/atomic_util.h +105 -0
  59. package/deps/simdutf/include/simdutf/scalar/base64.h +911 -0
  60. package/deps/simdutf/include/simdutf/scalar/latin1.h +26 -0
  61. package/deps/simdutf/include/simdutf/scalar/latin1_to_utf16/latin1_to_utf16.h +52 -0
  62. package/deps/simdutf/include/simdutf/scalar/latin1_to_utf32/latin1_to_utf32.h +27 -0
  63. package/deps/simdutf/include/simdutf/scalar/latin1_to_utf8/latin1_to_utf8.h +191 -0
  64. package/deps/simdutf/include/simdutf/scalar/swap_bytes.h +35 -0
  65. package/deps/simdutf/include/simdutf/scalar/utf16.h +226 -0
  66. package/deps/simdutf/include/simdutf/scalar/utf16_to_latin1/utf16_to_latin1.h +108 -0
  67. package/deps/simdutf/include/simdutf/scalar/utf16_to_latin1/valid_utf16_to_latin1.h +40 -0
  68. package/deps/simdutf/include/simdutf/scalar/utf16_to_utf32/utf16_to_utf32.h +86 -0
  69. package/deps/simdutf/include/simdutf/scalar/utf16_to_utf32/valid_utf16_to_utf32.h +44 -0
  70. package/deps/simdutf/include/simdutf/scalar/utf16_to_utf8/utf16_to_utf8.h +295 -0
  71. package/deps/simdutf/include/simdutf/scalar/utf16_to_utf8/valid_utf16_to_utf8.h +91 -0
  72. package/deps/simdutf/include/simdutf/scalar/utf32.h +82 -0
  73. package/deps/simdutf/include/simdutf/scalar/utf32_to_latin1/utf32_to_latin1.h +68 -0
  74. package/deps/simdutf/include/simdutf/scalar/utf32_to_latin1/valid_utf32_to_latin1.h +67 -0
  75. package/deps/simdutf/include/simdutf/scalar/utf32_to_utf16/utf32_to_utf16.h +84 -0
  76. package/deps/simdutf/include/simdutf/scalar/utf32_to_utf16/valid_utf32_to_utf16.h +44 -0
  77. package/deps/simdutf/include/simdutf/scalar/utf32_to_utf8/utf32_to_utf8.h +142 -0
  78. package/deps/simdutf/include/simdutf/scalar/utf32_to_utf8/valid_utf32_to_utf8.h +72 -0
  79. package/deps/simdutf/include/simdutf/scalar/utf8.h +326 -0
  80. package/deps/simdutf/include/simdutf/scalar/utf8_to_latin1/utf8_to_latin1.h +225 -0
  81. package/deps/simdutf/include/simdutf/scalar/utf8_to_latin1/valid_utf8_to_latin1.h +87 -0
  82. package/deps/simdutf/include/simdutf/scalar/utf8_to_utf16/utf8_to_utf16.h +342 -0
  83. package/deps/simdutf/include/simdutf/scalar/utf8_to_utf16/valid_utf8_to_utf16.h +106 -0
  84. package/deps/simdutf/include/simdutf/scalar/utf8_to_utf32/utf8_to_utf32.h +299 -0
  85. package/deps/simdutf/include/simdutf/scalar/utf8_to_utf32/valid_utf8_to_utf32.h +83 -0
  86. package/deps/simdutf/include/simdutf/simdutf_version.h +26 -0
  87. package/deps/simdutf/include/simdutf.h +26 -0
  88. package/deps/simdutf/include/simdutf_c.h +342 -0
  89. package/deps/simdutf/src/arm64/arm_base64.cpp +791 -0
  90. package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf16.cpp +24 -0
  91. package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf32.cpp +24 -0
  92. package/deps/simdutf/src/arm64/arm_convert_latin1_to_utf8.cpp +70 -0
  93. package/deps/simdutf/src/arm64/arm_convert_utf16_to_latin1.cpp +61 -0
  94. package/deps/simdutf/src/arm64/arm_convert_utf16_to_utf32.cpp +185 -0
  95. package/deps/simdutf/src/arm64/arm_convert_utf16_to_utf8.cpp +780 -0
  96. package/deps/simdutf/src/arm64/arm_convert_utf32_to_latin1.cpp +60 -0
  97. package/deps/simdutf/src/arm64/arm_convert_utf32_to_utf16.cpp +208 -0
  98. package/deps/simdutf/src/arm64/arm_convert_utf32_to_utf8.cpp +505 -0
  99. package/deps/simdutf/src/arm64/arm_convert_utf8_to_latin1.cpp +69 -0
  100. package/deps/simdutf/src/arm64/arm_convert_utf8_to_utf16.cpp +313 -0
  101. package/deps/simdutf/src/arm64/arm_convert_utf8_to_utf32.cpp +179 -0
  102. package/deps/simdutf/src/arm64/arm_find.cpp +199 -0
  103. package/deps/simdutf/src/arm64/arm_utf16fix.cpp +185 -0
  104. package/deps/simdutf/src/arm64/arm_validate_utf16.cpp +165 -0
  105. package/deps/simdutf/src/arm64/arm_validate_utf32le.cpp +65 -0
  106. package/deps/simdutf/src/arm64/implementation.cpp +1442 -0
  107. package/deps/simdutf/src/encoding_types.cpp +67 -0
  108. package/deps/simdutf/src/error.cpp +3 -0
  109. package/deps/simdutf/src/fallback/implementation.cpp +589 -0
  110. package/deps/simdutf/src/generic/ascii_validation.h +50 -0
  111. package/deps/simdutf/src/generic/base64.h +233 -0
  112. package/deps/simdutf/src/generic/base64lengths.h +63 -0
  113. package/deps/simdutf/src/generic/buf_block_reader.h +109 -0
  114. package/deps/simdutf/src/generic/find.h +75 -0
  115. package/deps/simdutf/src/generic/utf16/change_endianness.h +24 -0
  116. package/deps/simdutf/src/generic/utf16/count_code_points_bytemask.h +58 -0
  117. package/deps/simdutf/src/generic/utf16/to_well_formed.h +93 -0
  118. package/deps/simdutf/src/generic/utf16/utf32_length_from_utf16.h +15 -0
  119. package/deps/simdutf/src/generic/utf16/utf8_length_from_utf16.h +35 -0
  120. package/deps/simdutf/src/generic/utf16/utf8_length_from_utf16_bytemask.h +199 -0
  121. package/deps/simdutf/src/generic/utf16.h +73 -0
  122. package/deps/simdutf/src/generic/utf32.h +136 -0
  123. package/deps/simdutf/src/generic/utf8/utf16_length_from_utf8_bytemask.h +53 -0
  124. package/deps/simdutf/src/generic/utf8.h +92 -0
  125. package/deps/simdutf/src/generic/utf8_to_latin1/utf8_to_latin1.h +316 -0
  126. package/deps/simdutf/src/generic/utf8_to_latin1/valid_utf8_to_latin1.h +78 -0
  127. package/deps/simdutf/src/generic/utf8_to_utf16/utf8_to_utf16.h +332 -0
  128. package/deps/simdutf/src/generic/utf8_to_utf16/valid_utf8_to_utf16.h +74 -0
  129. package/deps/simdutf/src/generic/utf8_to_utf32/utf8_to_utf32.h +318 -0
  130. package/deps/simdutf/src/generic/utf8_to_utf32/valid_utf8_to_utf32.h +42 -0
  131. package/deps/simdutf/src/generic/utf8_validation/utf8_lookup4_algorithm.h +223 -0
  132. package/deps/simdutf/src/generic/utf8_validation/utf8_validator.h +84 -0
  133. package/deps/simdutf/src/generic/validate_utf16.h +164 -0
  134. package/deps/simdutf/src/generic/validate_utf32.h +99 -0
  135. package/deps/simdutf/src/haswell/avx2_base64.cpp +837 -0
  136. package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf16.cpp +28 -0
  137. package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf32.cpp +20 -0
  138. package/deps/simdutf/src/haswell/avx2_convert_latin1_to_utf8.cpp +83 -0
  139. package/deps/simdutf/src/haswell/avx2_convert_utf16_to_latin1.cpp +83 -0
  140. package/deps/simdutf/src/haswell/avx2_convert_utf16_to_utf32.cpp +210 -0
  141. package/deps/simdutf/src/haswell/avx2_convert_utf16_to_utf8.cpp +602 -0
  142. package/deps/simdutf/src/haswell/avx2_convert_utf32_to_latin1.cpp +116 -0
  143. package/deps/simdutf/src/haswell/avx2_convert_utf32_to_utf16.cpp +164 -0
  144. package/deps/simdutf/src/haswell/avx2_convert_utf32_to_utf8.cpp +569 -0
  145. package/deps/simdutf/src/haswell/avx2_convert_utf8_to_latin1.cpp +60 -0
  146. package/deps/simdutf/src/haswell/avx2_convert_utf8_to_utf16.cpp +195 -0
  147. package/deps/simdutf/src/haswell/avx2_convert_utf8_to_utf32.cpp +135 -0
  148. package/deps/simdutf/src/haswell/avx2_utf16fix.cpp +173 -0
  149. package/deps/simdutf/src/haswell/avx2_validate_utf16.cpp +17 -0
  150. package/deps/simdutf/src/haswell/implementation.cpp +1447 -0
  151. package/deps/simdutf/src/icelake/icelake_ascii_validation.inl.cpp +19 -0
  152. package/deps/simdutf/src/icelake/icelake_base64.inl.cpp +630 -0
  153. package/deps/simdutf/src/icelake/icelake_common.inl.cpp +37 -0
  154. package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf16.inl.cpp +36 -0
  155. package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf32.inl.cpp +23 -0
  156. package/deps/simdutf/src/icelake/icelake_convert_latin1_to_utf8.inl.cpp +107 -0
  157. package/deps/simdutf/src/icelake/icelake_convert_utf16_to_latin1.inl.cpp +103 -0
  158. package/deps/simdutf/src/icelake/icelake_convert_utf16_to_utf32.inl.cpp +136 -0
  159. package/deps/simdutf/src/icelake/icelake_convert_utf16_to_utf8.inl.cpp +206 -0
  160. package/deps/simdutf/src/icelake/icelake_convert_utf32_to_latin1.inl.cpp +74 -0
  161. package/deps/simdutf/src/icelake/icelake_convert_utf32_to_utf16.inl.cpp +338 -0
  162. package/deps/simdutf/src/icelake/icelake_convert_utf32_to_utf8.inl.cpp +574 -0
  163. package/deps/simdutf/src/icelake/icelake_convert_utf8_to_latin1.inl.cpp +104 -0
  164. package/deps/simdutf/src/icelake/icelake_convert_utf8_to_utf16.inl.cpp +75 -0
  165. package/deps/simdutf/src/icelake/icelake_convert_valid_utf8_to_latin1.inl.cpp +69 -0
  166. package/deps/simdutf/src/icelake/icelake_find.inl.cpp +146 -0
  167. package/deps/simdutf/src/icelake/icelake_from_utf8.inl.cpp +266 -0
  168. package/deps/simdutf/src/icelake/icelake_from_valid_utf8.inl.cpp +136 -0
  169. package/deps/simdutf/src/icelake/icelake_macros.inl.cpp +143 -0
  170. package/deps/simdutf/src/icelake/icelake_utf16fix.cpp +138 -0
  171. package/deps/simdutf/src/icelake/icelake_utf32_validation.inl.cpp +63 -0
  172. package/deps/simdutf/src/icelake/icelake_utf8_common.inl.cpp +753 -0
  173. package/deps/simdutf/src/icelake/icelake_utf8_length_from_utf16.inl.cpp +269 -0
  174. package/deps/simdutf/src/icelake/icelake_utf8_validation.inl.cpp +116 -0
  175. package/deps/simdutf/src/icelake/implementation.cpp +1903 -0
  176. package/deps/simdutf/src/implementation.cpp +2526 -0
  177. package/deps/simdutf/src/lasx/implementation.cpp +1531 -0
  178. package/deps/simdutf/src/lasx/lasx_base64.cpp +695 -0
  179. package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf16.cpp +76 -0
  180. package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf32.cpp +55 -0
  181. package/deps/simdutf/src/lasx/lasx_convert_latin1_to_utf8.cpp +65 -0
  182. package/deps/simdutf/src/lasx/lasx_convert_utf16_to_latin1.cpp +64 -0
  183. package/deps/simdutf/src/lasx/lasx_convert_utf16_to_utf32.cpp +183 -0
  184. package/deps/simdutf/src/lasx/lasx_convert_utf16_to_utf8.cpp +550 -0
  185. package/deps/simdutf/src/lasx/lasx_convert_utf32_to_latin1.cpp +73 -0
  186. package/deps/simdutf/src/lasx/lasx_convert_utf32_to_utf16.cpp +218 -0
  187. package/deps/simdutf/src/lasx/lasx_convert_utf32_to_utf8.cpp +589 -0
  188. package/deps/simdutf/src/lasx/lasx_convert_utf8_to_latin1.cpp +72 -0
  189. package/deps/simdutf/src/lasx/lasx_convert_utf8_to_utf16.cpp +296 -0
  190. package/deps/simdutf/src/lasx/lasx_convert_utf8_to_utf32.cpp +190 -0
  191. package/deps/simdutf/src/lasx/lasx_find.cpp +64 -0
  192. package/deps/simdutf/src/lasx/lasx_validate_utf16.cpp +13 -0
  193. package/deps/simdutf/src/lasx/lasx_validate_utf32le.cpp +84 -0
  194. package/deps/simdutf/src/lsx/implementation.cpp +1417 -0
  195. package/deps/simdutf/src/lsx/lsx_base64.cpp +675 -0
  196. package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf16.cpp +39 -0
  197. package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf32.cpp +27 -0
  198. package/deps/simdutf/src/lsx/lsx_convert_latin1_to_utf8.cpp +56 -0
  199. package/deps/simdutf/src/lsx/lsx_convert_utf16_to_latin1.cpp +64 -0
  200. package/deps/simdutf/src/lsx/lsx_convert_utf16_to_utf32.cpp +133 -0
  201. package/deps/simdutf/src/lsx/lsx_convert_utf16_to_utf8.cpp +518 -0
  202. package/deps/simdutf/src/lsx/lsx_convert_utf32_to_latin1.cpp +66 -0
  203. package/deps/simdutf/src/lsx/lsx_convert_utf32_to_utf16.cpp +155 -0
  204. package/deps/simdutf/src/lsx/lsx_convert_utf32_to_utf8.cpp +459 -0
  205. package/deps/simdutf/src/lsx/lsx_convert_utf8_to_latin1.cpp +75 -0
  206. package/deps/simdutf/src/lsx/lsx_convert_utf8_to_utf16.cpp +291 -0
  207. package/deps/simdutf/src/lsx/lsx_convert_utf8_to_utf32.cpp +179 -0
  208. package/deps/simdutf/src/lsx/lsx_find.cpp +60 -0
  209. package/deps/simdutf/src/lsx/lsx_validate_utf16.cpp +13 -0
  210. package/deps/simdutf/src/lsx/lsx_validate_utf32le.cpp +68 -0
  211. package/deps/simdutf/src/ppc64/implementation.cpp +992 -0
  212. package/deps/simdutf/src/ppc64/ppc64_base64.cpp +480 -0
  213. package/deps/simdutf/src/ppc64/ppc64_base64_internal_tests.cpp +401 -0
  214. package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf16.cpp +12 -0
  215. package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf32.cpp +12 -0
  216. package/deps/simdutf/src/ppc64/ppc64_convert_latin1_to_utf8.cpp +149 -0
  217. package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_latin1.cpp +67 -0
  218. package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_utf32.cpp +87 -0
  219. package/deps/simdutf/src/ppc64/ppc64_convert_utf16_to_utf8.cpp +296 -0
  220. package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_latin1.cpp +57 -0
  221. package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_utf16.cpp +117 -0
  222. package/deps/simdutf/src/ppc64/ppc64_convert_utf32_to_utf8.cpp +166 -0
  223. package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_latin1.cpp +69 -0
  224. package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_utf16.cpp +211 -0
  225. package/deps/simdutf/src/ppc64/ppc64_convert_utf8_to_utf32.cpp +153 -0
  226. package/deps/simdutf/src/ppc64/ppc64_utf16_to_utf8_tables.h +1011 -0
  227. package/deps/simdutf/src/ppc64/ppc64_utf8_length_from_latin1.cpp +37 -0
  228. package/deps/simdutf/src/ppc64/ppc64_validate_utf16.cpp +19 -0
  229. package/deps/simdutf/src/ppc64/templates.cpp +91 -0
  230. package/deps/simdutf/src/rvv/implementation.cpp +138 -0
  231. package/deps/simdutf/src/rvv/rvv_find.cpp +27 -0
  232. package/deps/simdutf/src/rvv/rvv_helpers.inl.cpp +23 -0
  233. package/deps/simdutf/src/rvv/rvv_latin1_to.inl.cpp +71 -0
  234. package/deps/simdutf/src/rvv/rvv_length_from.inl.cpp +164 -0
  235. package/deps/simdutf/src/rvv/rvv_utf16_to.inl.cpp +399 -0
  236. package/deps/simdutf/src/rvv/rvv_utf16fix.cpp +110 -0
  237. package/deps/simdutf/src/rvv/rvv_utf32_to.inl.cpp +307 -0
  238. package/deps/simdutf/src/rvv/rvv_utf8_to.inl.cpp +435 -0
  239. package/deps/simdutf/src/rvv/rvv_validate.inl.cpp +275 -0
  240. package/deps/simdutf/src/simdutf/arm64/begin.h +2 -0
  241. package/deps/simdutf/src/simdutf/arm64/bitmanipulation.h +34 -0
  242. package/deps/simdutf/src/simdutf/arm64/end.h +2 -0
  243. package/deps/simdutf/src/simdutf/arm64/implementation.h +307 -0
  244. package/deps/simdutf/src/simdutf/arm64/intrinsics.h +10 -0
  245. package/deps/simdutf/src/simdutf/arm64/simd.h +547 -0
  246. package/deps/simdutf/src/simdutf/arm64/simd16-inl.h +403 -0
  247. package/deps/simdutf/src/simdutf/arm64/simd32-inl.h +129 -0
  248. package/deps/simdutf/src/simdutf/arm64/simd64-inl.h +28 -0
  249. package/deps/simdutf/src/simdutf/arm64.h +43 -0
  250. package/deps/simdutf/src/simdutf/fallback/begin.h +1 -0
  251. package/deps/simdutf/src/simdutf/fallback/bitmanipulation.h +13 -0
  252. package/deps/simdutf/src/simdutf/fallback/end.h +1 -0
  253. package/deps/simdutf/src/simdutf/fallback/implementation.h +331 -0
  254. package/deps/simdutf/src/simdutf/fallback.h +42 -0
  255. package/deps/simdutf/src/simdutf/haswell/begin.h +15 -0
  256. package/deps/simdutf/src/simdutf/haswell/bitmanipulation.h +35 -0
  257. package/deps/simdutf/src/simdutf/haswell/end.h +13 -0
  258. package/deps/simdutf/src/simdutf/haswell/implementation.h +338 -0
  259. package/deps/simdutf/src/simdutf/haswell/intrinsics.h +67 -0
  260. package/deps/simdutf/src/simdutf/haswell/simd.h +363 -0
  261. package/deps/simdutf/src/simdutf/haswell/simd16-inl.h +261 -0
  262. package/deps/simdutf/src/simdutf/haswell/simd32-inl.h +111 -0
  263. package/deps/simdutf/src/simdutf/haswell/simd64-inl.h +34 -0
  264. package/deps/simdutf/src/simdutf/haswell.h +63 -0
  265. package/deps/simdutf/src/simdutf/icelake/begin.h +14 -0
  266. package/deps/simdutf/src/simdutf/icelake/bitmanipulation.h +44 -0
  267. package/deps/simdutf/src/simdutf/icelake/end.h +12 -0
  268. package/deps/simdutf/src/simdutf/icelake/implementation.h +346 -0
  269. package/deps/simdutf/src/simdutf/icelake/intrinsics.h +138 -0
  270. package/deps/simdutf/src/simdutf/icelake/simd.h +17 -0
  271. package/deps/simdutf/src/simdutf/icelake/simd16-inl.h +90 -0
  272. package/deps/simdutf/src/simdutf/icelake/simd32-inl.h +47 -0
  273. package/deps/simdutf/src/simdutf/icelake.h +81 -0
  274. package/deps/simdutf/src/simdutf/lasx/begin.h +8 -0
  275. package/deps/simdutf/src/simdutf/lasx/bitmanipulation.h +25 -0
  276. package/deps/simdutf/src/simdutf/lasx/end.h +8 -0
  277. package/deps/simdutf/src/simdutf/lasx/implementation.h +310 -0
  278. package/deps/simdutf/src/simdutf/lasx/intrinsics.h +319 -0
  279. package/deps/simdutf/src/simdutf/lasx/simd.h +551 -0
  280. package/deps/simdutf/src/simdutf/lasx/simd16-inl.h +234 -0
  281. package/deps/simdutf/src/simdutf/lasx/simd32-inl.h +74 -0
  282. package/deps/simdutf/src/simdutf/lasx/simd64-inl.h +52 -0
  283. package/deps/simdutf/src/simdutf/lasx.h +49 -0
  284. package/deps/simdutf/src/simdutf/lsx/begin.h +2 -0
  285. package/deps/simdutf/src/simdutf/lsx/bitmanipulation.h +25 -0
  286. package/deps/simdutf/src/simdutf/lsx/end.h +2 -0
  287. package/deps/simdutf/src/simdutf/lsx/implementation.h +309 -0
  288. package/deps/simdutf/src/simdutf/lsx/intrinsics.h +196 -0
  289. package/deps/simdutf/src/simdutf/lsx/simd.h +421 -0
  290. package/deps/simdutf/src/simdutf/lsx/simd16-inl.h +242 -0
  291. package/deps/simdutf/src/simdutf/lsx/simd32-inl.h +69 -0
  292. package/deps/simdutf/src/simdutf/lsx/simd64-inl.h +50 -0
  293. package/deps/simdutf/src/simdutf/lsx.h +52 -0
  294. package/deps/simdutf/src/simdutf/ppc64/begin.h +1 -0
  295. package/deps/simdutf/src/simdutf/ppc64/bitmanipulation.h +29 -0
  296. package/deps/simdutf/src/simdutf/ppc64/end.h +1 -0
  297. package/deps/simdutf/src/simdutf/ppc64/implementation.h +348 -0
  298. package/deps/simdutf/src/simdutf/ppc64/intrinsics.h +19 -0
  299. package/deps/simdutf/src/simdutf/ppc64/simd.h +177 -0
  300. package/deps/simdutf/src/simdutf/ppc64/simd16-inl.h +327 -0
  301. package/deps/simdutf/src/simdutf/ppc64/simd32-inl.h +247 -0
  302. package/deps/simdutf/src/simdutf/ppc64/simd8-inl.h +618 -0
  303. package/deps/simdutf/src/simdutf/ppc64.h +40 -0
  304. package/deps/simdutf/src/simdutf/rvv/begin.h +7 -0
  305. package/deps/simdutf/src/simdutf/rvv/end.h +7 -0
  306. package/deps/simdutf/src/simdutf/rvv/implementation.h +321 -0
  307. package/deps/simdutf/src/simdutf/rvv/intrinsics.h +131 -0
  308. package/deps/simdutf/src/simdutf/rvv.h +41 -0
  309. package/deps/simdutf/src/simdutf/westmere/begin.h +8 -0
  310. package/deps/simdutf/src/simdutf/westmere/bitmanipulation.h +37 -0
  311. package/deps/simdutf/src/simdutf/westmere/end.h +8 -0
  312. package/deps/simdutf/src/simdutf/westmere/implementation.h +338 -0
  313. package/deps/simdutf/src/simdutf/westmere/intrinsics.h +38 -0
  314. package/deps/simdutf/src/simdutf/westmere/simd.h +379 -0
  315. package/deps/simdutf/src/simdutf/westmere/simd16-inl.h +242 -0
  316. package/deps/simdutf/src/simdutf/westmere/simd32-inl.h +151 -0
  317. package/deps/simdutf/src/simdutf/westmere/simd64-inl.h +33 -0
  318. package/deps/simdutf/src/simdutf/westmere.h +59 -0
  319. package/deps/simdutf/src/simdutf.cpp +152 -0
  320. package/deps/simdutf/src/simdutf_c.cpp +525 -0
  321. package/deps/simdutf/src/tables/utf16_to_utf8_tables.h +768 -0
  322. package/deps/simdutf/src/tables/utf32_to_utf16_tables.h +53 -0
  323. package/deps/simdutf/src/tables/utf8_to_utf16_tables.h +826 -0
  324. package/deps/simdutf/src/westmere/implementation.cpp +1479 -0
  325. package/deps/simdutf/src/westmere/internal/loader.cpp +7 -0
  326. package/deps/simdutf/src/westmere/internal/write_v_u16_11bits_to_utf8.cpp +66 -0
  327. package/deps/simdutf/src/westmere/sse_base64.cpp +672 -0
  328. package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf16.cpp +21 -0
  329. package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf32.cpp +31 -0
  330. package/deps/simdutf/src/westmere/sse_convert_latin1_to_utf8.cpp +71 -0
  331. package/deps/simdutf/src/westmere/sse_convert_utf16_to_latin1.cpp +70 -0
  332. package/deps/simdutf/src/westmere/sse_convert_utf16_to_utf32.cpp +206 -0
  333. package/deps/simdutf/src/westmere/sse_convert_utf16_to_utf8.cpp +504 -0
  334. package/deps/simdutf/src/westmere/sse_convert_utf32_to_latin1.cpp +82 -0
  335. package/deps/simdutf/src/westmere/sse_convert_utf32_to_utf16.cpp +209 -0
  336. package/deps/simdutf/src/westmere/sse_convert_utf32_to_utf8.cpp +589 -0
  337. package/deps/simdutf/src/westmere/sse_convert_utf8_to_latin1.cpp +58 -0
  338. package/deps/simdutf/src/westmere/sse_convert_utf8_to_utf16.cpp +197 -0
  339. package/deps/simdutf/src/westmere/sse_convert_utf8_to_utf32.cpp +141 -0
  340. package/deps/simdutf/src/westmere/sse_utf16fix.cpp +82 -0
  341. package/deps/simdutf/src/westmere/sse_validate_utf16.cpp +17 -0
  342. package/lib/commonjs/argon2.js +51 -2
  343. package/lib/commonjs/argon2.js.map +1 -1
  344. package/lib/commonjs/cipher.js +109 -11
  345. package/lib/commonjs/cipher.js.map +1 -1
  346. package/lib/commonjs/dsa.js +8 -2
  347. package/lib/commonjs/dsa.js.map +1 -1
  348. package/lib/commonjs/hash.js +15 -5
  349. package/lib/commonjs/hash.js.map +1 -1
  350. package/lib/commonjs/hkdf.js +33 -6
  351. package/lib/commonjs/hkdf.js.map +1 -1
  352. package/lib/commonjs/hmac.js +15 -5
  353. package/lib/commonjs/hmac.js.map +1 -1
  354. package/lib/commonjs/keys/publicCipher.js +10 -4
  355. package/lib/commonjs/keys/publicCipher.js.map +1 -1
  356. package/lib/commonjs/random.js +11 -2
  357. package/lib/commonjs/random.js.map +1 -1
  358. package/lib/commonjs/rsa.js +12 -5
  359. package/lib/commonjs/rsa.js.map +1 -1
  360. package/lib/commonjs/scrypt.js +47 -6
  361. package/lib/commonjs/scrypt.js.map +1 -1
  362. package/lib/commonjs/subtle.js +76 -5
  363. package/lib/commonjs/subtle.js.map +1 -1
  364. package/lib/commonjs/utils/cipher.js +18 -7
  365. package/lib/commonjs/utils/cipher.js.map +1 -1
  366. package/lib/commonjs/utils/conversion.js +33 -9
  367. package/lib/commonjs/utils/conversion.js.map +1 -1
  368. package/lib/commonjs/utils/timingSafeEqual.js +7 -2
  369. package/lib/commonjs/utils/timingSafeEqual.js.map +1 -1
  370. package/lib/commonjs/x509certificate.js +6 -6
  371. package/lib/commonjs/x509certificate.js.map +1 -1
  372. package/lib/module/argon2.js +51 -2
  373. package/lib/module/argon2.js.map +1 -1
  374. package/lib/module/cipher.js +109 -11
  375. package/lib/module/cipher.js.map +1 -1
  376. package/lib/module/dsa.js +8 -2
  377. package/lib/module/dsa.js.map +1 -1
  378. package/lib/module/hash.js +15 -5
  379. package/lib/module/hash.js.map +1 -1
  380. package/lib/module/hkdf.js +33 -6
  381. package/lib/module/hkdf.js.map +1 -1
  382. package/lib/module/hmac.js +15 -5
  383. package/lib/module/hmac.js.map +1 -1
  384. package/lib/module/keys/publicCipher.js +10 -4
  385. package/lib/module/keys/publicCipher.js.map +1 -1
  386. package/lib/module/random.js +11 -2
  387. package/lib/module/random.js.map +1 -1
  388. package/lib/module/rsa.js +11 -4
  389. package/lib/module/rsa.js.map +1 -1
  390. package/lib/module/scrypt.js +47 -6
  391. package/lib/module/scrypt.js.map +1 -1
  392. package/lib/module/subtle.js +76 -5
  393. package/lib/module/subtle.js.map +1 -1
  394. package/lib/module/utils/cipher.js +18 -7
  395. package/lib/module/utils/cipher.js.map +1 -1
  396. package/lib/module/utils/conversion.js +33 -9
  397. package/lib/module/utils/conversion.js.map +1 -1
  398. package/lib/module/utils/timingSafeEqual.js +8 -3
  399. package/lib/module/utils/timingSafeEqual.js.map +1 -1
  400. package/lib/module/x509certificate.js +6 -6
  401. package/lib/module/x509certificate.js.map +1 -1
  402. package/lib/typescript/argon2.d.ts.map +1 -1
  403. package/lib/typescript/cipher.d.ts +2 -2
  404. package/lib/typescript/cipher.d.ts.map +1 -1
  405. package/lib/typescript/dsa.d.ts.map +1 -1
  406. package/lib/typescript/hash.d.ts +2 -2
  407. package/lib/typescript/hash.d.ts.map +1 -1
  408. package/lib/typescript/hkdf.d.ts.map +1 -1
  409. package/lib/typescript/hmac.d.ts +2 -2
  410. package/lib/typescript/hmac.d.ts.map +1 -1
  411. package/lib/typescript/index.d.ts +1 -1
  412. package/lib/typescript/index.d.ts.map +1 -1
  413. package/lib/typescript/keys/publicCipher.d.ts.map +1 -1
  414. package/lib/typescript/random.d.ts.map +1 -1
  415. package/lib/typescript/rsa.d.ts.map +1 -1
  416. package/lib/typescript/scrypt.d.ts.map +1 -1
  417. package/lib/typescript/specs/utils.nitro.d.ts +0 -2
  418. package/lib/typescript/specs/utils.nitro.d.ts.map +1 -1
  419. package/lib/typescript/subtle.d.ts.map +1 -1
  420. package/lib/typescript/utils/cipher.d.ts +13 -1
  421. package/lib/typescript/utils/cipher.d.ts.map +1 -1
  422. package/lib/typescript/utils/conversion.d.ts +9 -6
  423. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  424. package/lib/typescript/utils/timingSafeEqual.d.ts.map +1 -1
  425. package/lib/typescript/x509certificate.d.ts.map +1 -1
  426. package/nitrogen/generated/shared/c++/HybridUtilsSpec.cpp +0 -2
  427. package/nitrogen/generated/shared/c++/HybridUtilsSpec.hpp +0 -3
  428. package/package.json +38 -6
  429. package/src/argon2.ts +80 -2
  430. package/src/cipher.ts +139 -15
  431. package/src/dsa.ts +11 -2
  432. package/src/hash.ts +17 -7
  433. package/src/hkdf.ts +44 -6
  434. package/src/hmac.ts +17 -7
  435. package/src/keys/publicCipher.ts +10 -4
  436. package/src/random.ts +11 -2
  437. package/src/rsa.ts +18 -4
  438. package/src/scrypt.ts +73 -6
  439. package/src/specs/utils.nitro.ts +0 -2
  440. package/src/subtle.ts +90 -8
  441. package/src/utils/cipher.ts +30 -8
  442. package/src/utils/conversion.ts +58 -20
  443. package/src/utils/timingSafeEqual.ts +8 -3
  444. package/src/x509certificate.ts +5 -6
  445. package/deps/blake3/.cargo/config.toml +0 -2
  446. package/deps/blake3/.git-blame-ignore-revs +0 -2
  447. package/deps/blake3/.github/workflows/build_b3sum.py +0 -38
  448. package/deps/blake3/.github/workflows/ci.yml +0 -491
  449. package/deps/blake3/.github/workflows/tag.yml +0 -43
  450. package/deps/blake3/.github/workflows/upload_github_release_asset.py +0 -73
  451. package/deps/blake3/CONTRIBUTING.md +0 -31
  452. package/deps/blake3/Cargo.toml +0 -135
  453. package/deps/blake3/b3sum/Cargo.lock +0 -513
  454. package/deps/blake3/b3sum/Cargo.toml +0 -26
  455. package/deps/blake3/b3sum/README.md +0 -72
  456. package/deps/blake3/b3sum/src/main.rs +0 -564
  457. package/deps/blake3/b3sum/src/unit_tests.rs +0 -235
  458. package/deps/blake3/b3sum/tests/cli_tests.rs +0 -680
  459. package/deps/blake3/b3sum/what_does_check_do.md +0 -176
  460. package/deps/blake3/benches/bench.rs +0 -623
  461. package/deps/blake3/build.rs +0 -389
  462. package/deps/blake3/c/CMakeLists.txt +0 -383
  463. package/deps/blake3/c/CMakePresets.json +0 -73
  464. package/deps/blake3/c/Makefile.testing +0 -82
  465. package/deps/blake3/c/blake3-config.cmake.in +0 -14
  466. package/deps/blake3/c/blake3_avx2.c +0 -326
  467. package/deps/blake3/c/blake3_avx2_x86-64_unix.S +0 -1815
  468. package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +0 -1817
  469. package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +0 -1828
  470. package/deps/blake3/c/blake3_avx512.c +0 -1388
  471. package/deps/blake3/c/blake3_avx512_x86-64_unix.S +0 -4824
  472. package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +0 -2615
  473. package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +0 -2634
  474. package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +0 -32
  475. package/deps/blake3/c/blake3_c_rust_bindings/README.md +0 -4
  476. package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +0 -477
  477. package/deps/blake3/c/blake3_c_rust_bindings/build.rs +0 -253
  478. package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +0 -31
  479. package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +0 -333
  480. package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +0 -696
  481. package/deps/blake3/c/blake3_sse2.c +0 -566
  482. package/deps/blake3/c/blake3_sse2_x86-64_unix.S +0 -2291
  483. package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +0 -2332
  484. package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +0 -2350
  485. package/deps/blake3/c/blake3_sse41.c +0 -560
  486. package/deps/blake3/c/blake3_sse41_x86-64_unix.S +0 -2028
  487. package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +0 -2069
  488. package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +0 -2089
  489. package/deps/blake3/c/blake3_tbb.cpp +0 -37
  490. package/deps/blake3/c/dependencies/CMakeLists.txt +0 -3
  491. package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +0 -28
  492. package/deps/blake3/c/example.c +0 -36
  493. package/deps/blake3/c/example_tbb.c +0 -57
  494. package/deps/blake3/c/libblake3.pc.in +0 -12
  495. package/deps/blake3/c/main.c +0 -166
  496. package/deps/blake3/c/test.py +0 -97
  497. package/deps/blake3/media/B3.svg +0 -70
  498. package/deps/blake3/media/BLAKE3.svg +0 -85
  499. package/deps/blake3/media/speed.svg +0 -1474
  500. package/deps/blake3/reference_impl/Cargo.toml +0 -8
  501. package/deps/blake3/reference_impl/README.md +0 -14
  502. package/deps/blake3/reference_impl/reference_impl.rs +0 -374
  503. package/deps/blake3/src/ffi_avx2.rs +0 -65
  504. package/deps/blake3/src/ffi_avx512.rs +0 -169
  505. package/deps/blake3/src/ffi_neon.rs +0 -82
  506. package/deps/blake3/src/ffi_sse2.rs +0 -126
  507. package/deps/blake3/src/ffi_sse41.rs +0 -126
  508. package/deps/blake3/src/guts.rs +0 -60
  509. package/deps/blake3/src/hazmat.rs +0 -704
  510. package/deps/blake3/src/io.rs +0 -64
  511. package/deps/blake3/src/join.rs +0 -92
  512. package/deps/blake3/src/lib.rs +0 -1835
  513. package/deps/blake3/src/platform.rs +0 -587
  514. package/deps/blake3/src/portable.rs +0 -198
  515. package/deps/blake3/src/rust_avx2.rs +0 -474
  516. package/deps/blake3/src/rust_sse2.rs +0 -775
  517. package/deps/blake3/src/rust_sse41.rs +0 -766
  518. package/deps/blake3/src/test.rs +0 -1049
  519. package/deps/blake3/src/traits.rs +0 -227
  520. package/deps/blake3/src/wasm32_simd.rs +0 -794
  521. package/deps/blake3/test_vectors/Cargo.toml +0 -19
  522. package/deps/blake3/test_vectors/cross_test.sh +0 -25
  523. package/deps/blake3/test_vectors/src/bin/generate.rs +0 -4
  524. package/deps/blake3/test_vectors/src/lib.rs +0 -350
  525. package/deps/blake3/test_vectors/test_vectors.json +0 -217
  526. package/deps/blake3/tools/compiler_version/Cargo.toml +0 -7
  527. package/deps/blake3/tools/compiler_version/build.rs +0 -6
  528. package/deps/blake3/tools/compiler_version/src/main.rs +0 -27
  529. package/deps/blake3/tools/instruction_set_support/Cargo.toml +0 -6
  530. package/deps/blake3/tools/instruction_set_support/src/main.rs +0 -10
  531. package/deps/blake3/tools/release.md +0 -16
  532. package/deps/ncrypto/.bazelignore +0 -4
  533. package/deps/ncrypto/.bazelrc +0 -1
  534. package/deps/ncrypto/.bazelversion +0 -1
  535. package/deps/ncrypto/.clang-format +0 -111
  536. package/deps/ncrypto/.github/workflows/bazel.yml +0 -58
  537. package/deps/ncrypto/.github/workflows/commitlint.yml +0 -16
  538. package/deps/ncrypto/.github/workflows/linter.yml +0 -38
  539. package/deps/ncrypto/.github/workflows/macos.yml +0 -43
  540. package/deps/ncrypto/.github/workflows/release-please.yml +0 -16
  541. package/deps/ncrypto/.github/workflows/ubuntu.yml +0 -128
  542. package/deps/ncrypto/.github/workflows/visual-studio.yml +0 -49
  543. package/deps/ncrypto/.python-version +0 -1
  544. package/deps/ncrypto/.release-please-manifest.json +0 -3
  545. package/deps/ncrypto/BUILD.bazel +0 -44
  546. package/deps/ncrypto/CHANGELOG.md +0 -37
  547. package/deps/ncrypto/CMakeLists.txt +0 -79
  548. package/deps/ncrypto/MODULE.bazel +0 -16
  549. package/deps/ncrypto/MODULE.bazel.lock +0 -461
  550. package/deps/ncrypto/cmake/CPM.cmake +0 -1225
  551. package/deps/ncrypto/cmake/ncrypto-flags.cmake +0 -17
  552. package/deps/ncrypto/ncrypto.pc.in +0 -10
  553. package/deps/ncrypto/patches/0001-Expose-libdecrepit-so-NodeJS-can-use-it-for-ncrypto.patch +0 -28
  554. package/deps/ncrypto/pyproject.toml +0 -38
  555. package/deps/ncrypto/release-please-config.json +0 -11
  556. package/deps/ncrypto/src/CMakeLists.txt +0 -40
  557. package/deps/ncrypto/tests/BUILD.bazel +0 -11
  558. package/deps/ncrypto/tests/CMakeLists.txt +0 -7
  559. package/deps/ncrypto/tests/basic.cpp +0 -856
  560. package/deps/ncrypto/tools/run-clang-format.sh +0 -42
  561. package/lib/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,401 @@
1
+ namespace base64tests {
2
+ const char *base64_std =
3
+ "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
4
+ const char *base64_url =
5
+ "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";
6
+ const char *accepted_whitespaces = "\x20\x09\x0a\x0c\x0d";
7
+ } // namespace base64tests
8
+
9
+ simdutf_maybe_unused static void
10
+ base64_encoding_translate_6bit_values(const simdutf::implementation &) {
11
+ using simdutf::ppc64::encoding_translate_6bit_values;
12
+ using simdutf::ppc64::vector_u8;
13
+
14
+ for (uint8_t value = 0; value < 64; value++) {
15
+ const auto in = vector_u8::splat(value);
16
+ const auto got = encoding_translate_6bit_values<false>(in);
17
+ const auto want = vector_u8::splat(base64tests::base64_std[value]);
18
+
19
+ const auto eq = (got == want);
20
+ if (not eq.all()) {
21
+ printf("value = 0x%02x (%c)\n", value, value);
22
+ printf("want = ");
23
+ want.dump();
24
+ printf("got = ");
25
+ got.dump();
26
+ abort();
27
+ }
28
+ }
29
+
30
+ for (uint8_t value = 0; value < 64; value++) {
31
+ const auto in = vector_u8::splat(value);
32
+ const auto got = encoding_translate_6bit_values<true>(in);
33
+ const auto want = vector_u8::splat(base64tests::base64_url[value]);
34
+
35
+ const auto eq = (got == want);
36
+ if (not eq.all()) {
37
+ printf("value = 0x%02x (%c)\n", value, value);
38
+ printf("want = ");
39
+ want.dump();
40
+ printf("got = ");
41
+ got.dump();
42
+ abort();
43
+ }
44
+ }
45
+ }
46
+
47
+ simdutf_maybe_unused static void
48
+ base64_encoding_expand_6bit_fields(const simdutf::implementation &) {
49
+ using simdutf::ppc64::encoding_expand_6bit_fields;
50
+ using simdutf::ppc64::vector_u8;
51
+
52
+ for (size_t position = 0; position < 5; position++) {
53
+ for (uint32_t value = 0; value < 0xffffff; value++) {
54
+ const uint8_t a = uint8_t(value >> (3 * 6)) & 0x3f;
55
+ const uint8_t b = uint8_t(value >> (2 * 6)) & 0x3f;
56
+ const uint8_t c = uint8_t(value >> (1 * 6)) & 0x3f;
57
+ const uint8_t d = uint8_t(value >> (0 * 6)) & 0x3f;
58
+
59
+ auto input = vector_u8::zero();
60
+ input.value[position * 3 + 0] = uint8_t(value >> (2 * 8));
61
+ input.value[position * 3 + 1] = uint8_t(value >> (1 * 8));
62
+ input.value[position * 3 + 2] = uint8_t(value >> (0 * 8));
63
+
64
+ const auto expanded = encoding_expand_6bit_fields(input);
65
+
66
+ // test
67
+ const size_t a_idx = position * 4 + 0;
68
+ const size_t b_idx = position * 4 + 1;
69
+ const size_t c_idx = position * 4 + 2;
70
+ const size_t d_idx = position * 4 + 3;
71
+
72
+ for (size_t i = 0; i < 5; i++) {
73
+ uint8_t want = 0;
74
+ if (i == a_idx) {
75
+ want = a;
76
+ } else if (i == b_idx) {
77
+ want = b;
78
+ } else if (i == c_idx) {
79
+ want = c;
80
+ } else if (i == d_idx) {
81
+ want = d;
82
+ }
83
+
84
+ const uint8_t got = expanded.value[i];
85
+ if (got != want) {
86
+ printf("value = 0x%02x\n", uint8_t(value));
87
+ printf("pos = %lu\n", position);
88
+ printf("want = %02x\n", want);
89
+ printf("got = %02x\n", got);
90
+ printf("expanded = ");
91
+ expanded.dump();
92
+ abort();
93
+ }
94
+ }
95
+ }
96
+ }
97
+ }
98
+
99
+ simdutf_maybe_unused static void
100
+ base64_decoding_valid(const simdutf::implementation &) {
101
+ using simdutf::ppc64::block64;
102
+ using simdutf::ppc64::vector_u8;
103
+ using simdutf::ppc64::with_base64_std;
104
+ using simdutf::ppc64::with_base64_url;
105
+ using simdutf::ppc64::with_ignore_errors;
106
+
107
+ for (uint8_t i = 0; i < 64; i++) {
108
+ auto ascii = vector_u8::splat(base64tests::base64_std[i]);
109
+ uint16_t error = 0;
110
+ const auto mask =
111
+ block64::to_base64_mask<with_base64_std, with_ignore_errors>(ascii,
112
+ error);
113
+
114
+ const auto err =
115
+ (mask != 0) || (error != 0) || (ascii != vector_u8::splat(i)).any();
116
+
117
+ if (err) {
118
+ printf("mask = %02x\n", mask);
119
+ printf("error = %02x\n", error);
120
+ printf("want = 0x%02x\n", i);
121
+ printf("got = ");
122
+ ascii.dump();
123
+ abort();
124
+ }
125
+ }
126
+
127
+ for (uint8_t i = 0; i < 64; i++) {
128
+ auto ascii = vector_u8::splat(base64tests::base64_url[i]);
129
+ uint16_t error = 0;
130
+ const auto mask =
131
+ block64::to_base64_mask<with_base64_url, with_ignore_errors>(ascii,
132
+ error);
133
+
134
+ const auto err =
135
+ (mask != 0) || (error != 0) || (ascii != vector_u8::splat(i)).any();
136
+
137
+ if (err) {
138
+ printf("mask = %02x\n", mask);
139
+ printf("error = %02x\n", error);
140
+ printf("want = 0x%02x\n", i);
141
+ printf("got = ");
142
+ ascii.dump();
143
+ abort();
144
+ }
145
+ }
146
+ }
147
+
148
+ template <bool base64_url>
149
+ static void unittest_decoding_invalid_ignore_errors(const char *base64) {
150
+ using simdutf::ppc64::block64;
151
+ using simdutf::ppc64::vector_u8;
152
+ using simdutf::ppc64::with_ignore_errors;
153
+
154
+ const char *accepted_whitespaces = " \t\n\r\v";
155
+
156
+ constexpr uint8_t invalid = 0xff;
157
+ constexpr uint8_t whitespace = 0x80;
158
+
159
+ uint8_t map[256];
160
+ for (size_t i = 0; i < 256; i++) {
161
+ map[i] = invalid;
162
+ }
163
+
164
+ for (uint8_t i = 0; i < 64; i++) {
165
+ map[uint8_t(base64[i])] = i;
166
+ }
167
+
168
+ for (size_t i = 0; i < 5; i++) {
169
+ const uint8_t idx = uint8_t(accepted_whitespaces[i]);
170
+ map[idx] = whitespace;
171
+ }
172
+
173
+ for (size_t i = 0; i < 256; i++) {
174
+ const auto b = uint8_t(i);
175
+ auto ascii = vector_u8::splat(b);
176
+ uint16_t error = 0;
177
+ const auto mask =
178
+ block64::to_base64_mask<base64_url, with_ignore_errors>(ascii, error);
179
+
180
+ if (map[i] == invalid or map[i] == whitespace) {
181
+ if (mask != 0xffff or error != 0x0000) {
182
+ printf("value = %u (0x%02x)\n", b, b);
183
+ printf("mask = %04x\n", mask);
184
+ printf("error = %04x\n", error);
185
+ ascii.dump();
186
+ printf("%s:%d\n", __FILE__, __LINE__);
187
+ exit(1);
188
+ }
189
+ } else {
190
+ if (mask != 0x0000 or error != 0x0000) {
191
+ printf("value = %u (0x%02x)\n", b, b);
192
+ printf("mask = %04x\n", mask);
193
+ printf("error = %04x\n", error);
194
+ ascii.dump();
195
+ printf("%s:%d\n", __FILE__, __LINE__);
196
+ exit(1);
197
+ }
198
+ }
199
+ }
200
+ }
201
+
202
+ template <bool base64_url>
203
+ static void unittest_decoding_invalid_strict_errors(const char *base64) {
204
+ using simdutf::ppc64::block64;
205
+ using simdutf::ppc64::vector_u8;
206
+ using simdutf::ppc64::with_strict_checking;
207
+
208
+ constexpr uint8_t invalid = 0xff;
209
+ constexpr uint8_t whitespace = 0x80;
210
+
211
+ uint8_t map[256];
212
+ for (size_t i = 0; i < 256; i++) {
213
+ map[i] = invalid;
214
+ }
215
+
216
+ for (uint8_t i = 0; i < 64; i++) {
217
+ map[uint8_t(base64[i])] = i;
218
+ }
219
+
220
+ for (size_t i = 0; i < 5; i++) {
221
+ const uint8_t idx = uint8_t(base64tests::accepted_whitespaces[i]);
222
+ map[idx] = whitespace;
223
+ }
224
+
225
+ for (size_t i = 0; i < 256; i++) {
226
+ const uint8_t b = uint8_t(i);
227
+ auto ascii = vector_u8::splat(b);
228
+ uint16_t error = 0;
229
+ const auto mask =
230
+ block64::to_base64_mask<base64_url, with_strict_checking>(ascii, error);
231
+
232
+ if (map[i] == invalid) {
233
+ if (mask != 0xffff or error != 0xffff) {
234
+ printf("value = %u (0x%02x)\n", b, b);
235
+ printf("mask = %04x\n", mask);
236
+ printf("error = %04x\n", error);
237
+ ascii.dump();
238
+ printf("%s:%d\n", __FILE__, __LINE__);
239
+ exit(1);
240
+ }
241
+ } else if (map[i] == whitespace) {
242
+ if (mask != 0xffff or error != 0x0000) {
243
+ printf("value = %lu (0x%02lx)\n", i, i);
244
+ printf("mask = %04x\n", mask);
245
+ printf("error = %04x\n", error);
246
+ ascii.dump();
247
+ printf("%s:%d\n", __FILE__, __LINE__);
248
+ exit(1);
249
+ }
250
+ } else {
251
+ if (mask != 0x0000 or error != 0x0000) {
252
+ printf("value = %lu (0x%02lx)\n", i, i);
253
+ printf("mask = %04x\n", mask);
254
+ printf("error = %04x\n", error);
255
+ ascii.dump();
256
+ printf("%s:%d\n", __FILE__, __LINE__);
257
+ exit(1);
258
+ }
259
+ }
260
+ }
261
+ }
262
+
263
+ simdutf_maybe_unused static void
264
+ base64_decoding_invalid_ignore_errors(const simdutf::implementation &) {
265
+ using simdutf::ppc64::with_base64_std;
266
+
267
+ unittest_decoding_invalid_ignore_errors<with_base64_std>(
268
+ base64tests::base64_std);
269
+ }
270
+
271
+ simdutf_maybe_unused static void
272
+ base64url_decoding_invalid_ignore_errors(const simdutf::implementation &) {
273
+ using simdutf::ppc64::with_base64_url;
274
+
275
+ unittest_decoding_invalid_ignore_errors<with_base64_url>(
276
+ base64tests::base64_url);
277
+ }
278
+
279
+ simdutf_maybe_unused static void
280
+ base64_decoding_invalid_strict_errors(const simdutf::implementation &) {
281
+ using simdutf::ppc64::with_base64_std;
282
+
283
+ unittest_decoding_invalid_strict_errors<with_base64_std>(
284
+ base64tests::base64_std);
285
+ }
286
+
287
+ simdutf_maybe_unused static void
288
+ base64url_decoding_invalid_strict_errors(const simdutf::implementation &) {
289
+ using simdutf::ppc64::with_base64_url;
290
+
291
+ unittest_decoding_invalid_strict_errors<with_base64_url>(
292
+ base64tests::base64_url);
293
+ }
294
+
295
+ simdutf_maybe_unused static void
296
+ base64_decoding_pack(const simdutf::implementation &) {
297
+ using simdutf::ppc64::decoding_pack;
298
+ using simdutf::ppc64::vector_u8;
299
+
300
+ for (size_t position = 0; position < 4; position++) {
301
+ for (uint32_t value = 0; value < 0xffffff; value++) {
302
+ const uint8_t a = uint8_t(value >> (0 * 6)) & 0x3f;
303
+ const uint8_t b = uint8_t(value >> (1 * 6)) & 0x3f;
304
+ const uint8_t c = uint8_t(value >> (2 * 6)) & 0x3f;
305
+ const uint8_t d = uint8_t(value >> (3 * 6)) & 0x3f;
306
+
307
+ auto input = vector_u8::zero();
308
+ input.value[position * 4 + 0] = a;
309
+ input.value[position * 4 + 1] = b;
310
+ input.value[position * 4 + 2] = c;
311
+ input.value[position * 4 + 3] = d;
312
+
313
+ const uint8_t b0 = uint8_t((a << 2) | (b >> 4));
314
+ const uint8_t b1 = uint8_t((b << 4) | (c >> 2));
315
+ const uint8_t b2 = uint8_t(d | (c << 6));
316
+
317
+ const auto packed = decoding_pack(input);
318
+
319
+ // test
320
+ const size_t b0_idx = position * 3 + 0;
321
+ const size_t b1_idx = position * 3 + 1;
322
+ const size_t b2_idx = position * 3 + 2;
323
+
324
+ for (size_t i = 0; i < 3; i++) {
325
+ uint8_t want = 0;
326
+ if (i == b0_idx) {
327
+ want = b0;
328
+ } else if (i == b1_idx) {
329
+ want = b1;
330
+ } else if (i == b2_idx) {
331
+ want = b2;
332
+ }
333
+
334
+ const uint8_t got = packed.value[i];
335
+ if (got != want) {
336
+ printf("pos = %lu\n", position);
337
+ printf("want = %02x\n", want);
338
+ printf("got = %02x\n", got);
339
+ printf("expanded = ");
340
+ packed.dump();
341
+ printf("file %s:%d, function %s\n", __FILE__, __LINE__, __func__);
342
+ abort();
343
+ }
344
+ }
345
+ }
346
+ }
347
+ }
348
+
349
+ simdutf_maybe_unused static int
350
+ scalar_compress(const simdutf::ppc64::vector_u8 data, uint16_t nmask,
351
+ char *output) {
352
+ char tmp[16];
353
+ data.store(tmp);
354
+
355
+ int j = 0;
356
+ for (int i = 0; i < 16; i++) {
357
+ if ((nmask & 0x1) == 0) {
358
+ output[j++] = tmp[i];
359
+ }
360
+
361
+ nmask >>= 1;
362
+ }
363
+
364
+ return j;
365
+ }
366
+
367
+ simdutf_maybe_unused static void
368
+ base64_compress(const simdutf::implementation &) {
369
+ using simdutf::ppc64::compress;
370
+ using simdutf::ppc64::vector_u8;
371
+
372
+ char want[16];
373
+ char got[16];
374
+
375
+ const auto data = vector_u8('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
376
+ 'K', 'L', 'M', 'N', 'O', 'P');
377
+ for (uint32_t mask = 0; mask <= 0xffff; mask++) {
378
+ memset(want, 0, 16);
379
+ memset(got, 0, 16);
380
+ const uint16_t nmask = uint16_t(~mask);
381
+
382
+ const int count = scalar_compress(data, nmask, want);
383
+ compress(data, nmask, got);
384
+
385
+ if (memcmp(want, got, count) != 0) {
386
+ printf("want = ");
387
+ for (int i = 0; i < count; i++) {
388
+ putchar(want[i]);
389
+ }
390
+ putchar('\n');
391
+
392
+ printf("got = ");
393
+ for (int i = 0; i < count; i++) {
394
+ putchar(got[i]);
395
+ }
396
+ putchar('\n');
397
+
398
+ exit(1);
399
+ }
400
+ }
401
+ }
@@ -0,0 +1,12 @@
1
+ template <endianness big_endian>
2
+ size_t ppc64_convert_latin1_to_utf16(const char *latin1_input, size_t len,
3
+ char16_t *utf16_output) {
4
+ const size_t rounded_len = align_down<vector_u8::ELEMENTS>(len);
5
+
6
+ for (size_t i = 0; i < rounded_len; i += vector_u8::ELEMENTS) {
7
+ const auto in = vector_u8::load(&latin1_input[i]);
8
+ in.store_bytes_as_utf16<big_endian>(&utf16_output[i]);
9
+ }
10
+
11
+ return rounded_len;
12
+ }
@@ -0,0 +1,12 @@
1
+ std::pair<const char *, char32_t *>
2
+ ppc64_convert_latin1_to_utf32(const char *buf, size_t len,
3
+ char32_t *utf32_output) {
4
+ const size_t rounded_len = align_down<vector_u8::ELEMENTS>(len);
5
+
6
+ for (size_t i = 0; i < rounded_len; i += vector_u8::ELEMENTS) {
7
+ const auto in = vector_u8::load(&buf[i]);
8
+ in.store_bytes_as_utf32(&utf32_output[i]);
9
+ }
10
+
11
+ return std::make_pair(buf + rounded_len, utf32_output + rounded_len);
12
+ }
@@ -0,0 +1,149 @@
1
+ /*
2
+ * reads a vector of uint16 values
3
+ * bits after 11th are ignored
4
+ * first 11 bits are encoded into utf8
5
+ * !important! utf8_output must have at least 16 writable bytes
6
+ */
7
+ simdutf_really_inline void
8
+ write_v_u16_11bits_to_utf8(const vector_u16 v_u16, char *&utf8_output,
9
+ const vector_u8 one_byte_bytemask,
10
+ const uint16_t one_byte_bitmask) {
11
+
12
+ // 0b1100_0000_1000_0000
13
+ const auto v_c080 = vector_u16(0xc080);
14
+ // 0b0011_1111_0000_0000
15
+ const auto v_1f00 = vector_u16(0x1f00);
16
+ // 0b0000_0000_0011_1111
17
+ const auto v_003f = vector_u16(0x003f);
18
+
19
+ // 1. prepare 2-byte values
20
+ // input 16-bit word : [0000|0aaa|aabb|bbbb] x 8
21
+ // expected output : [110a|aaaa|10bb|bbbb] x 8
22
+
23
+ // t0 = [0000|0000|00bb|bbbb]
24
+ const auto t0 = v_u16 & v_003f;
25
+ // t1 = [000a|aaaa|bbbb|bb00]
26
+ const auto t1 = v_u16.shl<2>();
27
+ // t2 = [000a|aaaa|00bb|bbbb]
28
+ const auto t2 = select(v_1f00, t1, t0);
29
+ // t3 = [110a|aaaa|10bb|bbbb]
30
+ const auto t3 = t2 | v_c080;
31
+
32
+ // 2. merge ASCII and 2-byte codewords
33
+ const auto utf8_unpacked1 =
34
+ select(one_byte_bytemask, as_vector_u8(v_u16), as_vector_u8(t3));
35
+
36
+ #if SIMDUTF_IS_BIG_ENDIAN
37
+ const auto tmp = as_vector_u16(utf8_unpacked1).swap_bytes();
38
+ #else
39
+ const auto tmp = as_vector_u16(utf8_unpacked1);
40
+ #endif // SIMDUTF_IS_BIG_ENDIAN
41
+ const auto utf8_unpacked = as_vector_u8(tmp);
42
+
43
+ // 3. prepare bitmask for 8-bit lookup
44
+ // one_byte_bitmask = hhggffeeddccbbaa -- the bits are doubled (h - MSB, a
45
+ // - LSB)
46
+ const uint16_t m0 = one_byte_bitmask & 0x5555; // m0 = 0h0g0f0e0d0c0b0a
47
+ const uint16_t m1 = static_cast<uint16_t>(m0 >> 7); // m1 = 00000000h0g0f0e0
48
+ const uint8_t m2 = static_cast<uint8_t>((m0 | m1) & 0xff); // m2 = hdgcfbea
49
+ // 4. pack the bytes
50
+ const uint8_t *row =
51
+ &simdutf::tables::utf16_to_utf8::pack_1_2_utf8_bytes[m2][0];
52
+ const auto shuffle = vector_u8::load(row + 1);
53
+ const auto utf8_packed = shuffle.lookup_16(utf8_unpacked);
54
+
55
+ // 5. store bytes
56
+ utf8_packed.store(utf8_output);
57
+
58
+ // 6. adjust pointers
59
+ utf8_output += row[0];
60
+ }
61
+
62
+ inline void write_v_u16_11bits_to_utf8(const vector_u16 v_u16,
63
+ char *&utf8_output,
64
+ const vector_u16 v_0000,
65
+ const vector_u16 v_ff80) {
66
+ // no bits set above 7th bit
67
+ const auto one_byte_bytemask = (v_u16 & v_ff80) == v_0000;
68
+ const uint16_t one_byte_bitmask = one_byte_bytemask.to_bitmask();
69
+
70
+ write_v_u16_11bits_to_utf8(v_u16, utf8_output,
71
+ as_vector_u8(one_byte_bytemask), one_byte_bitmask);
72
+ }
73
+
74
+ std::pair<const char *const, char *const>
75
+ ppc64_convert_latin1_to_utf8(const char *latin_input,
76
+ const size_t latin_input_length,
77
+ char *utf8_output) {
78
+ const char *end = latin_input + latin_input_length;
79
+
80
+ const auto v_0000 = vector_u16::zero();
81
+ const auto v_00 = vector_u8::zero();
82
+
83
+ // 0b1111_1111_1000_0000
84
+ const auto v_ff80 = vector_u16(0xff80);
85
+
86
+ #if SIMDUTF_IS_BIG_ENDIAN
87
+ const auto latin_1_half_into_u16_byte_mask =
88
+ vector_u8(16, 0, 16, 1, 16, 2, 16, 3, 16, 4, 16, 5, 16, 6, 16, 7);
89
+ const auto latin_2_half_into_u16_byte_mask =
90
+ vector_u8(16, 8, 16, 9, 16, 10, 16, 11, 16, 12, 16, 13, 16, 14, 16, 15);
91
+ #else
92
+ const auto latin_1_half_into_u16_byte_mask =
93
+ vector_u8(0, 16, 1, 16, 2, 16, 3, 16, 4, 16, 5, 16, 6, 16, 7, 16);
94
+ const auto latin_2_half_into_u16_byte_mask =
95
+ vector_u8(8, 16, 9, 16, 10, 16, 11, 16, 12, 16, 13, 16, 14, 16, 15, 16);
96
+ #endif // SIMDUTF_IS_BIG_ENDIAN
97
+
98
+ // each latin1 takes 1-2 utf8 bytes
99
+ // slow path writes useful 8-15 bytes twice (eagerly writes 16 bytes and then
100
+ // adjust the pointer) so the last write can exceed the utf8_output size by
101
+ // 8-1 bytes by reserving 8 extra input bytes, we expect the output to have
102
+ // 8-16 bytes free
103
+ while (end - latin_input >= 16 + 8) {
104
+ // Load 16 Latin1 characters (16 bytes) into a 128-bit register
105
+ const auto v_latin = vector_u8::load(latin_input);
106
+
107
+ if (v_latin.is_ascii()) { // ASCII fast path!!!!
108
+ v_latin.store(utf8_output);
109
+ latin_input += 16;
110
+ utf8_output += 16;
111
+ continue;
112
+ }
113
+
114
+ // assuming a/b are bytes and A/B are uint16 of the same value
115
+ // aaaa_aaaa_bbbb_bbbb -> AAAA_AAAA
116
+ const vector_u16 v_u16_latin_1_half =
117
+ as_vector_u16(latin_1_half_into_u16_byte_mask.lookup_32(v_latin, v_00));
118
+
119
+ // aaaa_aaaa_bbbb_bbbb -> BBBB_BBBB
120
+ const vector_u16 v_u16_latin_2_half =
121
+ as_vector_u16(latin_2_half_into_u16_byte_mask.lookup_32(v_latin, v_00));
122
+
123
+ write_v_u16_11bits_to_utf8(v_u16_latin_1_half, utf8_output, v_0000, v_ff80);
124
+ write_v_u16_11bits_to_utf8(v_u16_latin_2_half, utf8_output, v_0000, v_ff80);
125
+ latin_input += 16;
126
+ }
127
+
128
+ if (end - latin_input >= 16) {
129
+ // Load 16 Latin1 characters (16 bytes) into a 128-bit register
130
+ const auto v_latin = vector_u8::load(latin_input);
131
+
132
+ if (v_latin.is_ascii()) { // ASCII fast path!!!!
133
+ v_latin.store(utf8_output);
134
+ latin_input += 16;
135
+ utf8_output += 16;
136
+ } else {
137
+ // assuming a/b are bytes and A/B are uint16 of the same value
138
+ // aaaa_aaaa_bbbb_bbbb -> AAAA_AAAA
139
+ const auto v_u16_latin_1_half = as_vector_u16(
140
+ latin_1_half_into_u16_byte_mask.lookup_32(v_latin, v_00));
141
+
142
+ write_v_u16_11bits_to_utf8(v_u16_latin_1_half, utf8_output, v_0000,
143
+ v_ff80);
144
+ latin_input += 8;
145
+ }
146
+ }
147
+
148
+ return std::make_pair(latin_input, utf8_output);
149
+ }
@@ -0,0 +1,67 @@
1
+ struct utf16_to_latin1_t {
2
+ error_code err;
3
+ const char16_t *input;
4
+ char *output;
5
+ };
6
+
7
+ template <endianness big_endian>
8
+ utf16_to_latin1_t ppc64_convert_utf16_to_latin1(const char16_t *buf, size_t len,
9
+ char *latin1_output) {
10
+ const char16_t *end = buf + len;
11
+ while (end - buf >= 8) {
12
+ // Load 8 x UTF-16 characters
13
+ auto in = vector_u8::load(buf);
14
+
15
+ // Move low bytes of UTF-16 chars to lower half of `in`
16
+ // and upper bytes to upper half of `in`.
17
+ if simdutf_constexpr (!match_system(big_endian)) {
18
+ const auto perm =
19
+ vector_u8(0, 2, 4, 6, 8, 10, 12, 14, 1, 3, 5, 7, 9, 11, 13, 15);
20
+ in = perm.lookup_16(in);
21
+ } else {
22
+ const auto perm =
23
+ vector_u8(1, 3, 5, 7, 9, 11, 13, 15, 0, 2, 4, 6, 8, 10, 12, 14);
24
+ in = perm.lookup_16(in);
25
+ }
26
+
27
+ // AltiVec-specific
28
+ #if defined(__clang__)
29
+ __attribute__((aligned(16))) uint64_t tmp[8];
30
+ in.store(tmp);
31
+ #if SIMDUTF_IS_BIG_ENDIAN
32
+ memcpy(latin1_output, &tmp[0], 8);
33
+ const uint64_t upper = tmp[1];
34
+ #else
35
+ memcpy(latin1_output, &tmp[1], 8);
36
+ const uint64_t upper = tmp[0];
37
+ #endif // SIMDUTF_IS_BIG_ENDIAN
38
+ #else
39
+ const auto tmp = vec_u64_t(in.value);
40
+ #if SIMDUTF_IS_BIG_ENDIAN
41
+ memcpy(latin1_output, &tmp[0], 8);
42
+ const uint64_t upper = tmp[1];
43
+ #else
44
+ memcpy(latin1_output, &tmp[1], 8);
45
+ const uint64_t upper = tmp[0];
46
+ #endif // SIMDUTF_IS_BIG_ENDIAN
47
+ #endif // defined(__clang__)
48
+ // AltiVec
49
+
50
+ if (simdutf_unlikely(upper)) {
51
+ uint8_t bytes[8];
52
+ memcpy(bytes, &upper, 8);
53
+ for (size_t k = 0; k < 8; k++) {
54
+ if (bytes[k] != 0) {
55
+ return utf16_to_latin1_t{error_code::TOO_LARGE, buf + k,
56
+ latin1_output};
57
+ }
58
+ }
59
+ } else {
60
+ // Adjust pointers for next iteration
61
+ buf += 8;
62
+ latin1_output += 8;
63
+ }
64
+ } // while
65
+
66
+ return utf16_to_latin1_t{error_code::SUCCESS, buf, latin1_output};
67
+ }