viem 0.0.1-alpha.24 → 0.0.1-alpha.26

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 (510) hide show
  1. package/contract/package.json +4 -0
  2. package/dist/call-3476b8ee.d.ts +22 -0
  3. package/dist/{chain-afa13f5a.d.ts → chain-42de87e5.d.ts} +20 -14
  4. package/dist/{chain-e33d019b.d.ts → chain-b0cfb141.d.ts} +1 -1
  5. package/dist/chains.d.ts +20 -8
  6. package/dist/chains.js +46 -46
  7. package/dist/chains.mjs +1 -1
  8. package/dist/{chunk-3ARWEJ3G.mjs → chunk-BSAB6UH4.mjs} +18 -2
  9. package/dist/chunk-BSAB6UH4.mjs.map +1 -0
  10. package/dist/{chunk-4D5XG6XB.js → chunk-DSQO3E4F.js} +367 -429
  11. package/dist/chunk-DSQO3E4F.js.map +1 -0
  12. package/dist/{chunk-A2HXAZXC.js → chunk-LINNE4N4.js} +199 -161
  13. package/dist/chunk-LINNE4N4.js.map +1 -0
  14. package/dist/{chunk-LQVMDX5I.mjs → chunk-PRG3BBPZ.mjs} +397 -459
  15. package/dist/chunk-PRG3BBPZ.mjs.map +1 -0
  16. package/dist/{chunk-YQUC52RL.mjs → chunk-QSIX64VZ.mjs} +136 -98
  17. package/dist/chunk-QSIX64VZ.mjs.map +1 -0
  18. package/dist/{chunk-ZYSXBTBB.js → chunk-YTG4YXMB.js} +30 -14
  19. package/dist/chunk-YTG4YXMB.js.map +1 -0
  20. package/dist/{contract-70f4ddbe.d.ts → contract-9dd2f98b.d.ts} +44 -31
  21. package/dist/contract.d.ts +129 -0
  22. package/dist/contract.js +55 -0
  23. package/dist/{clients/index.js.map → contract.js.map} +0 -0
  24. package/dist/contract.mjs +55 -0
  25. package/dist/{clients/index.mjs.map → contract.mjs.map} +0 -0
  26. package/dist/{createClient-60e3ab98.d.ts → createClient-6689596e.d.ts} +11 -5
  27. package/dist/{createPublicClient-d3d12dc3.d.ts → createPublicClient-fd558574.d.ts} +3 -3
  28. package/dist/{createTestClient-5f4532c4.d.ts → createTestClient-bc1d9028.d.ts} +3 -3
  29. package/dist/{createWalletClient-9ec3df4f.d.ts → createWalletClient-4df88244.d.ts} +3 -3
  30. package/dist/decodeErrorResult-ac835649.d.ts +16 -0
  31. package/dist/{eip1193-9317a312.d.ts → eip1193-617a05ae.d.ts} +2 -2
  32. package/dist/ens.d.ts +82 -1
  33. package/dist/ens.js +208 -3
  34. package/dist/ens.js.map +1 -1
  35. package/dist/ens.mjs +209 -4
  36. package/dist/ens.mjs.map +1 -1
  37. package/dist/getAbiItem-d2e8bd76.d.ts +97 -0
  38. package/dist/index.d.ts +113 -180
  39. package/dist/index.js +259 -279
  40. package/dist/index.js.map +1 -1
  41. package/dist/index.mjs +267 -287
  42. package/dist/index.mjs.map +1 -1
  43. package/dist/public.d.ts +353 -10
  44. package/dist/public.js +3 -4
  45. package/dist/public.mjs +6 -7
  46. package/dist/readContract-c460f23a.d.ts +10 -0
  47. package/dist/rpc-8c10fc98.d.ts +119 -0
  48. package/dist/{sendTransaction-54a0d509.d.ts → sendTransaction-7ce442c0.d.ts} +3 -3
  49. package/dist/test.d.ts +160 -5
  50. package/dist/test.js +222 -18
  51. package/dist/test.js.map +1 -1
  52. package/dist/test.mjs +233 -29
  53. package/dist/test.mjs.map +1 -1
  54. package/dist/transactionReceipt-44dbf122.d.ts +26 -0
  55. package/dist/{transactionRequest-bdf57f7d.d.ts → transactionRequest-f437b4ba.d.ts} +1 -1
  56. package/dist/utils/index.d.ts +228 -21
  57. package/dist/utils/index.js +2 -6
  58. package/dist/utils/index.mjs +3 -7
  59. package/dist/wallet.d.ts +41 -7
  60. package/dist/wallet.js +3 -3
  61. package/dist/wallet.mjs +2 -2
  62. package/dist/watchEvent-569c9976.d.ts +41 -0
  63. package/dist/window.d.ts +2 -2
  64. package/ens/package.json +4 -0
  65. package/package.json +16 -12
  66. package/public/package.json +4 -0
  67. package/test/package.json +4 -0
  68. package/wallet/package.json +4 -0
  69. package/clients/package.json +0 -4
  70. package/dist/chunk-3ARWEJ3G.mjs.map +0 -1
  71. package/dist/chunk-4D5XG6XB.js.map +0 -1
  72. package/dist/chunk-6QTEW2BE.mjs +0 -260
  73. package/dist/chunk-6QTEW2BE.mjs.map +0 -1
  74. package/dist/chunk-A2HXAZXC.js.map +0 -1
  75. package/dist/chunk-KRPS5CIB.mjs +0 -256
  76. package/dist/chunk-KRPS5CIB.mjs.map +0 -1
  77. package/dist/chunk-LQVMDX5I.mjs.map +0 -1
  78. package/dist/chunk-N3IOPT3R.js +0 -256
  79. package/dist/chunk-N3IOPT3R.js.map +0 -1
  80. package/dist/chunk-YQUC52RL.mjs.map +0 -1
  81. package/dist/chunk-ZSTVHQ6J.js +0 -260
  82. package/dist/chunk-ZSTVHQ6J.js.map +0 -1
  83. package/dist/chunk-ZYSXBTBB.js.map +0 -1
  84. package/dist/clients/index.d.ts +0 -9
  85. package/dist/clients/index.js +0 -24
  86. package/dist/clients/index.mjs +0 -24
  87. package/dist/normalize-ef9240c0.d.ts +0 -33
  88. package/dist/parseGwei-492ab7dd.d.ts +0 -355
  89. package/dist/rpc-26932bae.d.ts +0 -61
  90. package/dist/stopImpersonatingAccount-c1a4b7e5.d.ts +0 -156
  91. package/dist/watchAsset-d59d6e35.d.ts +0 -38
  92. package/dist/watchPendingTransactions-ea21b31d.d.ts +0 -373
  93. package/dist/webSocket-775b4037.d.ts +0 -83
  94. package/src/_test/abis.ts +0 -1420
  95. package/src/_test/bench.ts +0 -15
  96. package/src/_test/constants.ts +0 -61
  97. package/src/_test/globalSetup.ts +0 -11
  98. package/src/_test/index.ts +0 -25
  99. package/src/_test/setup.ts +0 -8
  100. package/src/_test/utils.ts +0 -150
  101. package/src/actions/index.test.ts +0 -81
  102. package/src/actions/index.ts +0 -182
  103. package/src/actions/public/call.bench.ts +0 -48
  104. package/src/actions/public/call.test.ts +0 -99
  105. package/src/actions/public/call.ts +0 -97
  106. package/src/actions/public/createBlockFilter.bench.ts +0 -11
  107. package/src/actions/public/createBlockFilter.test.ts +0 -9
  108. package/src/actions/public/createBlockFilter.ts +0 -14
  109. package/src/actions/public/createContractEventFilter.test.ts +0 -119
  110. package/src/actions/public/createContractEventFilter.ts +0 -69
  111. package/src/actions/public/createEventFilter.test.ts +0 -245
  112. package/src/actions/public/createEventFilter.ts +0 -76
  113. package/src/actions/public/createPendingTransactionFilter.bench.ts +0 -11
  114. package/src/actions/public/createPendingTransactionFilter.test.ts +0 -9
  115. package/src/actions/public/createPendingTransactionFilter.ts +0 -14
  116. package/src/actions/public/deployContract.test.ts +0 -56
  117. package/src/actions/public/deployContract.ts +0 -38
  118. package/src/actions/public/estimateGas.bench.ts +0 -46
  119. package/src/actions/public/estimateGas.test.ts +0 -92
  120. package/src/actions/public/estimateGas.ts +0 -61
  121. package/src/actions/public/getBalance.test.ts +0 -83
  122. package/src/actions/public/getBalance.ts +0 -37
  123. package/src/actions/public/getBlock.bench.ts +0 -28
  124. package/src/actions/public/getBlock.test.ts +0 -575
  125. package/src/actions/public/getBlock.ts +0 -65
  126. package/src/actions/public/getBlockNumber.bench.ts +0 -28
  127. package/src/actions/public/getBlockNumber.test.ts +0 -27
  128. package/src/actions/public/getBlockNumber.ts +0 -32
  129. package/src/actions/public/getBlockTransactionCount.bench.ts +0 -15
  130. package/src/actions/public/getBlockTransactionCount.test.ts +0 -57
  131. package/src/actions/public/getBlockTransactionCount.ts +0 -52
  132. package/src/actions/public/getBytecode.test.ts +0 -27
  133. package/src/actions/public/getBytecode.ts +0 -32
  134. package/src/actions/public/getChainId.bench.ts +0 -15
  135. package/src/actions/public/getChainId.test.ts +0 -8
  136. package/src/actions/public/getChainId.ts +0 -7
  137. package/src/actions/public/getFeeHistory.bench.ts +0 -18
  138. package/src/actions/public/getFeeHistory.test.ts +0 -137
  139. package/src/actions/public/getFeeHistory.ts +0 -44
  140. package/src/actions/public/getFilterChanges.bench.ts +0 -13
  141. package/src/actions/public/getFilterChanges.test.ts +0 -189
  142. package/src/actions/public/getFilterChanges.ts +0 -23
  143. package/src/actions/public/getFilterLogs.test.ts +0 -104
  144. package/src/actions/public/getFilterLogs.ts +0 -20
  145. package/src/actions/public/getGasPrice.bench.ts +0 -19
  146. package/src/actions/public/getGasPrice.test.ts +0 -8
  147. package/src/actions/public/getGasPrice.ts +0 -15
  148. package/src/actions/public/getLogs.test.ts +0 -107
  149. package/src/actions/public/getLogs.ts +0 -84
  150. package/src/actions/public/getStorageAt.test.ts +0 -34
  151. package/src/actions/public/getStorageAt.ts +0 -32
  152. package/src/actions/public/getTransaction.bench.ts +0 -33
  153. package/src/actions/public/getTransaction.test.ts +0 -311
  154. package/src/actions/public/getTransaction.ts +0 -95
  155. package/src/actions/public/getTransactionConfirmations.test.ts +0 -69
  156. package/src/actions/public/getTransactionConfirmations.ts +0 -38
  157. package/src/actions/public/getTransactionCount.test.ts +0 -56
  158. package/src/actions/public/getTransactionCount.ts +0 -34
  159. package/src/actions/public/getTransactionReceipt.bench.ts +0 -33
  160. package/src/actions/public/getTransactionReceipt.test.ts +0 -179
  161. package/src/actions/public/getTransactionReceipt.ts +0 -34
  162. package/src/actions/public/index.test.ts +0 -44
  163. package/src/actions/public/index.ts +0 -152
  164. package/src/actions/public/multicall.test.ts +0 -452
  165. package/src/actions/public/multicall.ts +0 -103
  166. package/src/actions/public/readContract.test.ts +0 -328
  167. package/src/actions/public/readContract.ts +0 -73
  168. package/src/actions/public/simulateContract.bench.ts +0 -41
  169. package/src/actions/public/simulateContract.test.ts +0 -410
  170. package/src/actions/public/simulateContract.ts +0 -94
  171. package/src/actions/public/uninstallFilter.bench.ts +0 -13
  172. package/src/actions/public/uninstallFilter.test.ts +0 -65
  173. package/src/actions/public/uninstallFilter.ts +0 -17
  174. package/src/actions/public/waitForTransactionReceipt.test.ts +0 -322
  175. package/src/actions/public/waitForTransactionReceipt.ts +0 -170
  176. package/src/actions/public/watchBlockNumber.test.ts +0 -166
  177. package/src/actions/public/watchBlockNumber.ts +0 -79
  178. package/src/actions/public/watchBlocks.test.ts +0 -210
  179. package/src/actions/public/watchBlocks.ts +0 -114
  180. package/src/actions/public/watchContractEvent.test.ts +0 -305
  181. package/src/actions/public/watchContractEvent.ts +0 -108
  182. package/src/actions/public/watchEvent.test.ts +0 -195
  183. package/src/actions/public/watchEvent.ts +0 -95
  184. package/src/actions/public/watchPendingTransactions.test.ts +0 -116
  185. package/src/actions/public/watchPendingTransactions.ts +0 -74
  186. package/src/actions/test/dropTransaction.test.ts +0 -34
  187. package/src/actions/test/dropTransaction.ts +0 -17
  188. package/src/actions/test/getAutomine.test.ts +0 -14
  189. package/src/actions/test/getAutomine.ts +0 -11
  190. package/src/actions/test/getTxpoolContent.test.ts +0 -45
  191. package/src/actions/test/getTxpoolContent.ts +0 -7
  192. package/src/actions/test/getTxpoolStatus.test.ts +0 -41
  193. package/src/actions/test/getTxpoolStatus.ts +0 -12
  194. package/src/actions/test/impersonateAccount.test.ts +0 -26
  195. package/src/actions/test/impersonateAccount.ts +0 -17
  196. package/src/actions/test/increaseTime.test.ts +0 -18
  197. package/src/actions/test/increaseTime.ts +0 -17
  198. package/src/actions/test/index.test.ts +0 -38
  199. package/src/actions/test/index.ts +0 -77
  200. package/src/actions/test/inspectTxpool.test.ts +0 -50
  201. package/src/actions/test/inspectTxpool.ts +0 -7
  202. package/src/actions/test/mine.test.ts +0 -20
  203. package/src/actions/test/mine.ts +0 -16
  204. package/src/actions/test/removeBlockTimestampInterval.test.ts +0 -23
  205. package/src/actions/test/removeBlockTimestampInterval.ts +0 -7
  206. package/src/actions/test/reset.test.ts +0 -19
  207. package/src/actions/test/reset.ts +0 -18
  208. package/src/actions/test/revert.test.ts +0 -39
  209. package/src/actions/test/revert.ts +0 -14
  210. package/src/actions/test/sendUnsignedTransaction.test.ts +0 -52
  211. package/src/actions/test/sendUnsignedTransaction.ts +0 -19
  212. package/src/actions/test/setAutomine.test.ts +0 -14
  213. package/src/actions/test/setAutomine.ts +0 -8
  214. package/src/actions/test/setBalance.test.ts +0 -29
  215. package/src/actions/test/setBalance.ts +0 -20
  216. package/src/actions/test/setBlockGasLimit.test.ts +0 -21
  217. package/src/actions/test/setBlockGasLimit.ts +0 -17
  218. package/src/actions/test/setBlockTimestampInterval.test.ts +0 -23
  219. package/src/actions/test/setBlockTimestampInterval.ts +0 -16
  220. package/src/actions/test/setCode.test.ts +0 -26
  221. package/src/actions/test/setCode.ts +0 -19
  222. package/src/actions/test/setCoinbase.test.ts +0 -11
  223. package/src/actions/test/setCoinbase.ts +0 -17
  224. package/src/actions/test/setIntervalMining.test.ts +0 -30
  225. package/src/actions/test/setIntervalMining.ts +0 -16
  226. package/src/actions/test/setLoggingEnabled.test.ts +0 -10
  227. package/src/actions/test/setLoggingEnabled.ts +0 -8
  228. package/src/actions/test/setMinGasPrice.test.ts +0 -22
  229. package/src/actions/test/setMinGasPrice.ts +0 -17
  230. package/src/actions/test/setNextBlockBaseFeePerGas.test.ts +0 -23
  231. package/src/actions/test/setNextBlockBaseFeePerGas.ts +0 -17
  232. package/src/actions/test/setNextBlockTimestamp.test.ts +0 -19
  233. package/src/actions/test/setNextBlockTimestamp.ts +0 -17
  234. package/src/actions/test/setNonce.test.ts +0 -28
  235. package/src/actions/test/setNonce.ts +0 -20
  236. package/src/actions/test/setRpcUrl.test.ts +0 -9
  237. package/src/actions/test/setRpcUrl.ts +0 -8
  238. package/src/actions/test/setStorageAt.test.ts +0 -36
  239. package/src/actions/test/setStorageAt.ts +0 -26
  240. package/src/actions/test/snapshot.test.ts +0 -18
  241. package/src/actions/test/snapshot.ts +0 -7
  242. package/src/actions/test/stopImpersonatingAccount.test.ts +0 -29
  243. package/src/actions/test/stopImpersonatingAccount.ts +0 -17
  244. package/src/actions/wallet/addChain.test.ts +0 -14
  245. package/src/actions/wallet/addChain.ts +0 -21
  246. package/src/actions/wallet/getAccounts.test.ts +0 -22
  247. package/src/actions/wallet/getAccounts.ts +0 -7
  248. package/src/actions/wallet/getPermissions.test.ts +0 -24
  249. package/src/actions/wallet/getPermissions.ts +0 -9
  250. package/src/actions/wallet/index.test.ts +0 -20
  251. package/src/actions/wallet/index.ts +0 -30
  252. package/src/actions/wallet/requestAccounts.test.ts +0 -13
  253. package/src/actions/wallet/requestAccounts.ts +0 -7
  254. package/src/actions/wallet/requestPermissions.test.ts +0 -26
  255. package/src/actions/wallet/requestPermissions.ts +0 -19
  256. package/src/actions/wallet/sendTransaction.bench.ts +0 -57
  257. package/src/actions/wallet/sendTransaction.test.ts +0 -440
  258. package/src/actions/wallet/sendTransaction.ts +0 -77
  259. package/src/actions/wallet/signMessage.test.ts +0 -61
  260. package/src/actions/wallet/signMessage.ts +0 -35
  261. package/src/actions/wallet/switchChain.test.ts +0 -21
  262. package/src/actions/wallet/switchChain.ts +0 -19
  263. package/src/actions/wallet/watchAsset.test.ts +0 -40
  264. package/src/actions/wallet/watchAsset.ts +0 -16
  265. package/src/actions/wallet/writeContract.test.ts +0 -84
  266. package/src/actions/wallet/writeContract.ts +0 -47
  267. package/src/chains.test.ts +0 -1912
  268. package/src/chains.ts +0 -99
  269. package/src/clients/createClient.test.ts +0 -295
  270. package/src/clients/createClient.ts +0 -81
  271. package/src/clients/createPublicClient.test.ts +0 -165
  272. package/src/clients/createPublicClient.ts +0 -49
  273. package/src/clients/createTestClient.test.ts +0 -145
  274. package/src/clients/createTestClient.ts +0 -72
  275. package/src/clients/createWalletClient.test.ts +0 -121
  276. package/src/clients/createWalletClient.ts +0 -54
  277. package/src/clients/index.test.ts +0 -19
  278. package/src/clients/index.ts +0 -31
  279. package/src/clients/transports/createTransport.test.ts +0 -58
  280. package/src/clients/transports/createTransport.ts +0 -48
  281. package/src/clients/transports/custom.test.ts +0 -98
  282. package/src/clients/transports/custom.ts +0 -34
  283. package/src/clients/transports/fallback.test.ts +0 -257
  284. package/src/clients/transports/fallback.ts +0 -50
  285. package/src/clients/transports/http.test.ts +0 -109
  286. package/src/clients/transports/http.ts +0 -51
  287. package/src/clients/transports/index.test.ts +0 -15
  288. package/src/clients/transports/index.ts +0 -17
  289. package/src/clients/transports/webSocket.test.ts +0 -163
  290. package/src/clients/transports/webSocket.ts +0 -117
  291. package/src/constants/abis.test.ts +0 -53
  292. package/src/constants/abis.ts +0 -44
  293. package/src/constants/index.test.ts +0 -14
  294. package/src/constants/index.ts +0 -3
  295. package/src/constants/solidity.test.ts +0 -41
  296. package/src/constants/solidity.ts +0 -35
  297. package/src/ens.ts +0 -5
  298. package/src/errors/abi.test.ts +0 -81
  299. package/src/errors/abi.ts +0 -238
  300. package/src/errors/address.test.ts +0 -14
  301. package/src/errors/address.ts +0 -9
  302. package/src/errors/base.test.ts +0 -114
  303. package/src/errors/base.ts +0 -57
  304. package/src/errors/block.test.ts +0 -24
  305. package/src/errors/block.ts +0 -18
  306. package/src/errors/contract.test.ts +0 -233
  307. package/src/errors/contract.ts +0 -178
  308. package/src/errors/data.ts +0 -20
  309. package/src/errors/encoding.ts +0 -60
  310. package/src/errors/index.ts +0 -79
  311. package/src/errors/log.ts +0 -8
  312. package/src/errors/request.test.ts +0 -330
  313. package/src/errors/request.ts +0 -163
  314. package/src/errors/rpc.test.ts +0 -87
  315. package/src/errors/rpc.ts +0 -113
  316. package/src/errors/transaction.test.ts +0 -83
  317. package/src/errors/transaction.ts +0 -54
  318. package/src/errors/transport.test.ts +0 -11
  319. package/src/errors/transport.ts +0 -12
  320. package/src/index.test.ts +0 -263
  321. package/src/index.ts +0 -389
  322. package/src/public.ts +0 -80
  323. package/src/test.ts +0 -51
  324. package/src/types/block.ts +0 -71
  325. package/src/types/chain.ts +0 -6
  326. package/src/types/contract.ts +0 -393
  327. package/src/types/eip1193.ts +0 -1041
  328. package/src/types/fee.ts +0 -47
  329. package/src/types/filter.ts +0 -8
  330. package/src/types/formatter.ts +0 -23
  331. package/src/types/index.ts +0 -83
  332. package/src/types/log.ts +0 -22
  333. package/src/types/misc.ts +0 -5
  334. package/src/types/multicall.ts +0 -82
  335. package/src/types/rpc.ts +0 -35
  336. package/src/types/transaction.ts +0 -145
  337. package/src/types/utils.ts +0 -67
  338. package/src/types/window.ts +0 -9
  339. package/src/utils/abi/decodeAbi.bench.ts +0 -135
  340. package/src/utils/abi/decodeAbi.test.ts +0 -1614
  341. package/src/utils/abi/decodeAbi.ts +0 -300
  342. package/src/utils/abi/decodeDeployData.test.ts +0 -151
  343. package/src/utils/abi/decodeDeployData.ts +0 -44
  344. package/src/utils/abi/decodeErrorResult.test.ts +0 -230
  345. package/src/utils/abi/decodeErrorResult.ts +0 -45
  346. package/src/utils/abi/decodeFunctionData.test.ts +0 -139
  347. package/src/utils/abi/decodeFunctionData.ts +0 -29
  348. package/src/utils/abi/decodeFunctionResult.test.ts +0 -333
  349. package/src/utils/abi/decodeFunctionResult.ts +0 -57
  350. package/src/utils/abi/encodeAbi.bench.ts +0 -163
  351. package/src/utils/abi/encodeAbi.test.ts +0 -1447
  352. package/src/utils/abi/encodeAbi.ts +0 -273
  353. package/src/utils/abi/encodeDeployData.test.ts +0 -124
  354. package/src/utils/abi/encodeDeployData.ts +0 -40
  355. package/src/utils/abi/encodeErrorResult.test.ts +0 -192
  356. package/src/utils/abi/encodeErrorResult.ts +0 -47
  357. package/src/utils/abi/encodeEventTopics.test.ts +0 -345
  358. package/src/utils/abi/encodeEventTopics.ts +0 -75
  359. package/src/utils/abi/encodeFunctionData.test.ts +0 -138
  360. package/src/utils/abi/encodeFunctionData.ts +0 -45
  361. package/src/utils/abi/encodeFunctionResult.test.ts +0 -279
  362. package/src/utils/abi/encodeFunctionResult.ts +0 -41
  363. package/src/utils/abi/formatAbiItem.test.ts +0 -335
  364. package/src/utils/abi/formatAbiItem.ts +0 -41
  365. package/src/utils/abi/formatAbiItemWithArgs.test.ts +0 -291
  366. package/src/utils/abi/formatAbiItemWithArgs.ts +0 -27
  367. package/src/utils/abi/getAbiItem.test.ts +0 -547
  368. package/src/utils/abi/getAbiItem.ts +0 -95
  369. package/src/utils/abi/index.test.ts +0 -23
  370. package/src/utils/abi/index.ts +0 -42
  371. package/src/utils/address/getAddress.bench.ts +0 -22
  372. package/src/utils/address/getAddress.test.ts +0 -46
  373. package/src/utils/address/getAddress.ts +0 -28
  374. package/src/utils/address/getContractAddress.bench.ts +0 -20
  375. package/src/utils/address/getContractAddress.test.ts +0 -78
  376. package/src/utils/address/getContractAddress.ts +0 -59
  377. package/src/utils/address/index.test.ts +0 -17
  378. package/src/utils/address/index.ts +0 -16
  379. package/src/utils/address/isAddress.test.ts +0 -10
  380. package/src/utils/address/isAddress.ts +0 -10
  381. package/src/utils/address/isAddressEqual.test.ts +0 -55
  382. package/src/utils/address/isAddressEqual.ts +0 -6
  383. package/src/utils/buildRequest.test.ts +0 -365
  384. package/src/utils/buildRequest.ts +0 -45
  385. package/src/utils/chain.test.ts +0 -43
  386. package/src/utils/chain.ts +0 -8
  387. package/src/utils/contract/extractFunctionParts.test.ts +0 -109
  388. package/src/utils/contract/extractFunctionParts.ts +0 -27
  389. package/src/utils/contract/getContractError.test.ts +0 -282
  390. package/src/utils/contract/getContractError.ts +0 -58
  391. package/src/utils/contract/index.test.ts +0 -15
  392. package/src/utils/contract/index.ts +0 -8
  393. package/src/utils/data/concat.test.ts +0 -35
  394. package/src/utils/data/concat.ts +0 -34
  395. package/src/utils/data/index.test.ts +0 -23
  396. package/src/utils/data/index.ts +0 -13
  397. package/src/utils/data/isBytes.test.ts +0 -9
  398. package/src/utils/data/isBytes.ts +0 -7
  399. package/src/utils/data/isHex.test.ts +0 -13
  400. package/src/utils/data/isHex.ts +0 -5
  401. package/src/utils/data/pad.bench.ts +0 -30
  402. package/src/utils/data/pad.test.ts +0 -367
  403. package/src/utils/data/pad.ts +0 -53
  404. package/src/utils/data/size.test.ts +0 -18
  405. package/src/utils/data/size.ts +0 -13
  406. package/src/utils/data/slice.test.ts +0 -203
  407. package/src/utils/data/slice.ts +0 -60
  408. package/src/utils/data/trim.bench.ts +0 -34
  409. package/src/utils/data/trim.test.ts +0 -175
  410. package/src/utils/data/trim.ts +0 -33
  411. package/src/utils/encoding/decodeBytes.bench.ts +0 -40
  412. package/src/utils/encoding/decodeBytes.test.ts +0 -144
  413. package/src/utils/encoding/decodeBytes.ts +0 -63
  414. package/src/utils/encoding/decodeHex.bench.ts +0 -24
  415. package/src/utils/encoding/decodeHex.test.ts +0 -167
  416. package/src/utils/encoding/decodeHex.ts +0 -76
  417. package/src/utils/encoding/decodeRlp.bench.ts +0 -34
  418. package/src/utils/encoding/decodeRlp.test.ts +0 -350
  419. package/src/utils/encoding/decodeRlp.ts +0 -121
  420. package/src/utils/encoding/encodeBytes.bench.ts +0 -29
  421. package/src/utils/encoding/encodeBytes.test.ts +0 -676
  422. package/src/utils/encoding/encodeBytes.ts +0 -59
  423. package/src/utils/encoding/encodeHex.bench.ts +0 -49
  424. package/src/utils/encoding/encodeHex.test.ts +0 -232
  425. package/src/utils/encoding/encodeHex.ts +0 -104
  426. package/src/utils/encoding/encodeRlp.bench.ts +0 -54
  427. package/src/utils/encoding/encodeRlp.test.ts +0 -254
  428. package/src/utils/encoding/encodeRlp.ts +0 -48
  429. package/src/utils/encoding/index.test.ts +0 -32
  430. package/src/utils/encoding/index.ts +0 -36
  431. package/src/utils/ens/index.test.ts +0 -13
  432. package/src/utils/ens/index.ts +0 -5
  433. package/src/utils/ens/labelhash.test.ts +0 -55
  434. package/src/utils/ens/labelhash.ts +0 -16
  435. package/src/utils/ens/namehash.test.ts +0 -65
  436. package/src/utils/ens/namehash.ts +0 -28
  437. package/src/utils/ens/normalize.bench.ts +0 -14
  438. package/src/utils/ens/normalize.test.ts +0 -35
  439. package/src/utils/ens/normalize.ts +0 -14
  440. package/src/utils/formatters/block.bench.ts +0 -51
  441. package/src/utils/formatters/block.test.ts +0 -115
  442. package/src/utils/formatters/block.ts +0 -37
  443. package/src/utils/formatters/extract.test.ts +0 -14
  444. package/src/utils/formatters/extract.ts +0 -18
  445. package/src/utils/formatters/feeHistory.test.ts +0 -66
  446. package/src/utils/formatters/feeHistory.ts +0 -12
  447. package/src/utils/formatters/format.test.ts +0 -93
  448. package/src/utils/formatters/format.ts +0 -90
  449. package/src/utils/formatters/index.test.ts +0 -27
  450. package/src/utils/formatters/index.ts +0 -34
  451. package/src/utils/formatters/log.test.ts +0 -79
  452. package/src/utils/formatters/log.ts +0 -12
  453. package/src/utils/formatters/transaction.test.ts +0 -271
  454. package/src/utils/formatters/transaction.ts +0 -63
  455. package/src/utils/formatters/transactionReceipt.bench.ts +0 -73
  456. package/src/utils/formatters/transactionReceipt.test.ts +0 -151
  457. package/src/utils/formatters/transactionReceipt.ts +0 -63
  458. package/src/utils/formatters/transactionRequest.bench.ts +0 -29
  459. package/src/utils/formatters/transactionRequest.test.ts +0 -237
  460. package/src/utils/formatters/transactionRequest.ts +0 -56
  461. package/src/utils/hash/getEventSignature.test.ts +0 -61
  462. package/src/utils/hash/getEventSignature.ts +0 -4
  463. package/src/utils/hash/getFunctionSignature.test.ts +0 -22
  464. package/src/utils/hash/getFunctionSignature.ts +0 -5
  465. package/src/utils/hash/hashFunction.test.ts +0 -65
  466. package/src/utils/hash/hashFunction.ts +0 -12
  467. package/src/utils/hash/index.test.ts +0 -13
  468. package/src/utils/hash/index.ts +0 -5
  469. package/src/utils/hash/keccak256.test.ts +0 -59
  470. package/src/utils/hash/keccak256.ts +0 -21
  471. package/src/utils/index.test.ts +0 -113
  472. package/src/utils/index.ts +0 -141
  473. package/src/utils/observe.test.ts +0 -176
  474. package/src/utils/observe.ts +0 -66
  475. package/src/utils/poll.test.ts +0 -127
  476. package/src/utils/poll.ts +0 -42
  477. package/src/utils/promise/index.test.ts +0 -14
  478. package/src/utils/promise/index.ts +0 -3
  479. package/src/utils/promise/withCache.test.ts +0 -97
  480. package/src/utils/promise/withCache.ts +0 -73
  481. package/src/utils/promise/withRetry.test.ts +0 -231
  482. package/src/utils/promise/withRetry.ts +0 -61
  483. package/src/utils/promise/withTimeout.test.ts +0 -37
  484. package/src/utils/promise/withTimeout.ts +0 -39
  485. package/src/utils/rpc.test.ts +0 -989
  486. package/src/utils/rpc.ts +0 -292
  487. package/src/utils/stringify.test.ts +0 -13
  488. package/src/utils/stringify.ts +0 -5
  489. package/src/utils/uid.ts +0 -14
  490. package/src/utils/unit/constants.test.ts +0 -22
  491. package/src/utils/unit/constants.ts +0 -12
  492. package/src/utils/unit/formatEther.test.ts +0 -75
  493. package/src/utils/unit/formatEther.ts +0 -6
  494. package/src/utils/unit/formatGwei.test.ts +0 -32
  495. package/src/utils/unit/formatGwei.ts +0 -6
  496. package/src/utils/unit/formatUnit.bench.ts +0 -21
  497. package/src/utils/unit/formatUnit.test.ts +0 -40
  498. package/src/utils/unit/formatUnit.ts +0 -16
  499. package/src/utils/unit/index.test.ts +0 -28
  500. package/src/utils/unit/index.ts +0 -7
  501. package/src/utils/unit/parseEther.test.ts +0 -126
  502. package/src/utils/unit/parseEther.ts +0 -6
  503. package/src/utils/unit/parseGwei.test.ts +0 -50
  504. package/src/utils/unit/parseGwei.ts +0 -6
  505. package/src/utils/unit/parseUnit.bench.ts +0 -21
  506. package/src/utils/unit/parseUnit.test.ts +0 -54
  507. package/src/utils/unit/parseUnit.ts +0 -27
  508. package/src/utils/wait.ts +0 -3
  509. package/src/wallet.ts +0 -23
  510. package/src/window.ts +0 -1
