@coinbase/cdp-hooks 0.0.56 → 0.0.57

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 (264) hide show
  1. package/dist/esm/index100.js +5 -32
  2. package/dist/esm/index101.js +55 -21
  3. package/dist/esm/index102.js +2 -6
  4. package/dist/esm/index103.js +6 -72
  5. package/dist/esm/index104.js +214 -5
  6. package/dist/esm/index105.js +32 -6
  7. package/dist/esm/index106.js +20 -34
  8. package/dist/esm/index107.js +5 -75
  9. package/dist/esm/index108.js +74 -3
  10. package/dist/esm/index109.js +5 -23
  11. package/dist/esm/index110.js +5 -451
  12. package/dist/esm/index111.js +28 -23
  13. package/dist/esm/index112.js +67 -18
  14. package/dist/esm/index113.js +3 -34
  15. package/dist/esm/index114.js +21 -32
  16. package/dist/esm/index115.js +370 -112
  17. package/dist/esm/index116.js +28 -6
  18. package/dist/esm/index117.js +27 -2
  19. package/dist/esm/index118.js +29 -8
  20. package/dist/esm/index119.js +33 -17
  21. package/dist/esm/index120.js +184 -18
  22. package/dist/esm/index121.js +8 -8
  23. package/dist/esm/index122.js +2 -56
  24. package/dist/esm/index123.js +10 -43
  25. package/dist/esm/index124.js +18 -8
  26. package/dist/esm/index125.js +27 -7
  27. package/dist/esm/index126.js +8 -16
  28. package/dist/esm/index127.js +53 -16
  29. package/dist/esm/index128.js +45 -24
  30. package/dist/esm/index129.js +8 -16
  31. package/dist/esm/index130.js +7 -54
  32. package/dist/esm/index131.js +16 -11
  33. package/dist/esm/index132.js +18 -160
  34. package/dist/esm/index133.js +24 -21
  35. package/dist/esm/index134.js +16 -127
  36. package/dist/esm/index135.js +53 -37
  37. package/dist/esm/index136.js +11 -6
  38. package/dist/esm/index137.js +160 -27
  39. package/dist/esm/index138.js +21 -191
  40. package/dist/esm/index139.js +128 -4
  41. package/dist/esm/index140.js +36 -62
  42. package/dist/esm/index141.js +7 -3
  43. package/dist/esm/index142.js +25 -18
  44. package/dist/esm/index143.js +188 -13
  45. package/dist/esm/index144.js +4 -24
  46. package/dist/esm/index145.js +64 -11
  47. package/dist/esm/index146.js +3 -35
  48. package/dist/esm/index147.js +21 -3
  49. package/dist/esm/index148.js +15 -17
  50. package/dist/esm/index149.js +22 -26
  51. package/dist/esm/index150.js +11 -35
  52. package/dist/esm/index151.js +34 -7
  53. package/dist/esm/index152.js +3 -26
  54. package/dist/esm/index153.js +18 -28
  55. package/dist/esm/index154.js +26 -63
  56. package/dist/esm/index155.js +35 -9
  57. package/dist/esm/index156.js +7 -33
  58. package/dist/esm/index157.js +24 -26
  59. package/dist/esm/index158.js +28 -24
  60. package/dist/esm/index159.js +64 -3
  61. package/dist/esm/index160.js +9 -14
  62. package/dist/esm/index161.js +31 -101
  63. package/dist/esm/index162.js +26 -63
  64. package/dist/esm/index163.js +24 -5
  65. package/dist/esm/index164.js +3 -6
  66. package/dist/esm/index165.js +14 -27
  67. package/dist/esm/index166.js +103 -39
  68. package/dist/esm/index167.js +64 -13
  69. package/dist/esm/index168.js +5 -42
  70. package/dist/esm/index169.js +6 -5
  71. package/dist/esm/index170.js +27 -11
  72. package/dist/esm/index171.js +39 -19
  73. package/dist/esm/index172.js +13 -78
  74. package/dist/esm/index173.js +43 -2
  75. package/dist/esm/index174.js +5 -37
  76. package/dist/esm/index175.js +11 -110
  77. package/dist/esm/index176.js +19 -48
  78. package/dist/esm/index177.js +76 -30
  79. package/dist/esm/index178.js +2 -9
  80. package/dist/esm/index179.js +37 -6
  81. package/dist/esm/index18.js +2 -2
  82. package/dist/esm/index180.js +110 -6
  83. package/dist/esm/index181.js +48 -11
  84. package/dist/esm/index182.js +31 -9
  85. package/dist/esm/index183.js +8 -13
  86. package/dist/esm/index184.js +6 -32
  87. package/dist/esm/index185.js +7 -5
  88. package/dist/esm/index186.js +11 -8
  89. package/dist/esm/index187.js +10 -19
  90. package/dist/esm/index188.js +13 -31
  91. package/dist/esm/index189.js +31 -19
  92. package/dist/esm/index19.js +2 -2
  93. package/dist/esm/index190.js +5 -4
  94. package/dist/esm/index191.js +8 -17
  95. package/dist/esm/index192.js +19 -10
  96. package/dist/esm/index193.js +30 -20
  97. package/dist/esm/index194.js +19 -21
  98. package/dist/esm/index195.js +3 -5
  99. package/dist/esm/index196.js +17 -5
  100. package/dist/esm/index197.js +10 -8
  101. package/dist/esm/index198.js +18 -101
  102. package/dist/esm/index199.js +23 -3
  103. package/dist/esm/index20.js +5 -5
  104. package/dist/esm/index200.js +4 -17
  105. package/dist/esm/index201.js +5 -171
  106. package/dist/esm/index202.js +8 -17
  107. package/dist/esm/index203.js +105 -10
  108. package/dist/esm/index204.js +3 -39
  109. package/dist/esm/index205.js +19 -2
  110. package/dist/esm/index206.js +171 -69
  111. package/dist/esm/index207.js +17 -34
  112. package/dist/esm/index208.js +10 -21
  113. package/dist/esm/index209.js +2 -41
  114. package/dist/esm/index21.js +2 -2
  115. package/dist/esm/index210.js +41 -2
  116. package/dist/esm/index211.js +2 -5
  117. package/dist/esm/index212.js +4 -10
  118. package/dist/esm/index213.js +9 -18
  119. package/dist/esm/index214.js +19 -7
  120. package/dist/esm/index215.js +7 -11
  121. package/dist/esm/index216.js +11 -66
  122. package/dist/esm/index217.js +65 -64
  123. package/dist/esm/index218.js +60 -180
  124. package/dist/esm/index219.js +183 -20
  125. package/dist/esm/index22.js +2 -2
  126. package/dist/esm/index220.js +21 -41
  127. package/dist/esm/index221.js +20 -54
  128. package/dist/esm/index222.js +54 -18
  129. package/dist/esm/index223.js +34 -10
  130. package/dist/esm/index224.js +10 -7
  131. package/dist/esm/index225.js +13 -7
  132. package/dist/esm/index226.js +7 -6
  133. package/dist/esm/index227.js +6 -36
  134. package/dist/esm/index228.js +35 -14
  135. package/dist/esm/index229.js +15 -8
  136. package/dist/esm/index230.js +7 -11
  137. package/dist/esm/index231.js +12 -9
  138. package/dist/esm/index232.js +9 -16
  139. package/dist/esm/index233.js +15 -21
  140. package/dist/esm/index234.js +22 -30
  141. package/dist/esm/index235.js +31 -2
  142. package/dist/esm/index236.js +2 -14
  143. package/dist/esm/index237.js +13 -12
  144. package/dist/esm/index238.js +10 -45
  145. package/dist/esm/index239.js +47 -9
  146. package/dist/esm/index24.js +37 -31
  147. package/dist/esm/index240.js +8 -12
  148. package/dist/esm/index241.js +13 -14
  149. package/dist/esm/index242.js +14 -8
  150. package/dist/esm/index243.js +6 -13
  151. package/dist/esm/index244.js +15 -24
  152. package/dist/esm/index245.js +24 -11
  153. package/dist/esm/index246.js +10 -23
  154. package/dist/esm/index247.js +24 -51
  155. package/dist/esm/index248.js +51 -17
  156. package/dist/esm/index249.js +17 -14
  157. package/dist/esm/index25.js +2 -4
  158. package/dist/esm/index250.js +14 -11
  159. package/dist/esm/index251.js +11 -103
  160. package/dist/esm/index252.js +103 -6
  161. package/dist/esm/index253.js +5 -223
  162. package/dist/esm/index254.js +224 -6
  163. package/dist/esm/index255.js +7 -7
  164. package/dist/esm/index256.js +7 -27
  165. package/dist/esm/index257.js +25 -18
  166. package/dist/esm/index258.js +18 -145
  167. package/dist/esm/index259.js +146 -12
  168. package/dist/esm/index26.js +69 -9
  169. package/dist/esm/index260.js +12 -35
  170. package/dist/esm/index261.js +35 -41
  171. package/dist/esm/index262.js +42 -2
  172. package/dist/esm/index263.js +3 -68
  173. package/dist/esm/index264.js +68 -3
  174. package/dist/esm/index265.js +3 -136
  175. package/dist/esm/index266.js +125 -144
  176. package/dist/esm/index267.js +155 -9
  177. package/dist/esm/index268.js +9 -16
  178. package/dist/esm/index269.js +16 -113
  179. package/dist/esm/index27.js +34 -68
  180. package/dist/esm/index270.js +95 -116
  181. package/dist/esm/index271.js +126 -70
  182. package/dist/esm/index272.js +79 -2
  183. package/dist/esm/index273.js +2 -699
  184. package/dist/esm/index274.js +685 -126
  185. package/dist/esm/index275.js +138 -41
  186. package/dist/esm/index276.js +40 -199
  187. package/dist/esm/index277.js +201 -3
  188. package/dist/esm/index28.js +19 -8
  189. package/dist/esm/index280.js +1 -1
  190. package/dist/esm/index281.js +2 -2
  191. package/dist/esm/index285.js +2 -2
  192. package/dist/esm/index286.js +1 -1
  193. package/dist/esm/index29.js +31 -27
  194. package/dist/esm/index30.js +3 -70
  195. package/dist/esm/index31.js +9 -19
  196. package/dist/esm/index32.js +68 -110
  197. package/dist/esm/index33.js +7 -58
  198. package/dist/esm/index34.js +27 -23
  199. package/dist/esm/index35.js +70 -40
  200. package/dist/esm/index36.js +19 -37
  201. package/dist/esm/index37.js +110 -58
  202. package/dist/esm/index38.js +57 -160
  203. package/dist/esm/index39.js +21 -36
  204. package/dist/esm/index40.js +40 -9
  205. package/dist/esm/index41.js +34 -28
  206. package/dist/esm/index42.js +58 -36
  207. package/dist/esm/index43.js +162 -8
  208. package/dist/esm/index44.js +35 -25
  209. package/dist/esm/index45.js +9 -46
  210. package/dist/esm/index46.js +31 -88
  211. package/dist/esm/index47.js +36 -40
  212. package/dist/esm/index48.js +8 -7
  213. package/dist/esm/index49.js +28 -5
  214. package/dist/esm/index50.js +46 -16
  215. package/dist/esm/index51.js +88 -8
  216. package/dist/esm/index52.js +40 -13
  217. package/dist/esm/index53.js +8 -7
  218. package/dist/esm/index54.js +6 -9
  219. package/dist/esm/index55.js +16 -16
  220. package/dist/esm/index56.js +8 -46
  221. package/dist/esm/index57.js +13 -13
  222. package/dist/esm/index58.js +7 -16
  223. package/dist/esm/index59.js +9 -13
  224. package/dist/esm/index60.js +15 -5
  225. package/dist/esm/index61.js +46 -35
  226. package/dist/esm/index62.js +13 -9
  227. package/dist/esm/index63.js +15 -7
  228. package/dist/esm/index64.js +13 -25
  229. package/dist/esm/index65.js +6 -10
  230. package/dist/esm/index66.js +32 -11
  231. package/dist/esm/index67.js +9 -11
  232. package/dist/esm/index68.js +8 -116
  233. package/dist/esm/index69.js +24 -32
  234. package/dist/esm/index70.js +10 -79
  235. package/dist/esm/index71.js +13 -176
  236. package/dist/esm/index72.js +11 -44
  237. package/dist/esm/index73.js +116 -6
  238. package/dist/esm/index74.js +32 -12
  239. package/dist/esm/index75.js +79 -13
  240. package/dist/esm/index76.js +173 -95
  241. package/dist/esm/index77.js +42 -70
  242. package/dist/esm/index78.js +6 -87
  243. package/dist/esm/index79.js +13 -148
  244. package/dist/esm/index80.js +13 -136
  245. package/dist/esm/index81.js +94 -63
  246. package/dist/esm/index82.js +72 -23
  247. package/dist/esm/index83.js +83 -101
  248. package/dist/esm/index84.js +148 -6
  249. package/dist/esm/index85.js +133 -128
  250. package/dist/esm/index86.js +66 -273
  251. package/dist/esm/index87.js +24 -3
  252. package/dist/esm/index88.js +106 -4
  253. package/dist/esm/index89.js +7 -9
  254. package/dist/esm/index90.js +132 -2
  255. package/dist/esm/index91.js +276 -2
  256. package/dist/esm/index92.js +3 -3
  257. package/dist/esm/index93.js +4 -327
  258. package/dist/esm/index94.js +9 -14
  259. package/dist/esm/index95.js +2 -5
  260. package/dist/esm/index96.js +2 -56
  261. package/dist/esm/index97.js +3 -2
  262. package/dist/esm/index98.js +325 -6
  263. package/dist/esm/index99.js +11 -212
  264. package/package.json +3 -3
