@coinbase/cdp-hooks 0.0.41 → 0.0.43

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 (273) hide show
  1. package/README.md +71 -0
  2. package/dist/esm/index.js +18 -16
  3. package/dist/esm/index10.js +56 -33
  4. package/dist/esm/index100.js +31 -32
  5. package/dist/esm/index101.js +32 -191
  6. package/dist/esm/index102.js +191 -6
  7. package/dist/esm/index103.js +9 -2
  8. package/dist/esm/index104.js +2 -13
  9. package/dist/esm/index105.js +11 -17
  10. package/dist/esm/index106.js +13 -22
  11. package/dist/esm/index107.js +27 -8
  12. package/dist/esm/index108.js +8 -55
  13. package/dist/esm/index109.js +50 -40
  14. package/dist/esm/index11.js +32 -3
  15. package/dist/esm/index110.js +45 -8
  16. package/dist/esm/index111.js +8 -7
  17. package/dist/esm/index112.js +7 -16
  18. package/dist/esm/index113.js +16 -18
  19. package/dist/esm/index114.js +18 -24
  20. package/dist/esm/index115.js +24 -16
  21. package/dist/esm/index116.js +16 -54
  22. package/dist/esm/index117.js +53 -10
  23. package/dist/esm/index118.js +11 -160
  24. package/dist/esm/index119.js +160 -21
  25. package/dist/esm/index12.js +3 -9
  26. package/dist/esm/index120.js +21 -127
  27. package/dist/esm/index121.js +127 -38
  28. package/dist/esm/index122.js +38 -6
  29. package/dist/esm/index123.js +6 -27
  30. package/dist/esm/index124.js +27 -191
  31. package/dist/esm/index125.js +192 -4
  32. package/dist/esm/index126.js +4 -65
  33. package/dist/esm/index127.js +65 -3
  34. package/dist/esm/index128.js +3 -21
  35. package/dist/esm/index129.js +19 -15
  36. package/dist/esm/index13.js +8 -67
  37. package/dist/esm/index130.js +16 -23
  38. package/dist/esm/index131.js +23 -11
  39. package/dist/esm/index132.js +11 -34
  40. package/dist/esm/index133.js +35 -3
  41. package/dist/esm/index134.js +3 -19
  42. package/dist/esm/index135.js +18 -27
  43. package/dist/esm/index136.js +25 -33
  44. package/dist/esm/index137.js +35 -7
  45. package/dist/esm/index138.js +7 -25
  46. package/dist/esm/index139.js +20 -23
  47. package/dist/esm/index14.js +66 -7
  48. package/dist/esm/index140.js +27 -63
  49. package/dist/esm/index141.js +64 -9
  50. package/dist/esm/index142.js +9 -33
  51. package/dist/esm/index143.js +33 -27
  52. package/dist/esm/index144.js +26 -23
  53. package/dist/esm/index145.js +24 -3
  54. package/dist/esm/index146.js +3 -14
  55. package/dist/esm/index147.js +14 -103
  56. package/dist/esm/index148.js +99 -60
  57. package/dist/esm/index149.js +64 -5
  58. package/dist/esm/index15.js +8 -27
  59. package/dist/esm/index150.js +5 -6
  60. package/dist/esm/index151.js +6 -27
  61. package/dist/esm/index152.js +27 -39
  62. package/dist/esm/index153.js +39 -13
  63. package/dist/esm/index154.js +13 -42
  64. package/dist/esm/index155.js +42 -5
  65. package/dist/esm/index156.js +5 -11
  66. package/dist/esm/index157.js +11 -19
  67. package/dist/esm/index158.js +18 -77
  68. package/dist/esm/index159.js +79 -2
  69. package/dist/esm/index16.js +25 -67
  70. package/dist/esm/index160.js +2 -38
  71. package/dist/esm/index161.js +32 -105
  72. package/dist/esm/index162.js +105 -43
  73. package/dist/esm/index163.js +47 -31
  74. package/dist/esm/index164.js +32 -8
  75. package/dist/esm/index165.js +8 -6
  76. package/dist/esm/index166.js +6 -6
  77. package/dist/esm/index167.js +6 -11
  78. package/dist/esm/index168.js +11 -10
  79. package/dist/esm/index169.js +10 -13
  80. package/dist/esm/index17.js +68 -17
  81. package/dist/esm/index170.js +12 -31
  82. package/dist/esm/index171.js +33 -5
  83. package/dist/esm/index172.js +5 -9
  84. package/dist/esm/index173.js +8 -19
  85. package/dist/esm/index174.js +19 -31
  86. package/dist/esm/index175.js +31 -20
  87. package/dist/esm/index176.js +20 -3
  88. package/dist/esm/index177.js +3 -17
  89. package/dist/esm/index178.js +17 -10
  90. package/dist/esm/index179.js +10 -21
  91. package/dist/esm/index18.js +17 -108
  92. package/dist/esm/index180.js +21 -22
  93. package/dist/esm/index181.js +22 -5
  94. package/dist/esm/index182.js +5 -5
  95. package/dist/esm/index183.js +5 -8
  96. package/dist/esm/index184.js +8 -104
  97. package/dist/esm/index185.js +105 -3
  98. package/dist/esm/index186.js +3 -19
  99. package/dist/esm/index187.js +17 -170
  100. package/dist/esm/index188.js +170 -16
  101. package/dist/esm/index189.js +18 -10
  102. package/dist/esm/index19.js +110 -60
  103. package/dist/esm/index190.js +10 -41
  104. package/dist/esm/index191.js +41 -2
  105. package/dist/esm/index192.js +2 -5
  106. package/dist/esm/index193.js +4 -10
  107. package/dist/esm/index194.js +9 -18
  108. package/dist/esm/index195.js +19 -7
  109. package/dist/esm/index196.js +7 -11
  110. package/dist/esm/index197.js +11 -66
  111. package/dist/esm/index198.js +65 -64
  112. package/dist/esm/index199.js +60 -180
  113. package/dist/esm/index20.js +56 -20
  114. package/dist/esm/index200.js +183 -20
  115. package/dist/esm/index201.js +21 -41
  116. package/dist/esm/index202.js +20 -54
  117. package/dist/esm/index203.js +54 -18
  118. package/dist/esm/index204.js +34 -10
  119. package/dist/esm/index205.js +10 -7
  120. package/dist/esm/index206.js +13 -7
  121. package/dist/esm/index207.js +7 -6
  122. package/dist/esm/index208.js +6 -36
  123. package/dist/esm/index209.js +35 -14
  124. package/dist/esm/index21.js +22 -38
  125. package/dist/esm/index210.js +15 -8
  126. package/dist/esm/index211.js +7 -11
  127. package/dist/esm/index212.js +12 -9
  128. package/dist/esm/index213.js +9 -16
  129. package/dist/esm/index214.js +15 -21
  130. package/dist/esm/index215.js +22 -30
  131. package/dist/esm/index216.js +31 -2
  132. package/dist/esm/index217.js +2 -14
  133. package/dist/esm/index218.js +13 -12
  134. package/dist/esm/index219.js +10 -45
  135. package/dist/esm/index22.js +37 -34
  136. package/dist/esm/index220.js +47 -9
  137. package/dist/esm/index221.js +8 -12
  138. package/dist/esm/index222.js +13 -14
  139. package/dist/esm/index223.js +14 -8
  140. package/dist/esm/index224.js +6 -13
  141. package/dist/esm/index225.js +15 -24
  142. package/dist/esm/index226.js +24 -11
  143. package/dist/esm/index227.js +10 -23
  144. package/dist/esm/index228.js +24 -51
  145. package/dist/esm/index229.js +51 -17
  146. package/dist/esm/index23.js +34 -55
  147. package/dist/esm/index230.js +17 -14
  148. package/dist/esm/index231.js +14 -11
  149. package/dist/esm/index232.js +11 -103
  150. package/dist/esm/index233.js +103 -6
  151. package/dist/esm/index234.js +5 -223
  152. package/dist/esm/index235.js +224 -6
  153. package/dist/esm/index236.js +7 -7
  154. package/dist/esm/index237.js +7 -27
  155. package/dist/esm/index238.js +25 -18
  156. package/dist/esm/index239.js +18 -145
  157. package/dist/esm/index24.js +55 -160
  158. package/dist/esm/index240.js +146 -12
  159. package/dist/esm/index241.js +12 -35
  160. package/dist/esm/index242.js +35 -41
  161. package/dist/esm/index243.js +41 -68
  162. package/dist/esm/index244.js +68 -3
  163. package/dist/esm/index245.js +3 -136
  164. package/dist/esm/index246.js +125 -144
  165. package/dist/esm/index247.js +155 -9
  166. package/dist/esm/index248.js +9 -16
  167. package/dist/esm/index249.js +16 -113
  168. package/dist/esm/index25.js +156 -32
  169. package/dist/esm/index250.js +95 -116
  170. package/dist/esm/index251.js +126 -70
  171. package/dist/esm/index252.js +79 -2
  172. package/dist/esm/index253.js +2 -699
  173. package/dist/esm/index254.js +685 -126
  174. package/dist/esm/index255.js +138 -41
  175. package/dist/esm/index256.js +40 -199
  176. package/dist/esm/index257.js +198 -62
  177. package/dist/esm/index258.js +65 -4
  178. package/dist/esm/index259.js +4 -40
  179. package/dist/esm/index26.js +39 -9
  180. package/dist/esm/index260.js +40 -7
  181. package/dist/esm/index261.js +7 -62
  182. package/dist/esm/index262.js +57 -72
  183. package/dist/esm/index263.js +78 -4
  184. package/dist/esm/index264.js +4 -195
  185. package/dist/esm/index265.js +183 -52
  186. package/dist/esm/index266.js +59 -40
  187. package/dist/esm/index267.js +44 -4
  188. package/dist/esm/index268.js +5 -5
  189. package/dist/esm/index269.js +5 -2
  190. package/dist/esm/index27.js +8 -30
  191. package/dist/esm/index270.js +2 -22
  192. package/dist/esm/index271.js +24 -0
  193. package/dist/esm/index28.js +21 -26
  194. package/dist/esm/index29.js +35 -8
  195. package/dist/esm/index3.js +2 -2
  196. package/dist/esm/index30.js +8 -28
  197. package/dist/esm/index31.js +27 -44
  198. package/dist/esm/index32.js +44 -86
  199. package/dist/esm/index33.js +83 -35
  200. package/dist/esm/index34.js +40 -8
  201. package/dist/esm/index35.js +7 -5
  202. package/dist/esm/index36.js +6 -16
  203. package/dist/esm/index37.js +16 -8
  204. package/dist/esm/index38.js +8 -13
  205. package/dist/esm/index39.js +13 -7
  206. package/dist/esm/index4.js +22 -33
  207. package/dist/esm/index40.js +7 -9
  208. package/dist/esm/index41.js +9 -16
  209. package/dist/esm/index42.js +16 -46
  210. package/dist/esm/index43.js +46 -13
  211. package/dist/esm/index44.js +13 -16
  212. package/dist/esm/index45.js +14 -11
  213. package/dist/esm/index46.js +13 -6
  214. package/dist/esm/index47.js +5 -34
  215. package/dist/esm/index48.js +34 -8
  216. package/dist/esm/index49.js +8 -7
  217. package/dist/esm/index5.js +33 -17
  218. package/dist/esm/index50.js +8 -25
  219. package/dist/esm/index51.js +25 -10
  220. package/dist/esm/index52.js +10 -14
  221. package/dist/esm/index53.js +14 -11
  222. package/dist/esm/index54.js +11 -116
  223. package/dist/esm/index55.js +114 -31
  224. package/dist/esm/index56.js +30 -76
  225. package/dist/esm/index57.js +78 -176
  226. package/dist/esm/index58.js +174 -41
  227. package/dist/esm/index59.js +44 -6
  228. package/dist/esm/index6.js +18 -12
  229. package/dist/esm/index60.js +5 -12
  230. package/dist/esm/index61.js +12 -12
  231. package/dist/esm/index62.js +13 -99
  232. package/dist/esm/index63.js +96 -69
  233. package/dist/esm/index64.js +61 -76
  234. package/dist/esm/index65.js +74 -135
  235. package/dist/esm/index66.js +108 -96
  236. package/dist/esm/index67.js +113 -45
  237. package/dist/esm/index68.js +68 -23
  238. package/dist/esm/index69.js +23 -105
  239. package/dist/esm/index7.js +12 -54
  240. package/dist/esm/index70.js +105 -6
  241. package/dist/esm/index71.js +6 -131
  242. package/dist/esm/index72.js +130 -274
  243. package/dist/esm/index73.js +276 -3
  244. package/dist/esm/index74.js +3 -4
  245. package/dist/esm/index75.js +4 -9
  246. package/dist/esm/index76.js +9 -2
  247. package/dist/esm/index77.js +2 -2
  248. package/dist/esm/index78.js +2 -3
  249. package/dist/esm/index79.js +3 -327
  250. package/dist/esm/index8.js +54 -58
  251. package/dist/esm/index80.js +324 -11
  252. package/dist/esm/index81.js +13 -4
  253. package/dist/esm/index82.js +4 -55
  254. package/dist/esm/index83.js +56 -2
  255. package/dist/esm/index84.js +2 -8
  256. package/dist/esm/index85.js +6 -213
  257. package/dist/esm/index86.js +215 -32
  258. package/dist/esm/index87.js +32 -22
  259. package/dist/esm/index88.js +21 -5
  260. package/dist/esm/index89.js +5 -73
  261. package/dist/esm/index9.js +58 -56
  262. package/dist/esm/index90.js +73 -5
  263. package/dist/esm/index91.js +4 -4
  264. package/dist/esm/index92.js +5 -35
  265. package/dist/esm/index93.js +29 -69
  266. package/dist/esm/index94.js +76 -3
  267. package/dist/esm/index95.js +3 -24
  268. package/dist/esm/index96.js +16 -444
  269. package/dist/esm/index97.js +444 -23
  270. package/dist/esm/index98.js +24 -20
  271. package/dist/esm/index99.js +18 -25
  272. package/dist/types/index.d.ts +18 -0
  273. package/package.json +5 -4