@@ -1,282 +0,0 @@
1
- import { describe, expect, test } from 'vitest'
2
-
3
- import { accounts } from '../../_test'
4
- import { baycContractConfig } from '../../_test/abis'
5
- import {
6
- AbiDecodingZeroDataError,
7
- BaseError,
8
- RawContractError,
9
- } from '../../errors'
10
- import { getContractError } from './getContractError'
11
-
12
- describe('getContractError', () => {
13
- test('default', () => {
14
- const error = getContractError(
15
- new RawContractError({
16
- message: 'execution reverted: Sale must be active to mint Ape',
17
- data: '0x08c379a00000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000001f53616c65206d7573742062652061637469766520746f206d696e742041706500',
18
- }),
19
- {
20
- abi: baycContractConfig.abi,
21
- functionName: 'mintApe',
22
- args: [1n],
23
- sender: accounts[0].address,
24
- },
25
- )
26
- expect(error).toMatchInlineSnapshot(`
27
- [ContractFunctionExecutionError: The contract function "mintApe" reverted with the following reason:
28
- Sale must be active to mint Ape
29
-
30
- Function: mintApe(uint256 numberOfTokens)
31
- Arguments: (1)
32
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
33
-
34
- Version: viem@1.0.2]
35
- `)
36
- expect(error.cause).toMatchInlineSnapshot(`
37
- [ContractFunctionRevertedError: The contract function "mintApe" reverted with the following reason:
38
- Sale must be active to mint Ape
39
-
40
- Version: viem@1.0.2]
41
- `)
42
- })
43
-
44
- test('default: rpc', () => {
45
- const error = getContractError(
46
- new BaseError('An RPC error occurred', {
47
- cause: {
48
- code: 3,
49
- message: 'execution reverted: Sale must be active to mint Ape',
50
- data: '0x08c379a00000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000001f53616c65206d7573742062652061637469766520746f206d696e742041706500',
51
- } as unknown as Error,
52
- }),
53
- {
54
- abi: baycContractConfig.abi,
55
- functionName: 'mintApe',
56
- args: [1n],
57
- sender: accounts[0].address,
58
- },
59
- )
60
- expect(error).toMatchInlineSnapshot(`
61
- [ContractFunctionExecutionError: The contract function "mintApe" reverted with the following reason:
62
- Sale must be active to mint Ape
63
-
64
- Function: mintApe(uint256 numberOfTokens)
65
- Arguments: (1)
66
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
67
-
68
- Version: viem@1.0.2]
69
- `)
70
- expect(error.cause).toMatchInlineSnapshot(`
71
- [ContractFunctionRevertedError: The contract function "mintApe" reverted with the following reason:
72
- Sale must be active to mint Ape
73
-
74
- Version: viem@1.0.2]
75
- `)
76
- })
77
-
78
- test('no data', () => {
79
- const error = getContractError(
80
- new BaseError('An RPC error occurred', {
81
- cause: {
82
- code: 3,
83
- message: 'ah no',
84
- } as unknown as Error,
85
- }),
86
- {
87
- abi: baycContractConfig.abi,
88
- functionName: 'mintApe',
89
- args: [1n],
90
- sender: accounts[0].address,
91
- },
92
- )
93
- expect(error).toMatchInlineSnapshot(`
94
- [ContractFunctionExecutionError: The contract function "mintApe" reverted with the following reason:
95
- ah no
96
-
97
- Function: mintApe(uint256 numberOfTokens)
98
- Arguments: (1)
99
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
100
-
101
- Version: viem@1.0.2]
102
- `)
103
- expect(error.cause).toMatchInlineSnapshot(`
104
- [ContractFunctionRevertedError: The contract function "mintApe" reverted with the following reason:
105
- ah no
106
-
107
- Version: viem@1.0.2]
108
- `)
109
- })
110
-
111
- test('no message', () => {
112
- const error = getContractError(
113
- new BaseError('An RPC error occurred', {
114
- cause: {
115
- code: 3,
116
- data: '0x08c379a00000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000001f53616c65206d7573742062652061637469766520746f206d696e742041706500',
117
- } as unknown as Error,
118
- }),
119
- {
120
- abi: baycContractConfig.abi,
121
- functionName: 'mintApe',
122
- args: [1n],
123
- sender: accounts[0].address,
124
- },
125
- )
126
- expect(error).toMatchInlineSnapshot(`
127
- [ContractFunctionExecutionError: The contract function "mintApe" reverted with the following reason:
128
- Sale must be active to mint Ape
129
-
130
- Function: mintApe(uint256 numberOfTokens)
131
- Arguments: (1)
132
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
133
-
134
- Version: viem@1.0.2]
135
- `)
136
- expect(error.cause).toMatchInlineSnapshot(`
137
- [ContractFunctionRevertedError: The contract function "mintApe" reverted with the following reason:
138
- Sale must be active to mint Ape
139
-
140
- Version: viem@1.0.2]
141
- `)
142
- })
143
-
144
- test('unknown function', () => {
145
- const error = getContractError(
146
- new BaseError('An RPC error occurred', {
147
- cause: {
148
- code: 3,
149
- message: 'execution reverted: Sale must be active to mint Ape',
150
- data: '0x08c379a00000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000001f53616c65206d7573742062652061637469766520746f206d696e742041706500',
151
- } as unknown as Error,
152
- }),
153
- {
154
- abi: baycContractConfig.abi,
155
- functionName: 'mintApe',
156
- args: [1n],
157
- sender: accounts[0].address,
158
- },
159
- )
160
- expect(error).toMatchInlineSnapshot(`
161
- [ContractFunctionExecutionError: The contract function "mintApe" reverted with the following reason:
162
- Sale must be active to mint Ape
163
-
164
- Function: mintApe(uint256 numberOfTokens)
165
- Arguments: (1)
166
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
167
-
168
- Version: viem@1.0.2]
169
- `)
170
- expect(error.cause).toMatchInlineSnapshot(`
171
- [ContractFunctionRevertedError: The contract function "mintApe" reverted with the following reason:
172
- Sale must be active to mint Ape
173
-
174
- Version: viem@1.0.2]
175
- `)
176
- })
177
-
178
- test('unknown error', () => {
179
- const error = getContractError(
180
- new BaseError('An RPC error occurred', {
181
- cause: new Error('rarararar i am an error lmaoaoo'),
182
- }),
183
- {
184
- abi: baycContractConfig.abi,
185
- functionName: 'mintApe',
186
- args: [1n],
187
- sender: accounts[0].address,
188
- },
189
- )
190
- expect(error).toMatchInlineSnapshot(`
191
- [ContractFunctionExecutionError: An RPC error occurred
192
-
193
- Function: mintApe(uint256 numberOfTokens)
194
- Arguments: (1)
195
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
196
-
197
- Details: rarararar i am an error lmaoaoo
198
- Version: viem@1.0.2]
199
- `)
200
- expect(error.cause).toMatchInlineSnapshot(`
201
- [ViemError: An RPC error occurred
202
-
203
- Details: rarararar i am an error lmaoaoo
204
- Version: viem@1.0.2]
205
- `)
206
-
207
- const error2 = getContractError(new BaseError('An RPC error occurred'), {
208
- abi: baycContractConfig.abi,
209
- functionName: 'mintApe',
210
- args: [1n],
211
- sender: accounts[0].address,
212
- })
213
- expect(error2).toMatchInlineSnapshot(`
214
- [ContractFunctionExecutionError: An RPC error occurred
215
-
216
- Function: mintApe(uint256 numberOfTokens)
217
- Arguments: (1)
218
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
219
-
220
- Version: viem@1.0.2]
221
- `)
222
- expect(error2.cause).toMatchInlineSnapshot(`
223
- [ViemError: An RPC error occurred
224
-
225
- Version: viem@1.0.2]
226
- `)
227
-
228
- const error3 = getContractError(new BaseError(''), {
229
- abi: baycContractConfig.abi,
230
- functionName: 'mintApe',
231
- args: [1n],
232
- sender: accounts[0].address,
233
- })
234
- expect(error3).toMatchInlineSnapshot(`
235
- [ContractFunctionExecutionError: An unknown error occurred while executing the contract function "mintApe".
236
-
237
- Function: mintApe(uint256 numberOfTokens)
238
- Arguments: (1)
239
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
240
-
241
- Version: viem@1.0.2]
242
- `)
243
- expect(error3.cause).toMatchInlineSnapshot(`
244
- [ViemError: An error occurred.
245
-
246
- Version: viem@1.0.2]
247
- `)
248
- })
249
-
250
- test('zero data', () => {
251
- const error = getContractError(new AbiDecodingZeroDataError(), {
252
- abi: baycContractConfig.abi,
253
- functionName: 'mintApe',
254
- args: [1n],
255
- sender: accounts[0].address,
256
- })
257
- expect(error).toMatchInlineSnapshot(`
258
- [ContractFunctionExecutionError: The contract function "mintApe" returned no data ("0x").
259
-
260
- This could be due to any of the following:
261
- - The contract does not have the function "mintApe",
262
- - The parameters passed to the contract function may be invalid, or
263
- - The address is not a contract.
264
-
265
- Function: mintApe(uint256 numberOfTokens)
266
- Arguments: (1)
267
- Sender: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266
268
-
269
- Version: viem@1.0.2]
270
- `)
271
- expect(error.cause).toMatchInlineSnapshot(`
272
- [ContractFunctionZeroDataError: The contract function "mintApe" returned no data ("0x").
273
-
274
- This could be due to any of the following:
275
- - The contract does not have the function "mintApe",
276
- - The parameters passed to the contract function may be invalid, or
277
- - The address is not a contract.
278
-
279
- Version: viem@1.0.2]
280
- `)
281
- })
282
- })
@@ -1,58 +0,0 @@
1
- import { Abi } from 'abitype'
2
- import {
3
- AbiDecodingZeroDataError,
4
- BaseError,
5
- ContractFunctionExecutionError,
6
- RawContractError,
7
- } from '../../errors'
8
- import {
9
- ContractFunctionRevertedError,
10
- ContractFunctionZeroDataError,
11
- } from '../../errors/contract'
12
- import { Address } from '../../types'
13
-
14
- const EXECUTION_REVERTED_ERROR_CODE = 3
15
-
16
- export function getContractError(
17
- err: BaseError,
18
- {
19
- abi,
20
- address,
21
- args,
22
- docsPath,
23
- functionName,
24
- sender,
25
- }: {
26
- abi: Abi
27
- args: any
28
- address?: Address
29
- docsPath?: string
30
- functionName: string
31
- sender?: Address
32
- },
33
- ) {
34
- const { code, data, message } = (
35
- err instanceof RawContractError ? err : err.cause || {}
36
- ) as RawContractError
37
-
38
- let cause = err
39
- if (err instanceof AbiDecodingZeroDataError) {
40
- cause = new ContractFunctionZeroDataError({ functionName })
41
- } else if (code === EXECUTION_REVERTED_ERROR_CODE && (data || message)) {
42
- cause = new ContractFunctionRevertedError({
43
- abi,
44
- data,
45
- functionName,
46
- message,
47
- })
48
- }
49
-
50
- return new ContractFunctionExecutionError(cause, {
51
- abi,
52
- args,
53
- contractAddress: address,
54
- docsPath,
55
- functionName,
56
- sender,
57
- })
58
- }
@@ -1,15 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import * as utils from './index'
4
-
5
- test('exports utils', () => {
6
- expect(utils).toMatchInlineSnapshot(`
7
- {
8
- "extractFunctionName": [Function],
9
- "extractFunctionParams": [Function],
10
- "extractFunctionParts": [Function],
11
- "extractFunctionType": [Function],
12
- "getContractError": [Function],
13
- }
14
- `)
15
- })
@@ -1,8 +0,0 @@
1
- export {
2
- extractFunctionName,
3
- extractFunctionParams,
4
- extractFunctionParts,
5
- extractFunctionType,
6
- } from './extractFunctionParts'
7
-
8
- export { getContractError } from './getContractError'
@@ -1,35 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import { concat, concatBytes, concatHex } from './concat'
4
-
5
- test('concat', () => {
6
- expect(concat(['0x0', '0x1'])).toBe('0x01')
7
- expect(concat(['0x1', '0x69', '0x420'])).toBe('0x169420')
8
- expect(concat(['0x00000001', '0x00000069', '0x00000420'])).toBe(
9
- '0x000000010000006900000420',
10
- )
11
- expect(concatHex(['0x00000001', '0x00000069', '0x00000420'])).toBe(
12
- '0x000000010000006900000420',
13
- )
14
-
15
- expect(concat([new Uint8Array([0]), new Uint8Array([1])])).toStrictEqual(
16
- new Uint8Array([0, 1]),
17
- )
18
- expect(concatBytes([new Uint8Array([0]), new Uint8Array([1])])).toStrictEqual(
19
- new Uint8Array([0, 1]),
20
- )
21
- expect(
22
- concat([
23
- new Uint8Array([1]),
24
- new Uint8Array([69]),
25
- new Uint8Array([420, 69]),
26
- ]),
27
- ).toStrictEqual(new Uint8Array([1, 69, 420, 69]))
28
- expect(
29
- concat([
30
- new Uint8Array([0, 0, 0, 1]),
31
- new Uint8Array([0, 0, 0, 69]),
32
- new Uint8Array([0, 0, 420, 69]),
33
- ]),
34
- ).toStrictEqual(new Uint8Array([0, 0, 0, 1, 0, 0, 0, 69, 0, 0, 420, 69]))
35
- })
@@ -1,34 +0,0 @@
1
- import type { ByteArray, Hex } from '../../types'
2
-
3
- type ConcatResult<TValue extends Hex | ByteArray> = TValue extends Hex
4
- ? Hex
5
- : ByteArray
6
-
7
- export function concat<TValue extends Hex | ByteArray>(
8
- values: TValue[],
9
- ): ConcatResult<TValue> {
10
- if (typeof values[0] === 'string')
11
- return concatHex(values as Hex[]) as ConcatResult<TValue>
12
- return concatBytes(values as ByteArray[]) as ConcatResult<TValue>
13
- }
14
-
15
- export function concatBytes(values: ByteArray[]): ByteArray {
16
- let length = 0
17
- for (const arr of values) {
18
- length += arr.length
19
- }
20
- const result = new Uint8Array(length)
21
- let offset = 0
22
- for (const arr of values) {
23
- result.set(arr, offset)
24
- offset += arr.length
25
- }
26
- return result
27
- }
28
-
29
- export function concatHex(values: Hex[]): Hex {
30
- return `0x${(values as Hex[]).reduce(
31
- (acc, x) => acc + x.replace('0x', ''),
32
- '',
33
- )}`
34
- }
@@ -1,23 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import * as utils from './index'
4
-
5
- test('exports utils', () => {
6
- expect(utils).toMatchInlineSnapshot(`
7
- {
8
- "concat": [Function],
9
- "concatBytes": [Function],
10
- "concatHex": [Function],
11
- "isBytes": [Function],
12
- "isHex": [Function],
13
- "pad": [Function],
14
- "padBytes": [Function],
15
- "padHex": [Function],
16
- "size": [Function],
17
- "slice": [Function],
18
- "sliceBytes": [Function],
19
- "sliceHex": [Function],
20
- "trim": [Function],
21
- }
22
- `)
23
- })
@@ -1,13 +0,0 @@
1
- export { concat, concatBytes, concatHex } from './concat'
2
-
3
- export { isBytes } from './isBytes'
4
-
5
- export { isHex } from './isHex'
6
-
7
- export { pad, padBytes, padHex } from './pad'
8
-
9
- export { trim } from './trim'
10
-
11
- export { size } from './size'
12
-
13
- export { slice, sliceBytes, sliceHex } from './slice'
@@ -1,9 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import { isBytes } from './isBytes'
4
-
5
- test('is bytes', () => {
6
- expect(isBytes(new Uint8Array([1, 69, 420])))
7
- expect(isBytes('0x1')).toBeFalsy()
8
- expect(isBytes(undefined)).toBeFalsy()
9
- })
@@ -1,7 +0,0 @@
1
- export function isBytes(value: any) {
2
- if (!value) return false
3
- if (typeof value !== 'object') return false
4
- return (
5
- value.BYTES_PER_ELEMENT === 1 && value.constructor.name === 'Uint8Array'
6
- )
7
- }
@@ -1,13 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import { isHex } from './isHex'
4
-
5
- test('is hex', () => {
6
- expect(isHex('0x')).toBeTruthy()
7
- expect(isHex('0x0')).toBeTruthy()
8
- expect(isHex('0x0123456789abcdef')).toBeTruthy()
9
- expect(isHex('0x0123456789abcdefABCDEF')).toBeTruthy()
10
- expect(isHex('0x0123456789abcdefg')).toBeFalsy()
11
- expect(isHex({ foo: 'bar' })).toBeFalsy()
12
- expect(isHex(undefined)).toBeFalsy()
13
- })
@@ -1,5 +0,0 @@
1
- export function isHex(value: any) {
2
- if (!value) return false
3
- if (typeof value !== 'string') return false
4
- return /^0x[0-9a-fA-F]*$/.test(value)
5
- }
@@ -1,30 +0,0 @@
1
- import { hexZeroPad, zeroPad } from 'ethers/lib/utils'
2
-
3
- import { bench, describe } from 'vitest'
4
- import Web3 from 'web3'
5
-
6
- import { padBytes, padHex } from './pad'
7
-
8
- describe('Pad Hex', () => {
9
- bench('viem: `padHex`', () => {
10
- padHex('0xa4e12a45')
11
- })
12
-
13
- bench('ethers: `hexZeroPad`', () => {
14
- hexZeroPad('0xa4e12a45', 32)
15
- })
16
-
17
- bench('web3.js: `padLeft`', () => {
18
- Web3.utils.padLeft('0xa4e12a45', 32)
19
- })
20
- })
21
-
22
- describe('Pad Bytes', () => {
23
- bench('viem: `padBytes`', () => {
24
- padBytes(new Uint8Array([1, 122, 51, 123]))
25
- })
26
-
27
- bench('ethers: `zeroPad`', () => {
28
- zeroPad(new Uint8Array([1, 122, 51, 123]), 32)
29
- })
30
- })