@gainsnetwork/sdk 0.0.30-rc4 → 0.0.30-rc6

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 (113) hide show
  1. package/README.md +11 -11
  2. package/lib/constants.d.ts +140 -138
  3. package/lib/constants.js +151 -145
  4. package/lib/contracts/addresses.d.ts +2 -2
  5. package/lib/contracts/addresses.js +15 -15
  6. package/lib/contracts/addresses.json +35 -35
  7. package/lib/contracts/index.d.ts +6 -6
  8. package/lib/contracts/index.js +35 -35
  9. package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -1911
  10. package/lib/contracts/types/generated/GFarmTradingStorageV5.js +2 -2
  11. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.d.ts +1058 -1058
  12. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.js +2 -2
  13. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +533 -533
  14. package/lib/contracts/types/generated/GNSNftRewardsV6.js +2 -2
  15. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.d.ts +613 -613
  16. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.js +2 -2
  17. package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +911 -911
  18. package/lib/contracts/types/generated/GNSPairInfosV6_1.js +2 -2
  19. package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +660 -660
  20. package/lib/contracts/types/generated/GNSPairsStorageV6.js +2 -2
  21. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.d.ts +821 -821
  22. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.js +2 -2
  23. package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
  24. package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
  25. package/lib/contracts/types/generated/GTokenV6_3_2.d.ts +1838 -1838
  26. package/lib/contracts/types/generated/GTokenV6_3_2.js +2 -2
  27. package/lib/contracts/types/generated/common.d.ts +22 -22
  28. package/lib/contracts/types/generated/common.js +2 -2
  29. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -83
  30. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -2691
  31. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.d.ts +113 -113
  32. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.js +1742 -1742
  33. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.d.ts +100 -100
  34. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.js +1116 -1116
  35. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +100 -100
  36. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +1003 -1003
  37. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +98 -98
  38. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +1485 -1485
  39. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +117 -117
  40. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +1265 -1265
  41. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.d.ts +82 -82
  42. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.js +1326 -1326
  43. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -59
  44. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -765
  45. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.d.ts +110 -110
  46. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.js +2682 -2682
  47. package/lib/contracts/types/generated/factories/index.d.ts +9 -9
  48. package/lib/contracts/types/generated/factories/index.js +24 -24
  49. package/lib/contracts/types/generated/index.d.ts +19 -19
  50. package/lib/contracts/types/generated/index.js +45 -45
  51. package/lib/contracts/types/index.d.ts +23 -23
  52. package/lib/contracts/types/index.js +2 -2
  53. package/lib/contracts/utils/borrowingFees.d.ts +8 -8
  54. package/lib/contracts/utils/borrowingFees.js +28 -28
  55. package/lib/contracts/utils/index.d.ts +4 -4
  56. package/lib/contracts/utils/index.js +20 -20
  57. package/lib/contracts/utils/openLimitOrders.d.ts +8 -8
  58. package/lib/contracts/utils/openLimitOrders.js +88 -88
  59. package/lib/contracts/utils/openTrades.d.ts +9 -9
  60. package/lib/contracts/utils/openTrades.js +172 -172
  61. package/lib/contracts/utils/pairs.d.ts +7 -7
  62. package/lib/contracts/utils/pairs.js +115 -115
  63. package/lib/index.d.ts +7 -7
  64. package/lib/index.js +24 -24
  65. package/lib/markets/commodities.d.ts +1 -1
  66. package/lib/markets/commodities.js +31 -31
  67. package/lib/markets/crypto.d.ts +1 -1
  68. package/lib/markets/crypto.js +6 -6
  69. package/lib/markets/forex.d.ts +2 -2
  70. package/lib/markets/forex.js +38 -38
  71. package/lib/markets/index.d.ts +5 -5
  72. package/lib/markets/index.js +21 -21
  73. package/lib/markets/indices.d.ts +1 -1
  74. package/lib/markets/indices.js +6 -6
  75. package/lib/markets/stocks.d.ts +3 -3
  76. package/lib/markets/stocks.js +54 -54
  77. package/lib/trade/fees/borrowing/converter.d.ts +13 -13
  78. package/lib/trade/fees/borrowing/converter.js +41 -41
  79. package/lib/trade/fees/borrowing/index.d.ts +55 -55
  80. package/lib/trade/fees/borrowing/index.js +171 -171
  81. package/lib/trade/fees/borrowing/types.d.ts +36 -36
  82. package/lib/trade/fees/borrowing/types.js +2 -2
  83. package/lib/trade/fees/index.d.ts +16 -16
  84. package/lib/trade/fees/index.js +60 -60
  85. package/lib/trade/fees.d.ts +15 -0
  86. package/lib/trade/fees.js +45 -0
  87. package/lib/trade/index.d.ts +7 -7
  88. package/lib/trade/index.js +23 -23
  89. package/lib/trade/liquidation.d.ts +7 -7
  90. package/lib/trade/liquidation.js +18 -18
  91. package/lib/trade/openLimitOrder.d.ts +2 -2
  92. package/lib/trade/openLimitOrder.js +24 -24
  93. package/lib/trade/pnl.d.ts +9 -9
  94. package/lib/trade/pnl.js +44 -44
  95. package/lib/trade/spread.d.ts +3 -3
  96. package/lib/trade/spread.js +30 -30
  97. package/lib/trade/types.d.ts +176 -176
  98. package/lib/trade/types.js +14 -14
  99. package/lib/utils/index.d.ts +1 -1
  100. package/lib/utils/index.js +17 -17
  101. package/lib/utils/packing.d.ts +2 -2
  102. package/lib/utils/packing.js +39 -39
  103. package/lib/vault/index.d.ts +7 -7
  104. package/lib/vault/index.js +11 -11
  105. package/package.json +104 -104
  106. package/lib/contracts/types/generated/GNSBorrowingFeesV6_3_2.d.ts +0 -979
  107. package/lib/contracts/types/generated/GNSBorrowingFeesV6_3_2.js +0 -2
  108. package/lib/contracts/types/generated/GNSTradingCallbacksV6_3_2.d.ts +0 -806
  109. package/lib/contracts/types/generated/GNSTradingCallbacksV6_3_2.js +0 -2
  110. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_3_2__factory.d.ts +0 -88
  111. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_3_2__factory.js +0 -1654
  112. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_3_2__factory.d.ts +0 -82
  113. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_3_2__factory.js +0 -1273