@@ -1,12 +1,6 @@
1
- let i = 256, t;
2
- function s(e = 11) {
3
- if (!t || i + e > 256 * 2) {
4
- t = "", i = 0;
5
- for (let r = 0; r < 256; r++)
6
- t += (256 + Math.random() * 256 | 0).toString(16).substring(1);
7
- }
8
- return t.substring(i, i++ + e);
1
+ function e(r) {
2
+ return typeof r == "string" ? { address: r, type: "json-rpc" } : r;
9
3
  }
10
4
  export {
11
- s as uid
5
+ e as parseAccount
12
6
  };
@@ -1,130 +1,24 @@
1
- import { NegativeOffsetError as o, PositionOutOfBoundsError as e, RecursiveReadLimitExceededError as n } from "./index128.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;
1
+ import { InvalidAddressError as c } from "./index105.js";
2
+ import { stringToBytes as m } from "./index109.js";
3
+ import { keccak256 as p } from "./index111.js";
4
+ import { LruMap as u } from "./index180.js";
5
+ import { isAddress as $ } from "./index132.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);
127
20
  }
128
21
  export {
129
- a as createCursor
22
+ h as checksumAddress,
23
+ w as getAddress
130
24
  };
@@ -1,41 +1,130 @@
1
- import { SliceOffsetOutOfBoundsError as t } from "./index105.js";
2
- import { isHex as p } from "./index145.js";
3
- import { size as r } from "./index81.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)
25
- });
26
- }
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;
1
+ import { NegativeOffsetError as o, PositionOutOfBoundsError as e, RecursiveReadLimitExceededError as n } from "./index129.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;
36
127
  }
