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,399 @@
1
+ #if SIMDUTF_FEATURE_UTF16
2
+ template <simdutf_ByteFlip bflip>
3
+ simdutf_really_inline static result
4
+ rvv_utf16_to_latin1_with_errors(const char16_t *src, size_t len, char *dst) {
5
+ const char16_t *const beg = src;
6
+ for (size_t vl; len > 0; len -= vl, src += vl, dst += vl) {
7
+ vl = __riscv_vsetvl_e16m8(len);
8
+ vuint16m8_t v = __riscv_vle16_v_u16m8((uint16_t *)src, vl);
9
+ v = simdutf_byteflip<bflip>(v, vl);
10
+ long idx = __riscv_vfirst_m_b2(__riscv_vmsgtu_vx_u16m8_b2(v, 255, vl), vl);
11
+ if (idx >= 0)
12
+ return result(error_code::TOO_LARGE, src - beg + idx);
13
+ __riscv_vse8_v_u8m4((uint8_t *)dst, __riscv_vncvt_x_x_w_u8m4(v, vl), vl);
14
+ }
15
+ return result(error_code::SUCCESS, src - beg);
16
+ }
17
+ #endif // SIMDUTF_FEATURE_UTF16
18
+
19
+ #if SIMDUTF_FEATURE_UTF16 && SIMDUTF_FEATURE_LATIN1
20
+ simdutf_warn_unused size_t implementation::convert_utf16le_to_latin1(
21
+ const char16_t *src, size_t len, char *dst) const noexcept {
22
+ result res = convert_utf16le_to_latin1_with_errors(src, len, dst);
23
+ return res.error == error_code::SUCCESS ? res.count : 0;
24
+ }
25
+
26
+ simdutf_warn_unused size_t implementation::convert_utf16be_to_latin1(
27
+ const char16_t *src, size_t len, char *dst) const noexcept {
28
+ result res = convert_utf16be_to_latin1_with_errors(src, len, dst);
29
+ return res.error == error_code::SUCCESS ? res.count : 0;
30
+ }
31
+
32
+ simdutf_warn_unused result
33
+ implementation::convert_utf16le_to_latin1_with_errors(
34
+ const char16_t *src, size_t len, char *dst) const noexcept {
35
+ return rvv_utf16_to_latin1_with_errors<simdutf_ByteFlip::NONE>(src, len, dst);
36
+ }
37
+
38
+ simdutf_warn_unused result
39
+ implementation::convert_utf16be_to_latin1_with_errors(
40
+ const char16_t *src, size_t len, char *dst) const noexcept {
41
+ if (supports_zvbb())
42
+ return rvv_utf16_to_latin1_with_errors<simdutf_ByteFlip::ZVBB>(src, len,
43
+ dst);
44
+ else
45
+ return rvv_utf16_to_latin1_with_errors<simdutf_ByteFlip::V>(src, len, dst);
46
+ }
47
+
48
+ simdutf_warn_unused size_t implementation::convert_valid_utf16le_to_latin1(
49
+ const char16_t *src, size_t len, char *dst) const noexcept {
50
+ const char16_t *const beg = src;
51
+ for (size_t vl; len > 0; len -= vl, src += vl, dst += vl) {
52
+ vl = __riscv_vsetvl_e16m8(len);
53
+ vuint16m8_t v = __riscv_vle16_v_u16m8((uint16_t *)src, vl);
54
+ __riscv_vse8_v_u8m4((uint8_t *)dst, __riscv_vncvt_x_x_w_u8m4(v, vl), vl);
55
+ }
56
+ return src - beg;
57
+ }
58
+
59
+ simdutf_warn_unused size_t implementation::convert_valid_utf16be_to_latin1(
60
+ const char16_t *src, size_t len, char *dst) const noexcept {
61
+ const char16_t *const beg = src;
62
+ for (size_t vl; len > 0; len -= vl, src += vl, dst += vl) {
63
+ vl = __riscv_vsetvl_e16m8(len);
64
+ vuint16m8_t v = __riscv_vle16_v_u16m8((uint16_t *)src, vl);
65
+ __riscv_vse8_v_u8m4((uint8_t *)dst, __riscv_vnsrl_wx_u8m4(v, 8, vl), vl);
66
+ }
67
+ return src - beg;
68
+ }
69
+ #endif // SIMDUTF_FEATURE_UTF16 && SIMDUTF_FEATURE_LATIN1
70
+
71
+ #if SIMDUTF_FEATURE_UTF8 && SIMDUTF_FEATURE_UTF16
72
+ template <simdutf_ByteFlip bflip>
73
+ simdutf_really_inline static result
74
+ rvv_utf16_to_utf8_with_errors(const char16_t *src, size_t len, char *dst) {
75
+ size_t n = len;
76
+ const char16_t *srcBeg = src;
77
+ const char *dstBeg = dst;
78
+ size_t vl8m4 = __riscv_vsetvlmax_e8m4();
79
+ vbool2_t m4mulp2 = __riscv_vmseq_vx_u8m4_b2(
80
+ __riscv_vand_vx_u8m4(__riscv_vid_v_u8m4(vl8m4), 3, vl8m4), 2, vl8m4);
81
+
82
+ for (size_t vl, vlOut; n > 0;) {
83
+ vl = __riscv_vsetvl_e16m2(n);
84
+
85
+ vuint16m2_t v = __riscv_vle16_v_u16m2((uint16_t const *)src, vl);
86
+ v = simdutf_byteflip<bflip>(v, vl);
87
+ vbool8_t m234 = __riscv_vmsgtu_vx_u16m2_b8(v, 0x80 - 1, vl);
88
+
89
+ if (__riscv_vfirst_m_b8(m234, vl) < 0) { /* 1 byte utf8 */
90
+ vlOut = vl;
91
+ __riscv_vse8_v_u8m1((uint8_t *)dst, __riscv_vncvt_x_x_w_u8m1(v, vlOut),
92
+ vlOut);
93
+ n -= vl, src += vl, dst += vlOut;
94
+ continue;
95
+ }
96
+
97
+ vbool8_t m34 = __riscv_vmsgtu_vx_u16m2_b8(v, 0x800 - 1, vl);
98
+
99
+ if (__riscv_vfirst_m_b8(m34, vl) < 0) { /* 1/2 byte utf8 */
100
+ /* 0: [ aaa|aabbbbbb]
101
+ * 1: [aabbbbbb| ] vsll 8
102
+ * 2: [ | aaaaa] vsrl 6
103
+ * 3: [00111111|00011111]
104
+ * 4: [ bbbbbb|000aaaaa] (1|2)&3
105
+ * 5: [11000000|11000000]
106
+ * 6: [10bbbbbb|110aaaaa] 4|5 */
107
+ vuint16m2_t twoByte = __riscv_vand_vx_u16m2(
108
+ __riscv_vor_vv_u16m2(__riscv_vsll_vx_u16m2(v, 8, vl),
109
+ __riscv_vsrl_vx_u16m2(v, 6, vl), vl),
110
+ 0b0011111100011111, vl);
111
+ vuint16m2_t vout16 =
112
+ __riscv_vor_vx_u16m2_mu(m234, v, twoByte, 0b1000000011000000, vl);
113
+ vuint8m2_t vout = __riscv_vreinterpret_v_u16m2_u8m2(vout16);
114
+
115
+ /* Every high byte that is zero should be compressed
116
+ * low bytes should never be compressed, so we set them
117
+ * to all ones, and then create a non-zero bytes mask */
118
+ vbool4_t mcomp =
119
+ __riscv_vmsne_vx_u8m2_b4(__riscv_vreinterpret_v_u16m2_u8m2(
120
+ __riscv_vor_vx_u16m2(vout16, 0xFF, vl)),
121
+ 0, vl * 2);
122
+ vlOut = __riscv_vcpop_m_b4(mcomp, vl * 2);
123
+
124
+ vout = __riscv_vcompress_vm_u8m2(vout, mcomp, vl * 2);
125
+ __riscv_vse8_v_u8m2((uint8_t *)dst, vout, vlOut);
126
+
127
+ n -= vl, src += vl, dst += vlOut;
128
+ continue;
129
+ }
130
+
131
+ vbool8_t sur = __riscv_vmseq_vx_u16m2_b8(
132
+ __riscv_vand_vx_u16m2(v, 0xF800, vl), 0xD800, vl);
133
+ long first = __riscv_vfirst_m_b8(sur, vl);
134
+ size_t tail = vl - first;
135
+ vl = first < 0 ? vl : first;
136
+
137
+ if (vl > 0) { /* 1/2/3 byte utf8 */
138
+ /* in: [aaaabbbb|bbcccccc]
139
+ * v1: [0bcccccc| ] vsll 8
140
+ * v1: [10cccccc| ] vsll 8 & 0b00111111 | 0b10000000
141
+ * v2: [ |110bbbbb] vsrl 6 & 0b00111111 | 0b11000000
142
+ * v2: [ |10bbbbbb] vsrl 6 & 0b00111111 | 0b10000000
143
+ * v3: [ |1110aaaa] vsrl 12 | 0b11100000
144
+ * 1: [00000000|0bcccccc|00000000|00000000] => [0bcccccc]
145
+ * 2: [00000000|10cccccc|110bbbbb|00000000] => [110bbbbb] [10cccccc]
146
+ * 3: [00000000|10cccccc|10bbbbbb|1110aaaa] => [1110aaaa] [10bbbbbb]
147
+ * [10cccccc]
148
+ */
149
+ vuint16m2_t v1, v2, v3, v12;
150
+ v1 = __riscv_vor_vx_u16m2_mu(
151
+ m234, v, __riscv_vand_vx_u16m2(v, 0b00111111, vl), 0b10000000, vl);
152
+ v1 = __riscv_vsll_vx_u16m2(v1, 8, vl);
153
+
154
+ v2 = __riscv_vor_vx_u16m2(
155
+ __riscv_vand_vx_u16m2(__riscv_vsrl_vx_u16m2(v, 6, vl), 0b00111111,
156
+ vl),
157
+ 0b10000000, vl);
158
+ v2 = __riscv_vor_vx_u16m2_mu(__riscv_vmnot_m_b8(m34, vl), v2, v2,
159
+ 0b01000000, vl);
160
+ v3 = __riscv_vor_vx_u16m2(__riscv_vsrl_vx_u16m2(v, 12, vl), 0b11100000,
161
+ vl);
162
+ v12 = __riscv_vor_vv_u16m2_mu(m234, v1, v1, v2, vl);
163
+
164
+ vuint32m4_t w12 = __riscv_vwmulu_vx_u32m4(v12, 1 << 8, vl);
165
+ vuint32m4_t w123 = __riscv_vwaddu_wv_u32m4_mu(m34, w12, w12, v3, vl);
166
+ vuint8m4_t vout = __riscv_vreinterpret_v_u32m4_u8m4(w123);
167
+
168
+ vbool2_t mcomp = __riscv_vmor_mm_b2(
169
+ m4mulp2, __riscv_vmsne_vx_u8m4_b2(vout, 0, vl * 4), vl * 4);
170
+ vlOut = __riscv_vcpop_m_b2(mcomp, vl * 4);
171
+
172
+ vout = __riscv_vcompress_vm_u8m4(vout, mcomp, vl * 4);
173
+ __riscv_vse8_v_u8m4((uint8_t *)dst, vout, vlOut);
174
+
175
+ n -= vl, src += vl, dst += vlOut;
176
+ }
177
+
178
+ if (tail)
179
+ while (n) {
180
+ uint16_t word = simdutf_byteflip<bflip>(src[0]);
181
+ if ((word & 0xFF80) == 0) {
182
+ break;
183
+ } else if ((word & 0xF800) == 0) {
184
+ break;
185
+ } else if ((word & 0xF800) != 0xD800) {
186
+ break;
187
+ } else {
188
+ // must be a surrogate pair
189
+ if (n <= 1)
190
+ return result(error_code::SURROGATE, src - srcBeg);
191
+ uint16_t diff = word - 0xD800;
192
+ if (diff > 0x3FF)
193
+ return result(error_code::SURROGATE, src - srcBeg);
194
+ uint16_t diff2 = simdutf_byteflip<bflip>(src[1]) - 0xDC00;
195
+ if (diff2 > 0x3FF)
196
+ return result(error_code::SURROGATE, src - srcBeg);
197
+
198
+ uint32_t value = ((diff + 0x40) << 10) + diff2;
199
+
200
+ // will generate four UTF-8 bytes
201
+ // we have 0b11110XXX 0b10XXXXXX 0b10XXXXXX 0b10XXXXXX
202
+ *dst++ = (char)((value >> 18) | 0b11110000);
203
+ *dst++ = (char)(((value >> 12) & 0b111111) | 0b10000000);
204
+ *dst++ = (char)(((value >> 6) & 0b111111) | 0b10000000);
205
+ *dst++ = (char)((value & 0b111111) | 0b10000000);
206
+ src += 2;
207
+ n -= 2;
208
+ }
209
+ }
210
+ }
211
+
212
+ return result(error_code::SUCCESS, dst - dstBeg);
213
+ }
214
+
215
+ simdutf_warn_unused size_t implementation::convert_utf16le_to_utf8(
216
+ const char16_t *src, size_t len, char *dst) const noexcept {
217
+ result res = convert_utf16le_to_utf8_with_errors(src, len, dst);
218
+ return res.error == error_code::SUCCESS ? res.count : 0;
219
+ }
220
+
221
+ simdutf_warn_unused size_t implementation::convert_utf16be_to_utf8(
222
+ const char16_t *src, size_t len, char *dst) const noexcept {
223
+ result res = convert_utf16be_to_utf8_with_errors(src, len, dst);
224
+ return res.error == error_code::SUCCESS ? res.count : 0;
225
+ }
226
+
227
+ simdutf_warn_unused result implementation::convert_utf16le_to_utf8_with_errors(
228
+ const char16_t *src, size_t len, char *dst) const noexcept {
229
+ return rvv_utf16_to_utf8_with_errors<simdutf_ByteFlip::NONE>(src, len, dst);
230
+ }
231
+
232
+ simdutf_warn_unused result implementation::convert_utf16be_to_utf8_with_errors(
233
+ const char16_t *src, size_t len, char *dst) const noexcept {
234
+ if (supports_zvbb())
235
+ return rvv_utf16_to_utf8_with_errors<simdutf_ByteFlip::ZVBB>(src, len, dst);
236
+ else
237
+ return rvv_utf16_to_utf8_with_errors<simdutf_ByteFlip::V>(src, len, dst);
238
+ }
239
+
240
+ simdutf_warn_unused size_t implementation::convert_valid_utf16le_to_utf8(
241
+ const char16_t *src, size_t len, char *dst) const noexcept {
242
+ return convert_utf16le_to_utf8(src, len, dst);
243
+ }
244
+
245
+ simdutf_warn_unused size_t implementation::convert_valid_utf16be_to_utf8(
246
+ const char16_t *src, size_t len, char *dst) const noexcept {
247
+ return convert_utf16be_to_utf8(src, len, dst);
248
+ }
249
+ #endif // SIMDUTF_FEATURE_UTF8 && SIMDUTF_FEATURE_UTF16
250
+
251
+ #if SIMDUTF_FEATURE_UTF16 && SIMDUTF_FEATURE_UTF32
252
+ template <simdutf_ByteFlip bflip>
253
+ simdutf_really_inline static result
254
+ rvv_utf16_to_utf32_with_errors(const char16_t *src, size_t len, char32_t *dst) {
255
+ const char16_t *const srcBeg = src;
256
+ char32_t *const dstBeg = dst;
257
+
258
+ constexpr const uint16_t ANY_SURROGATE_MASK = 0xf800;
259
+ constexpr const uint16_t ANY_SURROGATE_VALUE = 0xd800;
260
+ constexpr const uint16_t LO_SURROGATE_MASK = 0xfc00;
261
+ constexpr const uint16_t LO_SURROGATE_VALUE = 0xdc00;
262
+ constexpr const uint16_t HI_SURROGATE_MASK = 0xfc00;
263
+ constexpr const uint16_t HI_SURROGATE_VALUE = 0xd800;
264
+
265
+ uint16_t last = 0;
266
+ while (len > 0) {
267
+ size_t vl = __riscv_vsetvl_e16m2(len);
268
+ vuint16m2_t v0 = __riscv_vle16_v_u16m2((uint16_t const *)src, vl);
269
+ v0 = simdutf_byteflip<bflip>(v0, vl);
270
+
271
+ { // check fast-path
272
+ const vuint16m2_t v = __riscv_vand_vx_u16m2(v0, ANY_SURROGATE_MASK, vl);
273
+ const vbool8_t any_surrogate =
274
+ __riscv_vmseq_vx_u16m2_b8(v, ANY_SURROGATE_VALUE, vl);
275
+ if (__riscv_vfirst_m_b8(any_surrogate, vl) < 0) {
276
+ /* no surrogates */
277
+ __riscv_vse32_v_u32m4((uint32_t *)dst, __riscv_vzext_vf2_u32m4(v0, vl),
278
+ vl);
279
+ len -= vl;
280
+ src += vl;
281
+ dst += vl;
282
+ continue;
283
+ }
284
+ }
285
+
286
+ if ((simdutf_byteflip<bflip>(src[0]) & LO_SURROGATE_MASK) ==
287
+ LO_SURROGATE_VALUE) {
288
+ return result(error_code::SURROGATE, src - srcBeg);
289
+ }
290
+
291
+ // decode surrogates
292
+ vuint16m2_t v1 = __riscv_vslide1down_vx_u16m2(v0, 0, vl);
293
+ vl = __riscv_vsetvl_e16m2(vl - 1);
294
+ if (vl == 0) {
295
+ return result(error_code::SURROGATE, src - srcBeg);
296
+ }
297
+
298
+ const vbool8_t surhi = __riscv_vmseq_vx_u16m2_b8(
299
+ __riscv_vand_vx_u16m2(v0, HI_SURROGATE_MASK, vl), HI_SURROGATE_VALUE,
300
+ vl);
301
+ const vbool8_t surlo = __riscv_vmseq_vx_u16m2_b8(
302
+ __riscv_vand_vx_u16m2(v1, LO_SURROGATE_MASK, vl), LO_SURROGATE_VALUE,
303
+ vl);
304
+
305
+ // compress everything but lo surrogates
306
+ const vbool8_t compress = __riscv_vmsne_vx_u16m2_b8(
307
+ __riscv_vand_vx_u16m2(v0, LO_SURROGATE_MASK, vl), LO_SURROGATE_VALUE,
308
+ vl);
309
+
310
+ {
311
+ const vbool8_t diff = __riscv_vmxor_mm_b8(surhi, surlo, vl);
312
+ const long idx = __riscv_vfirst_m_b8(diff, vl);
313
+ if (idx >= 0) {
314
+ uint16_t word = simdutf_byteflip<bflip>(src[idx]);
315
+ if (word < 0xD800 || word > 0xDBFF) {
316
+ return result(error_code::SURROGATE, src - srcBeg + idx + 1);
317
+ }
318
+ return result(error_code::SURROGATE, src - srcBeg + idx);
319
+ }
320
+ }
321
+
322
+ last = simdutf_byteflip<bflip>(src[vl]);
323
+ vuint32m4_t utf32 = __riscv_vzext_vf2_u32m4(v0, vl);
324
+
325
+ // v0 = 110110yyyyyyyyyy (0xd800 + yyyyyyyyyy) --- hi surrogate
326
+ // v1 = 110111xxxxxxxxxx (0xdc00 + xxxxxxxxxx) --- lo surrogate
327
+
328
+ // t0 = u16( 0000_00yy_yyyy_yyyy)
329
+ const vuint32m4_t t0 =
330
+ __riscv_vzext_vf2_u32m4(__riscv_vand_vx_u16m2(v0, 0x03ff, vl), vl);
331
+ // t1 = u32(0000_0000_0000_yyyy_yyyy_yy00_0000_0000)
332
+ const vuint32m4_t t1 = __riscv_vsll_vx_u32m4(t0, 10, vl);
333
+
334
+ // t2 = u32(0000_0000_0000_0000_0000_00xx_xxxx_xxxx)
335
+ const vuint32m4_t t2 =
336
+ __riscv_vzext_vf2_u32m4(__riscv_vand_vx_u16m2(v1, 0x03ff, vl), vl);
337
+
338
+ // t3 = u32(0000_0000_0000_yyyy_yyyy_yyxx_xxxx_xxxx)
339
+ const vuint32m4_t t3 = __riscv_vor_vv_u32m4(t1, t2, vl);
340
+
341
+ // t4 = utf32 from surrogate pairs
342
+ const vuint32m4_t t4 = __riscv_vadd_vx_u32m4(t3, 0x10000, vl);
343
+
344
+ const vuint32m4_t result = __riscv_vmerge_vvm_u32m4(utf32, t4, surhi, vl);
345
+
346
+ const vuint32m4_t comp = __riscv_vcompress_vm_u32m4(result, compress, vl);
347
+ const size_t vlOut = __riscv_vcpop_m_b8(compress, vl);
348
+ __riscv_vse32_v_u32m4((uint32_t *)dst, comp, vlOut);
349
+
350
+ len -= vl;
351
+ src += vl;
352
+ dst += vlOut;
353
+
354
+ if ((last & LO_SURROGATE_MASK) == LO_SURROGATE_VALUE) {
355
+ // last item is lo surrogate and got already consumed
356
+ len -= 1;
357
+ src += 1;
358
+ }
359
+ }
360
+
361
+ return result(error_code::SUCCESS, dst - dstBeg);
362
+ }
363
+
364
+ simdutf_warn_unused size_t implementation::convert_utf16le_to_utf32(
365
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
366
+ result res = convert_utf16le_to_utf32_with_errors(src, len, dst);
367
+ return res.error == error_code::SUCCESS ? res.count : 0;
368
+ }
369
+
370
+ simdutf_warn_unused size_t implementation::convert_utf16be_to_utf32(
371
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
372
+ result res = convert_utf16be_to_utf32_with_errors(src, len, dst);
373
+ return res.error == error_code::SUCCESS ? res.count : 0;
374
+ }
375
+
376
+ simdutf_warn_unused result implementation::convert_utf16le_to_utf32_with_errors(
377
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
378
+ return rvv_utf16_to_utf32_with_errors<simdutf_ByteFlip::NONE>(src, len, dst);
379
+ }
380
+
381
+ simdutf_warn_unused result implementation::convert_utf16be_to_utf32_with_errors(
382
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
383
+ if (supports_zvbb())
384
+ return rvv_utf16_to_utf32_with_errors<simdutf_ByteFlip::ZVBB>(src, len,
385
+ dst);
386
+ else
387
+ return rvv_utf16_to_utf32_with_errors<simdutf_ByteFlip::V>(src, len, dst);
388
+ }
389
+
390
+ simdutf_warn_unused size_t implementation::convert_valid_utf16le_to_utf32(
391
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
392
+ return convert_utf16le_to_utf32(src, len, dst);
393
+ }
394
+
395
+ simdutf_warn_unused size_t implementation::convert_valid_utf16be_to_utf32(
396
+ const char16_t *src, size_t len, char32_t *dst) const noexcept {
397
+ return convert_utf16be_to_utf32(src, len, dst);
398
+ }
399
+ #endif // SIMDUTF_FEATURE_UTF16 && SIMDUTF_FEATURE_UTF32
@@ -0,0 +1,110 @@
1
+ template <endianness big_endian, bool in_place, bool vlmax>
2
+ simdutf_really_inline void utf16fix_block_rvv(char16_t *out, const char16_t *in,
3
+ size_t vl) {
4
+ const char16_t replacement = scalar::utf16::replacement<big_endian>();
5
+ vuint16m8_t block = __riscv_vle16_v_u16m8((const uint16_t *)in, vl);
6
+ vuint16m8_t lookback = __riscv_vslide1up_vx_u16m8(block, in[-1], vl);
7
+ vuint16m8_t lb_masked = __riscv_vand_vx_u16m8(
8
+ lookback, scalar::utf16::swap_if_needed<big_endian>(0xfc00U), vl);
9
+ vuint16m8_t block_masked = __riscv_vand_vx_u16m8(
10
+ block, scalar::utf16::swap_if_needed<big_endian>(0xfc00U), vl);
11
+ vbool2_t lb_is_high = __riscv_vmseq_vx_u16m8_b2(
12
+ lb_masked, scalar::utf16::swap_if_needed<big_endian>(0xd800U), vl);
13
+ vbool2_t block_is_low = __riscv_vmseq_vx_u16m8_b2(
14
+ block_masked, scalar::utf16::swap_if_needed<big_endian>(0xdc00U), vl);
15
+
16
+ vbool2_t illseq = __riscv_vmxor_mm_b2(lb_is_high, block_is_low, vl);
17
+ if (__riscv_vfirst_m_b2(illseq, vl) >= 0) {
18
+ vbool2_t lb_illseq = __riscv_vmandn_mm_b2(lb_is_high, block_is_low, vl);
19
+
20
+ vbool2_t lb_illseq_right_shifted;
21
+ if (vlmax) {
22
+ /* right shift mask register directly via reinterpret at vlmax */
23
+ size_t vlm = __riscv_vsetvlmax_e8mf2();
24
+ vuint8mf2_t vlb_illseq =
25
+ __riscv_vlmul_trunc_u8mf2(__riscv_vreinterpret_u8m1(lb_illseq));
26
+ lb_illseq_right_shifted =
27
+ __riscv_vreinterpret_b2(__riscv_vlmul_ext_u8m1(__riscv_vmacc_vx_u8mf2(
28
+ __riscv_vsrl_vx_u8mf2(vlb_illseq, 1, vlm), 1 << 7,
29
+ __riscv_vslide1down_vx_u8mf2(vlb_illseq, 0, vlm), vlm)));
30
+ } else {
31
+ lb_illseq_right_shifted = __riscv_vmandn_mm_b2(
32
+ __riscv_vmseq_vx_u16m8_b2(
33
+ __riscv_vslide1down_vx_u16m8(lb_masked, 0, vl),
34
+ scalar::utf16::swap_if_needed<big_endian>(0xd800U), vl),
35
+ __riscv_vmseq_vx_u16m8_b2(
36
+ __riscv_vslide1down_vx_u16m8(block_masked, 0, vl),
37
+ scalar::utf16::swap_if_needed<big_endian>(0xdc00U), vl),
38
+ vl);
39
+ }
40
+
41
+ char16_t last = out[-1]; /* allow compiler to generate branchless code */
42
+ out[-1] = __riscv_vfirst_m_b2(lb_illseq, vl) == 0 ? replacement : last;
43
+ vbool2_t block_illseq =
44
+ __riscv_vmor_mm_b2(__riscv_vmandn_mm_b2(block_is_low, lb_is_high, vl),
45
+ lb_illseq_right_shifted, vl);
46
+ block = __riscv_vmerge_vxm_u16m8(block, replacement, block_illseq, vl);
47
+ __riscv_vse16_v_u16m8((uint16_t *)out, block, vl);
48
+ } else if (!in_place) {
49
+ __riscv_vse16_v_u16m8((uint16_t *)out, block, vl);
50
+ }
51
+ }
52
+
53
+ template <endianness big_endian>
54
+ void rvv_to_well_formed_utf16(const char16_t *in, size_t n, char16_t *out) {
55
+ const char16_t replacement = scalar::utf16::replacement<big_endian>();
56
+ const size_t VL = __riscv_vsetvlmax_e16m8();
57
+ if (n == 0)
58
+ return;
59
+
60
+ out[0] =
61
+ scalar::utf16::is_low_surrogate<big_endian>(in[0]) ? replacement : in[0];
62
+ n -= 1;
63
+ in += 1;
64
+ out += 1;
65
+
66
+ /* duplicate code to have the compiler specialise utf16fix_block() */
67
+ if (in == out) {
68
+ for (; n > VL; n -= VL, in += VL, out += VL) {
69
+ utf16fix_block_rvv<big_endian, true, true>(out, in, VL);
70
+ }
71
+ utf16fix_block_rvv<big_endian, true, false>(out, in, n);
72
+ } else {
73
+ for (; n > VL; n -= VL, in += VL, out += VL) {
74
+ utf16fix_block_rvv<big_endian, false, true>(out, in, VL);
75
+ }
76
+ utf16fix_block_rvv<big_endian, false, false>(out, in, n);
77
+ }
78
+
79
+ out[n - 1] = scalar::utf16::is_high_surrogate<big_endian>(out[n - 1])
80
+ ? replacement
81
+ : out[n - 1];
82
+ }
83
+
84
+ void implementation::to_well_formed_utf16le(const char16_t *input, size_t len,
85
+ char16_t *output) const noexcept {
86
+ return rvv_to_well_formed_utf16<endianness::LITTLE>(input, len, output);
87
+ }
88
+
89
+ void implementation::to_well_formed_utf16be(const char16_t *input, size_t len,
90
+ char16_t *output) const noexcept {
91
+ return rvv_to_well_formed_utf16<endianness::BIG>(input, len, output);
92
+ }
93
+
94
+ template <simdutf_ByteFlip bflip>
95
+ simdutf_really_inline static void
96
+ rvv_change_endianness_utf16(const char16_t *src, size_t len, char16_t *dst) {
97
+ for (size_t vl; len > 0; len -= vl, src += vl, dst += vl) {
98
+ vl = __riscv_vsetvl_e16m8(len);
99
+ vuint16m8_t v = __riscv_vle16_v_u16m8((uint16_t *)src, vl);
100
+ __riscv_vse16_v_u16m8((uint16_t *)dst, simdutf_byteflip<bflip>(v, vl), vl);
101
+ }
102
+ }
103
+
104
+ void implementation::change_endianness_utf16(const char16_t *src, size_t len,
105
+ char16_t *dst) const noexcept {
106
+ if (supports_zvbb())
107
+ return rvv_change_endianness_utf16<simdutf_ByteFlip::ZVBB>(src, len, dst);
108
+ else
109
+ return rvv_change_endianness_utf16<simdutf_ByteFlip::V>(src, len, dst);
110
+ }