@@ -1,176 +1,176 @@
1
- import { GFarmTradingStorageV5 } from "@/contracts/types/generated";
2
- import { BigNumber } from "ethers";
3
- import { BorrowingFee } from "./fees/borrowing";
4
- export type PairIndexes = {
5
- [key: string]: number;
6
- };
7
- export type TradeContainer = {
8
- trade: Trade;
9
- tradeInfo: TradeInfo;
10
- initialAccFees: TradeInitialAccFees;
11
- receivedAt?: number;
12
- };
13
- export type Trade = {
14
- buy: boolean;
15
- index: number;
16
- initialPosToken: number;
17
- leverage: number;
18
- openPrice: number;
19
- pairIndex: number;
20
- sl: number;
21
- tp: number;
22
- trader: string;
23
- };
24
- export type TradeInfo = {
25
- openInterestDai: number;
26
- slLastUpdated: number;
27
- tokenPriceDai: number;
28
- tpLastUpdated: number;
29
- };
30
- export type TradeInitialAccFees = {
31
- rollover: number;
32
- funding: number;
33
- openedAfterUpdate: boolean;
34
- borrowing: BorrowingFee.InitialAccFees;
35
- };
36
- export type TradingGroup = {
37
- maxCollateralP: number;
38
- maxLeverage: number;
39
- minLeverage: number;
40
- name: string;
41
- };
42
- export type LimitOrder = {
43
- block: number;
44
- buy: boolean;
45
- index: number;
46
- leverage: number;
47
- maxPrice: number;
48
- minPrice: number;
49
- pairIndex: number;
50
- positionSize: number;
51
- sl: number;
52
- spreadReductionP: number;
53
- tp: number;
54
- trader: string;
55
- type: number;
56
- maxSlippageP: number;
57
- };
58
- export type LimitOrderRaw = GFarmTradingStorageV5.OpenLimitOrderStructOutput & {
59
- type: number;
60
- maxSlippageP: BigNumber;
61
- };
62
- export type Fee = {
63
- closeFeeP: number;
64
- minLevPosDai: number;
65
- nftLimitOrderFeeP: number;
66
- openFeeP: number;
67
- referralFeeP: number;
68
- };
69
- export type OpenInterest = {
70
- long: number;
71
- max: number;
72
- short: number;
73
- };
74
- export type OpenCollateral = {
75
- long: number;
76
- short: number;
77
- };
78
- export type PairParams = {
79
- onePercentDepthAbove: number;
80
- onePercentDepthBelow: number;
81
- rolloverFeePerBlockP: number;
82
- fundingFeePerBlockP: number;
83
- };
84
- export type PairRolloverFees = {
85
- accPerCollateral: number;
86
- lastUpdateBlock: number;
87
- };
88
- export type PairFundingFees = {
89
- accPerOiLong: number;
90
- accPerOiShort: number;
91
- lastUpdateBlock: number;
92
- };
93
- export type PairParamsBorrowingFees = {
94
- pairs: BorrowingFee.Pair[];
95
- groups: BorrowingFee.Group[];
96
- };
97
- export type Pair = {
98
- name: string;
99
- from: string;
100
- to: string;
101
- feeIndex: number;
102
- groupIndex: number;
103
- pairIndex: number;
104
- spreadP: number;
105
- };
106
- export type TradeHistoryRecord = {
107
- action: string;
108
- address: string;
109
- buy: number;
110
- date: string;
111
- leverage: number;
112
- pair: string;
113
- pnl_net: number;
114
- price: number;
115
- size: number;
116
- tx: string;
117
- };
118
- export type MarketOrder = {
119
- trader: string;
120
- pairIndex: number;
121
- index: number;
122
- block: number;
123
- open: boolean;
124
- };
125
- export type ChartBar = {
126
- close: number;
127
- high: number;
128
- isBarClosed: boolean;
129
- isLastBar: boolean;
130
- low: number;
131
- open: number;
132
- time: number;
133
- };
134
- export type LeaderboardTrader = {
135
- address: string;
136
- tradesCount: number;
137
- winrate: number;
138
- pnl: number;
139
- volume: number;
140
- score: number;
141
- };
142
- export type OpenTradeParams = [
143
- address: string,
144
- pairIndex: number,
145
- x1: number,
146
- x2: number,
147
- wei: number,
148
- price: string,
149
- buy: boolean,
150
- leverage: number,
151
- takeProfit: string,
152
- stopLoss: string
153
- ];
154
- export declare enum PositionType {
155
- LONG = "LONG",
156
- SHORT = "SHORT"
157
- }
158
- export type TradeContainerRaw = {
159
- trade: GFarmTradingStorageV5.TradeStruct;
160
- tradeInfo: GFarmTradingStorageV5.TradeInfoStruct;
161
- initialAccFees: {
162
- rollover: BigNumber;
163
- funding: BigNumber;
164
- openedAfterUpdate: boolean;
165
- borrowing: {
166
- accPairFee: number;
167
- accGroupFee: number;
168
- block: number;
169
- };
170
- };
171
- };
172
- export declare enum OpenLimitOrderType {
173
- LEGACY = 0,
174
- REVERSAL = 1,
175
- MOMENTUM = 2
176
- }
1
+ import { GFarmTradingStorageV5 } from "@/contracts/types/generated";
2
+ import { BigNumber } from "ethers";
3
+ import { BorrowingFee } from "./fees/borrowing";
4
+ export type PairIndexes = {
5
+ [key: string]: number;
6
+ };
7
+ export type TradeContainer = {
8
+ trade: Trade;
9
+ tradeInfo: TradeInfo;
10
+ initialAccFees: TradeInitialAccFees;
11
+ receivedAt?: number;
12
+ };
13
+ export type Trade = {
14
+ buy: boolean;
15
+ index: number;
16
+ initialPosToken: number;
17
+ leverage: number;
18
+ openPrice: number;
19
+ pairIndex: number;
20
+ sl: number;
21
+ tp: number;
22
+ trader: string;
23
+ };
24
+ export type TradeInfo = {
25
+ openInterestDai: number;
26
+ slLastUpdated: number;
27
+ tokenPriceDai: number;
28
+ tpLastUpdated: number;
29
+ };
30
+ export type TradeInitialAccFees = {
31
+ rollover: number;
32
+ funding: number;
33
+ openedAfterUpdate: boolean;
34
+ borrowing: BorrowingFee.InitialAccFees;
35
+ };
36
+ export type TradingGroup = {
37
+ maxCollateralP: number;
38
+ maxLeverage: number;
39
+ minLeverage: number;
40
+ name: string;
41
+ };
42
+ export type LimitOrder = {
43
+ block: number;
44
+ buy: boolean;
45
+ index: number;
46
+ leverage: number;
47
+ maxPrice: number;
48
+ minPrice: number;
49
+ pairIndex: number;
50
+ positionSize: number;
51
+ sl: number;
52
+ spreadReductionP: number;
53
+ tp: number;
54
+ trader: string;
55
+ type: number;
56
+ maxSlippageP: number;
57
+ };
58
+ export type LimitOrderRaw = GFarmTradingStorageV5.OpenLimitOrderStructOutput & {
59
+ type: number;
60
+ maxSlippageP: BigNumber;
61
+ };
62
+ export type Fee = {
63
+ closeFeeP: number;
64
+ minLevPosDai: number;
65
+ nftLimitOrderFeeP: number;
66
+ openFeeP: number;
67
+ referralFeeP: number;
68
+ };
69
+ export type OpenInterest = {
70
+ long: number;
71
+ max: number;
72
+ short: number;
73
+ };
74
+ export type OpenCollateral = {
75
+ long: number;
76
+ short: number;
77
+ };
78
+ export type PairParams = {
79
+ onePercentDepthAbove: number;
80
+ onePercentDepthBelow: number;
81
+ rolloverFeePerBlockP: number;
82
+ fundingFeePerBlockP: number;
83
+ };
84
+ export type PairRolloverFees = {
85
+ accPerCollateral: number;
86
+ lastUpdateBlock: number;
87
+ };
88
+ export type PairFundingFees = {
89
+ accPerOiLong: number;
90
+ accPerOiShort: number;
91
+ lastUpdateBlock: number;
92
+ };
93
+ export type PairParamsBorrowingFees = {
94
+ pairs: BorrowingFee.Pair[];
95
+ groups: BorrowingFee.Group[];
96
+ };
97
+ export type Pair = {
98
+ name: string;
99
+ from: string;
100
+ to: string;
101
+ feeIndex: number;
102
+ groupIndex: number;
103
+ pairIndex: number;
104
+ spreadP: number;
105
+ };
106
+ export type TradeHistoryRecord = {
107
+ action: string;
108
+ address: string;
109
+ buy: number;
110
+ date: string;
111
+ leverage: number;
112
+ pair: string;
113
+ pnl_net: number;
114
+ price: number;
115
+ size: number;
116
+ tx: string;
117
+ };
118
+ export type MarketOrder = {
119
+ trader: string;
120
+ pairIndex: number;
121
+ index: number;
122
+ block: number;
123
+ open: boolean;
124
+ };
125
+ export type ChartBar = {
126
+ close: number;
127
+ high: number;
128
+ isBarClosed: boolean;
129
+ isLastBar: boolean;
130
+ low: number;
131
+ open: number;
132
+ time: number;
133
+ };
134
+ export type LeaderboardTrader = {
135
+ address: string;
136
+ tradesCount: number;
137
+ winrate: number;
138
+ pnl: number;
139
+ volume: number;
140
+ score: number;
141
+ };
142
+ export type OpenTradeParams = [
143
+ address: string,
144
+ pairIndex: number,
145
+ x1: number,
146
+ x2: number,
147
+ wei: number,
148
+ price: string,
149
+ buy: boolean,
150
+ leverage: number,
151
+ takeProfit: string,
152
+ stopLoss: string
153
+ ];
154
+ export declare enum PositionType {
155
+ LONG = "LONG",
156
+ SHORT = "SHORT"
157
+ }
158
+ export type TradeContainerRaw = {
159
+ trade: GFarmTradingStorageV5.TradeStruct;
160
+ tradeInfo: GFarmTradingStorageV5.TradeInfoStruct;
161
+ initialAccFees: {
162
+ rollover: BigNumber;
163
+ funding: BigNumber;
164
+ openedAfterUpdate: boolean;
165
+ borrowing: {
166
+ accPairFee: number;
167
+ accGroupFee: number;
168
+ block: number;
169
+ };
170
+ };
171
+ };
172
+ export declare enum OpenLimitOrderType {
173
+ LEGACY = 0,
174
+ REVERSAL = 1,
175
+ MOMENTUM = 2
176
+ }
@@ -1,14 +1,14 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.OpenLimitOrderType = exports.PositionType = void 0;
4
- var PositionType;
5
- (function (PositionType) {
6
- PositionType["LONG"] = "LONG";
7
- PositionType["SHORT"] = "SHORT";
8
- })(PositionType = exports.PositionType || (exports.PositionType = {}));
9
- var OpenLimitOrderType;
10
- (function (OpenLimitOrderType) {
11
- OpenLimitOrderType[OpenLimitOrderType["LEGACY"] = 0] = "LEGACY";
12
- OpenLimitOrderType[OpenLimitOrderType["REVERSAL"] = 1] = "REVERSAL";
13
- OpenLimitOrderType[OpenLimitOrderType["MOMENTUM"] = 2] = "MOMENTUM";
14
- })(OpenLimitOrderType = exports.OpenLimitOrderType || (exports.OpenLimitOrderType = {}));
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OpenLimitOrderType = exports.PositionType = void 0;
4
+ var PositionType;
5
+ (function (PositionType) {
6
+ PositionType["LONG"] = "LONG";
7
+ PositionType["SHORT"] = "SHORT";
8
+ })(PositionType = exports.PositionType || (exports.PositionType = {}));
9
+ var OpenLimitOrderType;
10
+ (function (OpenLimitOrderType) {
11
+ OpenLimitOrderType[OpenLimitOrderType["LEGACY"] = 0] = "LEGACY";
12
+ OpenLimitOrderType[OpenLimitOrderType["REVERSAL"] = 1] = "REVERSAL";
13
+ OpenLimitOrderType[OpenLimitOrderType["MOMENTUM"] = 2] = "MOMENTUM";
14
+ })(OpenLimitOrderType = exports.OpenLimitOrderType || (exports.OpenLimitOrderType = {}));
@@ -1 +1 @@
1
- export * from "./packing";
1
+ export * from "./packing";
@@ -1,17 +1,17 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./packing"), exports);
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./packing"), exports);
@@ -1,2 +1,2 @@
1
- export declare const pack: (values: bigint[], bitLengths: bigint[]) => bigint;
2
- export declare const unpack: (packed: bigint, bitLengths: bigint[]) => bigint[];
1
+ export declare const pack: (values: bigint[], bitLengths: bigint[]) => bigint;
2
+ export declare const unpack: (packed: bigint, bitLengths: bigint[]) => bigint[];
@@ -1,39 +1,39 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.unpack = exports.pack = void 0;
4
- const pack = (values, bitLengths) => {
5
- if (values.length !== bitLengths.length) {
6
- throw new Error("Mismatch in the lengths of values and bitLengths arrays");
7
- }
8
- let packed = BigInt(0);
9
- let currentShift = BigInt(0);
10
- for (let i = 0; i < values.length; i++) {
11
- if (currentShift + bitLengths[i] > BigInt(256)) {
12
- throw new Error("Packed value exceeds 256 bits");
13
- }
14
- const maxValue = (BigInt(1) << bitLengths[i]) - BigInt(1);
15
- if (values[i] > maxValue) {
16
- throw new Error("Value too large for specified bit length");
17
- }
18
- const maskedValue = values[i] & maxValue;
19
- packed |= maskedValue << currentShift;
20
- currentShift += bitLengths[i];
21
- }
22
- return packed;
23
- };
24
- exports.pack = pack;
25
- const unpack = (packed, bitLengths) => {
26
- const values = [];
27
- let currentShift = BigInt(0);
28
- for (let i = 0; i < bitLengths.length; i++) {
29
- if (currentShift + bitLengths[i] > BigInt(256)) {
30
- throw new Error("Unpacked value exceeds 256 bits");
31
- }
32
- const maxValue = (BigInt(1) << bitLengths[i]) - BigInt(1);
33
- const mask = maxValue << currentShift;
34
- values[i] = (packed & mask) >> currentShift;
35
- currentShift += bitLengths[i];
36
- }
37
- return values;
38
- };
39
- exports.unpack = unpack;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.unpack = exports.pack = void 0;
4
+ const pack = (values, bitLengths) => {
5
+ if (values.length !== bitLengths.length) {
6
+ throw new Error("Mismatch in the lengths of values and bitLengths arrays");
7
+ }
8
+ let packed = BigInt(0);
9
+ let currentShift = BigInt(0);
10
+ for (let i = 0; i < values.length; i++) {
11
+ if (currentShift + bitLengths[i] > BigInt(256)) {
12
+ throw new Error("Packed value exceeds 256 bits");
13
+ }
14
+ const maxValue = (BigInt(1) << bitLengths[i]) - BigInt(1);
15
+ if (values[i] > maxValue) {
16
+ throw new Error("Value too large for specified bit length");
17
+ }
18
+ const maskedValue = values[i] & maxValue;
19
+ packed |= maskedValue << currentShift;
20
+ currentShift += bitLengths[i];
21
+ }
22
+ return packed;
23
+ };
24
+ exports.pack = pack;
25
+ const unpack = (packed, bitLengths) => {
26
+ const values = [];
27
+ let currentShift = BigInt(0);
28
+ for (let i = 0; i < bitLengths.length; i++) {
29
+ if (currentShift + bitLengths[i] > BigInt(256)) {
30
+ throw new Error("Unpacked value exceeds 256 bits");
31
+ }
32
+ const maxValue = (BigInt(1) << bitLengths[i]) - BigInt(1);
33
+ const mask = maxValue << currentShift;
34
+ values[i] = (packed & mask) >> currentShift;
35
+ currentShift += bitLengths[i];
36
+ }
37
+ return values;
38
+ };
39
+ exports.unpack = unpack;
@@ -1,7 +1,7 @@
1
- type GetPendingAccBlockWeightedMarketCap = {
2
- marketCap: number;
3
- accBlockWeightedMarketCap: number;
4
- accBlockWeightedMarketCapLastStored: number;
5
- };
6
- export declare const getPendingAccBlockWeightedMarketCap: (currentBlock: number, context: GetPendingAccBlockWeightedMarketCap) => number;
7
- export {};
1
+ type GetPendingAccBlockWeightedMarketCap = {
2
+ marketCap: number;
3
+ accBlockWeightedMarketCap: number;
4
+ accBlockWeightedMarketCapLastStored: number;
5
+ };
6
+ export declare const getPendingAccBlockWeightedMarketCap: (currentBlock: number, context: GetPendingAccBlockWeightedMarketCap) => number;
7
+ export {};
@@ -1,11 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getPendingAccBlockWeightedMarketCap = void 0;
4
- const MC_PRECISION = 1e18;
5
- const getPendingAccBlockWeightedMarketCap = (currentBlock, context) => {
6
- const { marketCap, accBlockWeightedMarketCap, accBlockWeightedMarketCapLastStored, } = context;
7
- return (accBlockWeightedMarketCap +
8
- (currentBlock - accBlockWeightedMarketCapLastStored) /
9
- Math.max(marketCap * MC_PRECISION, 1));
10
- };
11
- exports.getPendingAccBlockWeightedMarketCap = getPendingAccBlockWeightedMarketCap;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPendingAccBlockWeightedMarketCap = void 0;
4
+ const MC_PRECISION = 1e18;
5
+ const getPendingAccBlockWeightedMarketCap = (currentBlock, context) => {
6
+ const { marketCap, accBlockWeightedMarketCap, accBlockWeightedMarketCapLastStored, } = context;
7
+ return (accBlockWeightedMarketCap +
8
+ (currentBlock - accBlockWeightedMarketCapLastStored) /
9
+ Math.max(marketCap * MC_PRECISION, 1));
10
+ };
11
+ exports.getPendingAccBlockWeightedMarketCap = getPendingAccBlockWeightedMarketCap;