37
128
  export {
38
- w as slice,
39
- m as sliceBytes,
40
- u as sliceHex
129
+ a as createCursor
41
130
  };
@@ -1,9 +1,41 @@
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;
1
+ import { SliceOffsetOutOfBoundsError as t } from "./index106.js";
2
+ import { isHex as p } from "./index146.js";
3
+ import { size as r } from "./index82.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)
25
+ });
26
+ }
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;
6
36
  }
7
37
  export {
8
- f as trim
38
+ w as slice,
39
+ m as sliceBytes,
40
+ u as sliceHex
9
41
  };
@@ -1,30 +1,9 @@
1
- import { InvalidBytesBooleanError as f } from "./index98.js";
2
- import { trim as o } from "./index122.js";
3
- import { assertSize as r, hexToNumber as s, hexToBigInt as u } from "./index142.js";
4
- import { bytesToHex as t } from "./index109.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
+ 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;
24
6
  }
25
7
  export {
26
- c as bytesToBigInt,
27
- T as bytesToBool,
28
- b as bytesToNumber,
29
- h as bytesToString
8
+ f as trim
30
9
  };
@@ -1,194 +1,30 @@
1
- import { AbiEncodingLengthMismatchError as y, InvalidAbiEncodingTypeError as u, InvalidArrayError as g, AbiEncodingArrayLengthMismatchError as l, AbiEncodingBytesSizeMismatchError as b } from "./index79.js";
2
- import { InvalidAddressError as w } from "./index104.js";
3
- import { BaseError as A } from "./index82.js";
4
- import { IntegerOutOfRangeError as x } from "./index98.js";
5
- import { isAddress as z } from "./index131.js";
6
- import { concat as f } from "./index113.js";
7
- import { padHex as d } from "./index132.js";
8
- import { size as a } from "./index81.js";
9
- import { slice as E } from "./index121.js";
10
- import { numberToHex as m, boolToHex as P, stringToHex as S } from "./index109.js";
11
- import { integerRegex as I } from "./index133.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 { InvalidBytesBooleanError as f } from "./index99.js";
2
+ import { trim as o } from "./index123.js";
3
+ import { assertSize as r, hexToNumber as s, hexToBigInt as u } from "./index143.js";
4
+ import { bytesToHex as t } from "./index110.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);
190
24
  }
191
25
  export {
192
- K as encodeAbiParameters,
193
- W as getArrayComponents
26
+ c as bytesToBigInt,
27
+ T as bytesToBool,
28
+ b as bytesToNumber,
29
+ h as bytesToString
194
30
  };