@@ -1,30 +1,163 @@
1
- import { InvalidBytesBooleanError as f } from "./index112.js";
2
- import { trim as o } from "./index136.js";
3
- import { assertSize as r, hexToNumber as s, hexToBigInt as u } from "./index156.js";
4
- import { bytesToHex as t } from "./index123.js";
5
- function c(n, i = {}) {
6
- typeof i.size < "u" && r(n, { size: i.size });
7
- const e = t(n, i);
8
- return u(e, i);
9
- }
10
- function T(n, i = {}) {
11
- let e = n;
12
- if (typeof i.size < "u" && (r(e, { size: i.size }), e = o(e)), e.length > 1 || e[0] > 1)
13
- throw new f(e);
14
- return !!e[0];
15
- }
16
- function b(n, i = {}) {
17
- typeof i.size < "u" && r(n, { size: i.size });
18
- const e = t(n, i);
19
- return s(e, i);
20
- }
21
- function h(n, i = {}) {
22
- let e = n;
23
- return typeof i.size < "u" && (r(e, { size: i.size }), e = o(e, { dir: "right" })), new TextDecoder().decode(e);
1
+ import { AbiDecodingZeroDataError as a, AbiDecodingDataSizeTooSmallError as C, InvalidAbiDecodingTypeError as D } from "./index98.js";
2
+ import { checksumAddress as w } from "./index138.js";
3
+ import { createCursor as _ } from "./index139.js";
4
+ import { size as p } from "./index100.js";
5
+ import { sliceBytes as W } from "./index140.js";
6
+ import { trim as x } from "./index141.js";
7
+ import { bytesToNumber as y, bytesToBool as I, bytesToBigInt as N, bytesToString as O } from "./index142.js";
8
+ import { hexToBytes as S } from "./index127.js";
9
+ import { bytesToHex as g } from "./index128.js";
10
+ import { getArrayComponents as A } from "./index143.js";
11
+ function Y(t, e) {
12
+ const n = typeof e == "string" ? S(e) : e, i = _(n);
13
+ if (p(n) === 0 && t.length > 0)
14
+ throw new a();
15
+ if (p(e) && p(e) < 32)
16
+ throw new C({
17
+ data: typeof e == "string" ? e : g(e),
18
+ params: t,
19
+ size: p(e)
20
+ });
21
+ let s = 0;
22
+ const d = [];
23
+ for (let o = 0; o < t.length; ++o) {
24
+ const r = t[o];
25
+ i.setPosition(s);
26
+ const [f, c] = u(i, r, {
27
+ staticPosition: 0
28
+ });
29
+ s += c, d.push(f);
30
+ }
31
+ return d;
32
+ }
33
+ function u(t, e, { staticPosition: n }) {
34
+ const i = A(e.type);
35
+ if (i) {
36
+ const [s, d] = i;
37
+ return k(t, { ...e, type: d }, { length: s, staticPosition: n });
38
+ }
39
+ if (e.type === "tuple")
40
+ return Z(t, e, { staticPosition: n });
41
+ if (e.type === "address")
42
+ return E(t);
43
+ if (e.type === "bool")
44
+ return H(t);
45
+ if (e.type.startsWith("bytes"))
46
+ return L(t, e, { staticPosition: n });
47
+ if (e.type.startsWith("uint") || e.type.startsWith("int"))
48
+ return U(t, e);
49
+ if (e.type === "string")
50
+ return j(t, { staticPosition: n });
51
+ throw new D(e.type, {
52
+ docsPath: "/docs/contract/decodeAbiParameters"
53
+ });
54
+ }
55
+ const P = 32, b = 32;
56
+ function E(t) {
57
+ const e = t.readBytes(32);
58
+ return [w(g(W(e, -20))), 32];
59
+ }
60
+ function k(t, e, { length: n, staticPosition: i }) {
61
+ if (!n) {
62
+ const o = y(t.readBytes(b)), r = i + o, f = r + P;
63
+ t.setPosition(r);
64
+ const c = y(t.readBytes(P)), l = m(e);
65
+ let h = 0;
66
+ const v = [];
67
+ for (let B = 0; B < c; ++B) {
68
+ t.setPosition(f + (l ? B * 32 : h));
69
+ const [T, z] = u(t, e, {
70
+ staticPosition: f
71
+ });
72
+ h += z, v.push(T);
73
+ }
74
+ return t.setPosition(i + 32), [v, 32];
75
+ }
76
+ if (m(e)) {
77
+ const o = y(t.readBytes(b)), r = i + o, f = [];
78
+ for (let c = 0; c < n; ++c) {
79
+ t.setPosition(r + c * 32);
80
+ const [l] = u(t, e, {
81
+ staticPosition: r
82
+ });
83
+ f.push(l);
84
+ }
85
+ return t.setPosition(i + 32), [f, 32];
86
+ }
87
+ let s = 0;
88
+ const d = [];
89
+ for (let o = 0; o < n; ++o) {
90
+ const [r, f] = u(t, e, {
91
+ staticPosition: i + s
92
+ });
93
+ s += f, d.push(r);
94
+ }
95
+ return [d, s];
96
+ }
97
+ function H(t) {
98
+ return [I(t.readBytes(32), { size: 32 }), 32];
99
+ }
100
+ function L(t, e, { staticPosition: n }) {
101
+ const [i, s] = e.type.split("bytes");
102
+ if (!s) {
103
+ const o = y(t.readBytes(32));
104
+ t.setPosition(n + o);
105
+ const r = y(t.readBytes(32));
106
+ if (r === 0)
107
+ return t.setPosition(n + 32), ["0x", 32];
108
+ const f = t.readBytes(r);
109
+ return t.setPosition(n + 32), [g(f), 32];
110
+ }
111
+ return [g(t.readBytes(Number.parseInt(s), 32)), 32];
112
+ }
113
+ function U(t, e) {
114
+ const n = e.type.startsWith("int"), i = Number.parseInt(e.type.split("int")[1] || "256"), s = t.readBytes(32);
115
+ return [
116
+ i > 48 ? N(s, { signed: n }) : y(s, { signed: n }),
117
+ 32
118
+ ];
119
+ }
120
+ function Z(t, e, { staticPosition: n }) {
121
+ const i = e.components.length === 0 || e.components.some(({ name: o }) => !o), s = i ? [] : {};
122
+ let d = 0;
123
+ if (m(e)) {
124
+ const o = y(t.readBytes(b)), r = n + o;
125
+ for (let f = 0; f < e.components.length; ++f) {
126
+ const c = e.components[f];
127
+ t.setPosition(r + d);
128
+ const [l, h] = u(t, c, {
129
+ staticPosition: r
130
+ });
131
+ d += h, s[i ? f : c?.name] = l;
132
+ }
133
+ return t.setPosition(n + 32), [s, 32];
134
+ }
135
+ for (let o = 0; o < e.components.length; ++o) {
136
+ const r = e.components[o], [f, c] = u(t, r, {
137
+ staticPosition: n
138
+ });
139
+ s[i ? o : r?.name] = f, d += c;
140
+ }
141
+ return [s, d];
142
+ }
143
+ function j(t, { staticPosition: e }) {
144
+ const n = y(t.readBytes(32)), i = e + n;
145
+ t.setPosition(i);
146
+ const s = y(t.readBytes(32));
147
+ if (s === 0)
148
+ return t.setPosition(e + 32), ["", 32];
149
+ const d = t.readBytes(s, 32), o = O(x(d));
150
+ return t.setPosition(e + 32), [o, 32];
151
+ }
152
+ function m(t) {
153
+ const { type: e } = t;
154
+ if (e === "string" || e === "bytes" || e.endsWith("[]"))
155
+ return !0;
156
+ if (e === "tuple")
157
+ return t.components?.some(m);
158
+ const n = A(t.type);
159
+ return !!(n && m({ ...t, type: n[1] }));
24
160
  }
25
161
  export {
26
- c as bytesToBigInt,
27
- T as bytesToBool,
28
- b as bytesToNumber,
29
- h as bytesToString
162
+ Y as decodeAbiParameters
30
163
  };
@@ -1,194 +1,24 @@
1
- import { AbiEncodingLengthMismatchError as y, InvalidAbiEncodingTypeError as u, InvalidArrayError as g, AbiEncodingArrayLengthMismatchError as l, AbiEncodingBytesSizeMismatchError as b } from "./index93.js";
2
- import { InvalidAddressError as w } from "./index118.js";
3
- import { BaseError as A } from "./index96.js";
4
- import { IntegerOutOfRangeError as x } from "./index112.js";
5
- import { isAddress as z } from "./index145.js";
6
- import { concat as f } from "./index127.js";
7
- import { padHex as d } from "./index146.js";
8
- import { size as a } from "./index95.js";
9
- import { slice as E } from "./index135.js";
10
- import { numberToHex as m, boolToHex as P, stringToHex as S } from "./index123.js";
11
- import { integerRegex as I } from "./index147.js";
12
- function K(e, t) {
13
- if (e.length !== t.length)
14
- throw new y({
15
- expectedLength: e.length,
16
- givenLength: t.length
17
- });
18
- const o = L({
19
- params: e,
20
- values: t
21
- }), n = h(o);
22
- return n.length === 0 ? "0x" : n;
23
- }
24
- function L({ params: e, values: t }) {
25
- const o = [];
26
- for (let n = 0; n < e.length; n++)
27
- o.push(p({ param: e[n], value: t[n] }));
28
- return o;
29
- }
30
- function p({ param: e, value: t }) {
31
- const o = W(e.type);
32
- if (o) {
33
- const [n, r] = o;
34
- return M(t, { length: n, param: { ...e, type: r } });
35
- }
36
- if (e.type === "tuple")
37
- return H(t, {
38
- param: e
39
- });
40
- if (e.type === "address")
41
- return B(t);
42
- if (e.type === "bool")
43
- return T(t);
44
- if (e.type.startsWith("uint") || e.type.startsWith("int")) {
45
- const n = e.type.startsWith("int"), [, , r = "256"] = I.exec(e.type) ?? [];
46
- return $(t, {
47
- signed: n,
48
- size: Number(r)
49
- });
50
- }
51
- if (e.type.startsWith("bytes"))
52
- return N(t, { param: e });
53
- if (e.type === "string")
54
- return C(t);
55
- throw new u(e.type, {
56
- docsPath: "/docs/contract/encodeAbiParameters"
57
- });
58
- }
59
- function h(e) {
60
- let t = 0;
61
- for (let i = 0; i < e.length; i++) {
62
- const { dynamic: c, encoded: s } = e[i];
63
- c ? t += 32 : t += a(s);
64
- }
65
- const o = [], n = [];
66
- let r = 0;
67
- for (let i = 0; i < e.length; i++) {
68
- const { dynamic: c, encoded: s } = e[i];
69
- c ? (o.push(m(t + r, { size: 32 })), n.push(s), r += a(s)) : o.push(s);
70
- }
71
- return f([...o, ...n]);
72
- }
73
- function B(e) {
74
- if (!z(e))
75
- throw new w({ address: e });
76
- return { dynamic: !1, encoded: d(e.toLowerCase()) };
77
- }
78
- function M(e, { length: t, param: o }) {
79
- const n = t === null;
80
- if (!Array.isArray(e))
81
- throw new g(e);
82
- if (!n && e.length !== t)
83
- throw new l({
84
- expectedLength: t,
85
- givenLength: e.length,
86
- type: `${o.type}[${t}]`
87
- });
88
- let r = !1;
89
- const i = [];
90
- for (let c = 0; c < e.length; c++) {
91
- const s = p({ param: o, value: e[c] });
92
- s.dynamic && (r = !0), i.push(s);
93
- }
94
- if (n || r) {
95
- const c = h(i);
96
- if (n) {
97
- const s = m(i.length, { size: 32 });
98
- return {
99
- dynamic: !0,
100
- encoded: i.length > 0 ? f([s, c]) : s
101
- };
102
- }
103
- if (r)
104
- return { dynamic: !0, encoded: c };
105
- }
106
- return {
107
- dynamic: !1,
108
- encoded: f(i.map(({ encoded: c }) => c))
109
- };
110
- }
111
- function N(e, { param: t }) {
112
- const [, o] = t.type.split("bytes"), n = a(e);
113
- if (!o) {
114
- let r = e;
115
- return n % 32 !== 0 && (r = d(r, {
116
- dir: "right",
117
- size: Math.ceil((e.length - 2) / 2 / 32) * 32
118
- })), {
119
- dynamic: !0,
120
- encoded: f([d(m(n, { size: 32 })), r])
121
- };
122
- }
123
- if (n !== Number.parseInt(o))
124
- throw new b({
125
- expectedSize: Number.parseInt(o),
126
- value: e
127
- });
128
- return { dynamic: !1, encoded: d(e, { dir: "right" }) };
129
- }
130
- function T(e) {
131
- if (typeof e != "boolean")
132
- throw new A(`Invalid boolean value: "${e}" (type: ${typeof e}). Expected: \`true\` or \`false\`.`);
133
- return { dynamic: !1, encoded: d(P(e)) };
134
- }
135
- function $(e, { signed: t, size: o = 256 }) {
136
- if (typeof o == "number") {
137
- const n = 2n ** (BigInt(o) - (t ? 1n : 0n)) - 1n, r = t ? -n - 1n : 0n;
138
- if (e > n || e < r)
139
- throw new x({
140
- max: n.toString(),
141
- min: r.toString(),
142
- signed: t,
143
- size: o / 8,
144
- value: e.toString()
145
- });
146
- }
147
- return {
148
- dynamic: !1,
149
- encoded: m(e, {
150
- size: 32,
151
- signed: t
152
- })
153
- };
154
- }
155
- function C(e) {
156
- const t = S(e), o = Math.ceil(a(t) / 32), n = [];
157
- for (let r = 0; r < o; r++)
158
- n.push(d(E(t, r * 32, (r + 1) * 32), {
159
- dir: "right"
160
- }));
161
- return {
162
- dynamic: !0,
163
- encoded: f([
164
- d(m(a(t), { size: 32 })),
165
- ...n
166
- ])
167
- };
168
- }
169
- function H(e, { param: t }) {
170
- let o = !1;
171
- const n = [];
172
- for (let r = 0; r < t.components.length; r++) {
173
- const i = t.components[r], c = Array.isArray(e) ? r : i.name, s = p({
174
- param: i,
175
- value: e[c]
176
- });
177
- n.push(s), s.dynamic && (o = !0);
178
- }
179
- return {
180
- dynamic: o,
181
- encoded: o ? h(n) : f(n.map(({ encoded: r }) => r))
182
- };
183
- }
184
- function W(e) {
185
- const t = e.match(/^(.*)\[(\d+)?\]$/);
186
- return t ? (
187
- // Return `null` if the array is dynamic.
188
- [t[2] ? Number(t[2]) : null, t[1]]
189
- ) : void 0;
1
+ import { InvalidAddressError as c } from "./index123.js";
2
+ import { stringToBytes as m } from "./index127.js";
3
+ import { keccak256 as p } from "./index129.js";
4
+ import { LruMap as u } from "./index198.js";
5
+ import { isAddress as $ } from "./index150.js";
6
+ const s = /* @__PURE__ */ new u(8192);
7
+ function h(t, o) {
8
+ if (s.has(`${t}.${o}`))
9
+ return s.get(`${t}.${o}`);
10
+ const i = t.substring(2).toLowerCase(), n = p(m(i), "bytes"), e = i.split("");
11
+ for (let r = 0; r < 40; r += 2)
12
+ n[r >> 1] >> 4 >= 8 && e[r] && (e[r] = e[r].toUpperCase()), (n[r >> 1] & 15) >= 8 && e[r + 1] && (e[r + 1] = e[r + 1].toUpperCase());
13
+ const f = `0x${e.join("")}`;
14
+ return s.set(`${t}.${o}`, f), f;
15
+ }
16
+ function w(t, o) {
17
+ if (!$(t, { strict: !1 }))
18
+ throw new c({ address: t });
19
+ return h(t, o);
190
20
  }
191
21
  export {
192
- K as encodeAbiParameters,
193
- W as getArrayComponents
22
+ h as checksumAddress,
23
+ w as getAddress
194
24
  };
@@ -1,6 +1,130 @@
1
- import { slice as t } from "./index135.js";
2
- import { toSignatureHash as r } from "./index195.js";
3
- const c = (o) => t(r(o), 0, 4);
1
+ import { NegativeOffsetError as o, PositionOutOfBoundsError as e, RecursiveReadLimitExceededError as n } from "./index147.js";
2
+ const h = {
3
+ bytes: new Uint8Array(),
4
+ dataView: new DataView(new ArrayBuffer(0)),
5
+ position: 0,
6
+ positionReadCount: /* @__PURE__ */ new Map(),
7
+ recursiveReadCount: 0,
8
+ recursiveReadLimit: Number.POSITIVE_INFINITY,
9
+ assertReadLimit() {
10
+ if (this.recursiveReadCount >= this.recursiveReadLimit)
11
+ throw new n({
12
+ count: this.recursiveReadCount + 1,
13
+ limit: this.recursiveReadLimit
14
+ });
15
+ },
16
+ assertPosition(t) {
17
+ if (t < 0 || t > this.bytes.length - 1)
18
+ throw new e({
19
+ length: this.bytes.length,
20
+ position: t
21
+ });
22
+ },
23
+ decrementPosition(t) {
24
+ if (t < 0)
25
+ throw new o({ offset: t });
26
+ const i = this.position - t;
27
+ this.assertPosition(i), this.position = i;
28
+ },
29
+ getReadCount(t) {
30
+ return this.positionReadCount.get(t || this.position) || 0;
31
+ },
32
+ incrementPosition(t) {
33
+ if (t < 0)
34
+ throw new o({ offset: t });
35
+ const i = this.position + t;
36
+ this.assertPosition(i), this.position = i;
37
+ },
38
+ inspectByte(t) {
39
+ const i = t ?? this.position;
40
+ return this.assertPosition(i), this.bytes[i];
41
+ },
42
+ inspectBytes(t, i) {
43
+ const s = i ?? this.position;
44
+ return this.assertPosition(s + t - 1), this.bytes.subarray(s, s + t);
45
+ },
46
+ inspectUint8(t) {
47
+ const i = t ?? this.position;
48
+ return this.assertPosition(i), this.bytes[i];
49
+ },
50
+ inspectUint16(t) {
51
+ const i = t ?? this.position;
52
+ return this.assertPosition(i + 1), this.dataView.getUint16(i);
53
+ },
54
+ inspectUint24(t) {
55
+ const i = t ?? this.position;
56
+ return this.assertPosition(i + 2), (this.dataView.getUint16(i) << 8) + this.dataView.getUint8(i + 2);
57
+ },
58
+ inspectUint32(t) {
59
+ const i = t ?? this.position;
60
+ return this.assertPosition(i + 3), this.dataView.getUint32(i);
61
+ },
62
+ pushByte(t) {
63
+ this.assertPosition(this.position), this.bytes[this.position] = t, this.position++;
64
+ },
65
+ pushBytes(t) {
66
+ this.assertPosition(this.position + t.length - 1), this.bytes.set(t, this.position), this.position += t.length;
67
+ },
68
+ pushUint8(t) {
69
+ this.assertPosition(this.position), this.bytes[this.position] = t, this.position++;
70
+ },
71
+ pushUint16(t) {
72
+ this.assertPosition(this.position + 1), this.dataView.setUint16(this.position, t), this.position += 2;
73
+ },
74
+ pushUint24(t) {
75
+ this.assertPosition(this.position + 2), this.dataView.setUint16(this.position, t >> 8), this.dataView.setUint8(this.position + 2, t & 255), this.position += 3;
76
+ },
77
+ pushUint32(t) {
78
+ this.assertPosition(this.position + 3), this.dataView.setUint32(this.position, t), this.position += 4;
79
+ },
80
+ readByte() {
81
+ this.assertReadLimit(), this._touch();
82
+ const t = this.inspectByte();
83
+ return this.position++, t;
84
+ },
85
+ readBytes(t, i) {
86
+ this.assertReadLimit(), this._touch();
87
+ const s = this.inspectBytes(t);
88
+ return this.position += i ?? t, s;
89
+ },
90
+ readUint8() {
91
+ this.assertReadLimit(), this._touch();
92
+ const t = this.inspectUint8();
93
+ return this.position += 1, t;
94
+ },
95
+ readUint16() {
96
+ this.assertReadLimit(), this._touch();
97
+ const t = this.inspectUint16();
98
+ return this.position += 2, t;
99
+ },
100
+ readUint24() {
101
+ this.assertReadLimit(), this._touch();
102
+ const t = this.inspectUint24();
103
+ return this.position += 3, t;
104
+ },
105
+ readUint32() {
106
+ this.assertReadLimit(), this._touch();
107
+ const t = this.inspectUint32();
108
+ return this.position += 4, t;
109
+ },
110
+ get remaining() {
111
+ return this.bytes.length - this.position;
112
+ },
113
+ setPosition(t) {
114
+ const i = this.position;
115
+ return this.assertPosition(t), this.position = t, () => this.position = i;
116
+ },
117
+ _touch() {
118
+ if (this.recursiveReadLimit === Number.POSITIVE_INFINITY)
119
+ return;
120
+ const t = this.getReadCount();
121
+ this.positionReadCount.set(this.position, t + 1), t > 0 && this.recursiveReadCount++;
122
+ }
123
+ };
124
+ function a(t, { recursiveReadLimit: i = 8192 } = {}) {
125
+ const s = Object.create(h);
126
+ return s.bytes = t, s.dataView = new DataView(t.buffer, t.byteOffset, t.byteLength), s.positionReadCount = /* @__PURE__ */ new Map(), s.recursiveReadLimit = i, s;
127
+ }
4
128
  export {
5
- c as toFunctionSelector
129
+ a as createCursor
6
130
  };
@@ -1,67 +1,41 @@
1
- import { AbiEventSignatureEmptyTopicsError as A, AbiEventSignatureNotFoundError as x, DecodeLogTopicsMismatch as D, AbiDecodingDataSizeTooSmallError as I, DecodeLogDataMismatch as h } from "./index93.js";
2
- import { size as S } from "./index95.js";
3
- import { toEventSelector as T } from "./index141.js";
4
- import { PositionOutOfBoundsError as z } from "./index142.js";
5
- import { decodeAbiParameters as w } from "./index132.js";
6
- import { formatAbiItem as L } from "./index94.js";
7
- const l = "/docs/contract/decodeEventLog";
8
- function U(n) {
9
- const { abi: c, data: i, strict: E, topics: b } = n, m = E ?? !0, [a, ...v] = b;
10
- if (!a)
11
- throw new A({ docsPath: l });
12
- const o = c.find((e) => e.type === "event" && a === T(L(e)));
13
- if (!(o && "name" in o) || o.type !== "event")
14
- throw new x(a, { docsPath: l });
15
- const { name: y, inputs: d } = o, f = d?.some((e) => !("name" in e && e.name)), r = f ? [] : {}, p = d.map((e, t) => [e, t]).filter(([e]) => "indexed" in e && e.indexed);
16
- for (let e = 0; e < p.length; e++) {
17
- const [t, g] = p[e], u = v[e];
18
- if (!u)
19
- throw new D({
20
- abiItem: o,
21
- param: t
22
- });
23
- r[f ? g : t.name || g] = O({
24
- param: t,
25
- value: u
1
+ import { SliceOffsetOutOfBoundsError as t } from "./index124.js";
2
+ import { isHex as p } from "./index164.js";
3
+ import { size as r } from "./index100.js";
4
+ function w(e, f, i, { strict: o } = {}) {
5
+ return p(e, { strict: !1 }) ? u(e, f, i, {
6
+ strict: o
7
+ }) : m(e, f, i, {
8
+ strict: o
9
+ });
10
+ }
11
+ function s(e, f) {
12
+ if (typeof f == "number" && f > 0 && f > r(e) - 1)
13
+ throw new t({
14
+ offset: f,
15
+ position: "start",
16
+ size: r(e)
17
+ });
18
+ }
19
+ function c(e, f, i) {
20
+ if (typeof f == "number" && typeof i == "number" && r(e) !== i - f)
21
+ throw new t({
22
+ offset: i,
23
+ position: "end",
24
+ size: r(e)
26
25
  });
27
- }
28
- const s = d.filter((e) => !("indexed" in e && e.indexed));
29
- if (s.length > 0) {
30
- if (i && i !== "0x")
31
- try {
32
- const e = w(s, i);
33
- if (e)
34
- if (f)
35
- for (let t = 0; t < d.length; t++)
36
- r[t] = r[t] ?? e.shift();
37
- else
38
- for (let t = 0; t < s.length; t++)
39
- r[s[t].name] = e[t];
40
- } catch (e) {
41
- if (m)
42
- throw e instanceof I || e instanceof z ? new h({
43
- abiItem: o,
44
- data: i,
45
- params: s,
46
- size: S(i)
47
- }) : e;
48
- }
49
- else if (m)
50
- throw new h({
51
- abiItem: o,
52
- data: "0x",
53
- params: s,
54
- size: 0
55
- });
56
- }
57
- return {
58
- eventName: y,
59
- args: Object.values(r).length > 0 ? r : void 0
60
- };
61
26
  }
62
- function O({ param: n, value: c }) {
63
- return n.type === "string" || n.type === "bytes" || n.type === "tuple" || n.type.match(/^(.*)\[(\d+)?\]$/) ? c : (w([n], c) || [])[0];
27
+ function m(e, f, i, { strict: o } = {}) {
28
+ s(e, f);
29
+ const n = e.slice(f, i);
30
+ return o && c(n, f, i), n;
31
+ }
32
+ function u(e, f, i, { strict: o } = {}) {
33
+ s(e, f);
34
+ const n = `0x${e.replace("0x", "").slice((f ?? 0) * 2, (i ?? e.length) * 2)}`;
35
+ return o && c(n, f, i), n;
64
36
  }
65
37
  export {
66
- U as decodeEventLog
38
+ w as slice,
39
+ m as sliceBytes,
40
+ u as sliceHex
67
41
  };
@@ -1,5 +1,9 @@
1
- import { toSignatureHash as t } from "./index195.js";
2
- const e = t;
1
+ function f(e, { dir: n = "left" } = {}) {
2
+ let t = typeof e == "string" ? e.replace("0x", "") : e, i = 0;
3
+ for (let l = 0; l < t.length - 1 && t[n === "left" ? l : t.length - l - 1].toString() === "0"; l++)
4
+ i++;
5
+ return t = n === "left" ? t.slice(i) : t.slice(0, t.length - i), typeof e == "string" ? (t.length === 1 && n === "right" && (t = `${t}0`), `0x${t.length % 2 === 1 ? `0${t}` : t}`) : t;
6
+ }
3
7
  export {
4
- e as toEventSelector
8
+ f as trim
5
9
  };