@etherisc/gif-next 0.0.2-d911522 → 0.0.2-e5ea33d
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.
- package/README.md +24 -0
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +2 -2
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +2 -2
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +2 -2
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2 -2
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +1 -1
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +2 -2
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +2 -2
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +2 -2
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +15 -2
- package/contracts/components/Component.sol +16 -18
- package/contracts/components/IPool.sol +3 -3
- package/contracts/components/IProduct.sol +3 -6
- package/contracts/components/Pool.sol +6 -13
- package/contracts/components/Product.sol +10 -21
- package/contracts/experiment/errors/Require.sol +10 -5
- package/contracts/experiment/errors/Revert.sol +13 -8
- package/contracts/experiment/inheritance/A.sol +8 -11
- package/contracts/experiment/inheritance/B.sol +10 -5
- package/contracts/experiment/inheritance/C.sol +11 -5
- package/contracts/experiment/inheritance/IA.sol +2 -7
- package/contracts/experiment/inheritance/IB.sol +3 -2
- package/contracts/experiment/inheritance/IC.sol +4 -3
- package/contracts/experiment/types/TypeA.sol +14 -9
- package/contracts/experiment/types/TypeB.sol +14 -9
- package/contracts/instance/IInstance.sol +1 -3
- package/contracts/instance/Instance.sol +13 -13
- package/contracts/instance/access/Access.sol +63 -116
- package/contracts/instance/access/IAccess.sol +28 -48
- package/contracts/instance/component/ComponentModule.sol +63 -98
- package/contracts/instance/component/IComponent.sol +30 -52
- package/contracts/instance/policy/IPolicy.sol +9 -24
- package/contracts/instance/policy/PolicyModule.sol +19 -35
- package/contracts/instance/pool/IPoolModule.sol +7 -19
- package/contracts/instance/pool/PoolModule.sol +22 -35
- package/contracts/instance/product/IProductService.sol +5 -15
- package/contracts/instance/product/ProductService.sol +43 -39
- package/contracts/registry/ChainNft.sol +23 -61
- package/contracts/registry/IChainNft.sol +10 -7
- package/contracts/registry/IRegistry.sol +46 -36
- package/contracts/registry/Registry.sol +80 -53
- package/contracts/types/Blocknumber.sol +76 -18
- package/contracts/types/ChainId.sol +18 -10
- package/contracts/types/NftId.sol +29 -13
- package/contracts/types/Timestamp.sol +63 -16
- package/contracts/types/UFixed.sol +62 -64
- package/package.json +9 -4
@@ -1,7 +1,7 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
-
import {
|
4
|
+
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";
|
5
5
|
|
6
6
|
/// @dev UFixed is a fixed point number with 18 decimals precision.
|
7
7
|
type UFixed is uint256;
|
@@ -18,59 +18,57 @@ using {
|
|
18
18
|
eqUFixed as ==
|
19
19
|
} for UFixed global;
|
20
20
|
|
21
|
-
function addUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
21
|
+
function addUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
22
22
|
return UFixed.wrap(UFixed.unwrap(a) + UFixed.unwrap(b));
|
23
23
|
}
|
24
24
|
|
25
|
-
function subUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
25
|
+
function subUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
26
26
|
require(a >= b, "ERROR:UFM-010:NEGATIVE_RESULT");
|
27
27
|
return UFixed.wrap(UFixed.unwrap(a) - UFixed.unwrap(b));
|
28
28
|
}
|
29
29
|
|
30
|
-
function mulUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
31
|
-
return
|
30
|
+
function mulUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
31
|
+
return
|
32
|
+
UFixed.wrap(Math.mulDiv(UFixed.unwrap(a), UFixed.unwrap(b), 10 ** 18));
|
32
33
|
}
|
33
34
|
|
34
|
-
function divUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
35
|
+
function divUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
35
36
|
require(UFixed.unwrap(b) > 0, "ERROR:UFM-020:DIVISOR_ZERO");
|
36
37
|
|
37
|
-
return
|
38
|
-
Math.mulDiv(
|
39
|
-
UFixed.unwrap(a),
|
40
|
-
10 ** 18,
|
41
|
-
UFixed.unwrap(b)));
|
38
|
+
return
|
39
|
+
UFixed.wrap(Math.mulDiv(UFixed.unwrap(a), 10 ** 18, UFixed.unwrap(b)));
|
42
40
|
}
|
43
41
|
|
44
|
-
function gtUFixed(UFixed a, UFixed b) pure returns(bool isGreaterThan) {
|
42
|
+
function gtUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
45
43
|
return UFixed.unwrap(a) > UFixed.unwrap(b);
|
46
44
|
}
|
47
45
|
|
48
|
-
function gteUFixed(UFixed a, UFixed b) pure returns(bool isGreaterThan) {
|
46
|
+
function gteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
49
47
|
return UFixed.unwrap(a) >= UFixed.unwrap(b);
|
50
48
|
}
|
51
49
|
|
52
|
-
function ltUFixed(UFixed a, UFixed b) pure returns(bool isGreaterThan) {
|
50
|
+
function ltUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
53
51
|
return UFixed.unwrap(a) < UFixed.unwrap(b);
|
54
52
|
}
|
55
53
|
|
56
|
-
function lteUFixed(UFixed a, UFixed b) pure returns(bool isGreaterThan) {
|
54
|
+
function lteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
57
55
|
return UFixed.unwrap(a) <= UFixed.unwrap(b);
|
58
56
|
}
|
59
57
|
|
60
|
-
function eqUFixed(UFixed a, UFixed b) pure returns(bool isEqual) {
|
58
|
+
function eqUFixed(UFixed a, UFixed b) pure returns (bool isEqual) {
|
61
59
|
return UFixed.unwrap(a) == UFixed.unwrap(b);
|
62
60
|
}
|
63
61
|
|
64
|
-
function gtzUFixed(UFixed a) pure returns(bool isZero) {
|
62
|
+
function gtzUFixed(UFixed a) pure returns (bool isZero) {
|
65
63
|
return UFixed.unwrap(a) > 0;
|
66
64
|
}
|
67
65
|
|
68
|
-
function eqzUFixed(UFixed a) pure returns(bool isZero) {
|
66
|
+
function eqzUFixed(UFixed a) pure returns (bool isZero) {
|
69
67
|
return UFixed.unwrap(a) == 0;
|
70
68
|
}
|
71
69
|
|
72
|
-
function deltaUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
73
|
-
if(a > b) {
|
70
|
+
function deltaUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
71
|
+
if (a > b) {
|
74
72
|
return a - b;
|
75
73
|
}
|
76
74
|
|
@@ -78,130 +76,130 @@ function deltaUFixed(UFixed a, UFixed b) pure returns(UFixed) {
|
|
78
76
|
}
|
79
77
|
|
80
78
|
library UFixedMathLib {
|
81
|
-
|
82
79
|
enum Rounding {
|
83
80
|
/// @dev Round down - floor(value)
|
84
|
-
Down,
|
81
|
+
Down,
|
85
82
|
/// @dev Round up - ceil(value)
|
86
|
-
Up,
|
83
|
+
Up,
|
87
84
|
/// @dev Round half up - round(value)
|
88
|
-
HalfUp
|
85
|
+
HalfUp
|
89
86
|
}
|
90
87
|
|
91
88
|
int8 public constant EXP = 18;
|
92
89
|
uint256 public constant MULTIPLIER = 10 ** uint256(int256(EXP));
|
93
90
|
uint256 public constant MULTIPLIER_HALF = MULTIPLIER / 2;
|
94
|
-
|
91
|
+
|
95
92
|
/// @dev Default rounding mode used by ftoi is HalfUp
|
96
93
|
Rounding public constant ROUNDING_DEFAULT = Rounding.HalfUp;
|
97
94
|
|
98
95
|
/// @dev returns the decimals precision of the UFixed type
|
99
|
-
function decimals() public pure returns(uint256) {
|
96
|
+
function decimals() public pure returns (uint256) {
|
100
97
|
return uint8(EXP);
|
101
98
|
}
|
102
99
|
|
103
100
|
/// @dev Converts the uint256 to a UFixed.
|
104
|
-
function itof(uint256 a)
|
105
|
-
public
|
106
|
-
pure
|
107
|
-
returns(UFixed)
|
108
|
-
{
|
101
|
+
function itof(uint256 a) public pure returns (UFixed) {
|
109
102
|
return UFixed.wrap(a * MULTIPLIER);
|
110
103
|
}
|
111
104
|
|
112
105
|
/// @dev Converts the uint256 to a UFixed with given exponent.
|
113
|
-
function itof(uint256 a, int8 exp)
|
114
|
-
public
|
115
|
-
pure
|
116
|
-
returns(UFixed)
|
117
|
-
{
|
106
|
+
function itof(uint256 a, int8 exp) public pure returns (UFixed) {
|
118
107
|
require(EXP + exp >= 0, "ERROR:FM-010:EXPONENT_TOO_SMALL");
|
119
|
-
require(EXP + exp <=
|
108
|
+
require(EXP + exp <= 64, "ERROR:FM-011:EXPONENT_TOO_LARGE");
|
120
109
|
|
121
110
|
return UFixed.wrap(a * 10 ** uint8(EXP + exp));
|
122
111
|
}
|
123
112
|
|
124
113
|
/// @dev Converts a UFixed to a uint256.
|
125
|
-
function ftoi(UFixed a)
|
126
|
-
public
|
127
|
-
pure
|
128
|
-
returns(uint256)
|
129
|
-
{
|
114
|
+
function ftoi(UFixed a) public pure returns (uint256) {
|
130
115
|
return ftoi(a, ROUNDING_DEFAULT);
|
131
116
|
}
|
132
117
|
|
133
118
|
/// @dev Converts a UFixed to a uint256 with given rounding mode.
|
134
|
-
function ftoi(UFixed a, Rounding rounding)
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
119
|
+
function ftoi(UFixed a, Rounding rounding) public pure returns (uint256) {
|
120
|
+
if (rounding == Rounding.HalfUp) {
|
121
|
+
return
|
122
|
+
Math.mulDiv(
|
123
|
+
UFixed.unwrap(a) + MULTIPLIER_HALF,
|
124
|
+
1,
|
125
|
+
MULTIPLIER,
|
126
|
+
Math.Rounding.Down
|
127
|
+
);
|
128
|
+
} else if (rounding == Rounding.Down) {
|
129
|
+
return
|
130
|
+
Math.mulDiv(
|
131
|
+
UFixed.unwrap(a),
|
132
|
+
1,
|
133
|
+
MULTIPLIER,
|
134
|
+
Math.Rounding.Down
|
135
|
+
);
|
143
136
|
} else {
|
144
|
-
return
|
137
|
+
return
|
138
|
+
Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Up);
|
145
139
|
}
|
146
140
|
}
|
147
141
|
|
148
142
|
/// @dev adds two UFixed numbers
|
149
|
-
function add(UFixed a, UFixed b) public pure returns(UFixed) {
|
143
|
+
function add(UFixed a, UFixed b) public pure returns (UFixed) {
|
150
144
|
return addUFixed(a, b);
|
151
145
|
}
|
152
146
|
|
153
147
|
/// @dev subtracts two UFixed numbers
|
154
|
-
function sub(UFixed a, UFixed b) public pure returns(UFixed) {
|
148
|
+
function sub(UFixed a, UFixed b) public pure returns (UFixed) {
|
155
149
|
return subUFixed(a, b);
|
156
150
|
}
|
157
151
|
|
158
152
|
/// @dev multiplies two UFixed numbers
|
159
|
-
function mul(UFixed a, UFixed b) public pure returns(UFixed) {
|
153
|
+
function mul(UFixed a, UFixed b) public pure returns (UFixed) {
|
160
154
|
return mulUFixed(a, b);
|
161
155
|
}
|
162
156
|
|
163
157
|
/// @dev divides two UFixed numbers
|
164
|
-
function div(UFixed a, UFixed b) public pure returns(UFixed) {
|
158
|
+
function div(UFixed a, UFixed b) public pure returns (UFixed) {
|
165
159
|
return divUFixed(a, b);
|
166
160
|
}
|
167
161
|
|
168
162
|
/// @dev return true if UFixed a is greater than UFixed b
|
169
|
-
function gt(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
|
163
|
+
function gt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
170
164
|
return gtUFixed(a, b);
|
171
165
|
}
|
172
166
|
|
173
167
|
/// @dev return true if UFixed a is greater than or equal to UFixed b
|
174
|
-
function gte(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
|
168
|
+
function gte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
175
169
|
return gteUFixed(a, b);
|
176
170
|
}
|
177
171
|
|
178
172
|
/// @dev return true if UFixed a is less than UFixed b
|
179
|
-
function lt(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
|
173
|
+
function lt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
180
174
|
return ltUFixed(a, b);
|
181
175
|
}
|
182
176
|
|
183
177
|
/// @dev return true if UFixed a is less than or equal to UFixed b
|
184
|
-
function lte(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
|
178
|
+
function lte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
185
179
|
return lteUFixed(a, b);
|
186
180
|
}
|
187
181
|
|
188
182
|
/// @dev return true if UFixed a is equal to UFixed b
|
189
|
-
function eq(UFixed a, UFixed b) public pure returns(bool isEqual) {
|
183
|
+
function eq(UFixed a, UFixed b) public pure returns (bool isEqual) {
|
190
184
|
return eqUFixed(a, b);
|
191
185
|
}
|
192
186
|
|
193
187
|
/// @dev return true if UFixed a is not zero
|
194
|
-
function gtz(UFixed a) public pure returns(bool isZero) {
|
188
|
+
function gtz(UFixed a) public pure returns (bool isZero) {
|
195
189
|
return gtzUFixed(a);
|
196
190
|
}
|
197
191
|
|
198
192
|
/// @dev return true if UFixed a is zero
|
199
|
-
function eqz(UFixed a) public pure returns(bool isZero) {
|
193
|
+
function eqz(UFixed a) public pure returns (bool isZero) {
|
200
194
|
return eqzUFixed(a);
|
201
195
|
}
|
202
196
|
|
197
|
+
function zero() public pure returns (UFixed) {
|
198
|
+
return UFixed.wrap(0);
|
199
|
+
}
|
200
|
+
|
203
201
|
/// @dev return the absolute delta between two UFixed numbers
|
204
|
-
function delta(UFixed a, UFixed b) public pure returns(UFixed) {
|
202
|
+
function delta(UFixed a, UFixed b) public pure returns (UFixed) {
|
205
203
|
return deltaUFixed(a, b);
|
206
204
|
}
|
207
205
|
}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@etherisc/gif-next",
|
3
|
-
"version": "0.0.2-
|
3
|
+
"version": "0.0.2-e5ea33d",
|
4
4
|
"description": "This is the repository for the next version of the Generic Insurance Framework (GIF) smart contracts. ",
|
5
5
|
"main": "index.js",
|
6
6
|
"scripts": {
|
@@ -8,7 +8,9 @@
|
|
8
8
|
"test": "hh test",
|
9
9
|
"ptest": "hh test --parallel",
|
10
10
|
"test-with-gas": "REPORT_GAS=true hh test",
|
11
|
-
"coverage": "hh coverage"
|
11
|
+
"coverage": "hh coverage",
|
12
|
+
"prettier": "prettier --write --plugin=prettier-plugin-solidity 'contracts/**/*.sol' 'test_forge/**/*.t.sol'",
|
13
|
+
"lint": "prettier --list-different --plugin=prettier-plugin-solidity 'contracts/**/*.sol' 'test_forge/**/*.t.sol' && solhint 'contracts/**/*.sol' 'test_forge/**/*.t.sol'"
|
12
14
|
},
|
13
15
|
"repository": {
|
14
16
|
"type": "git",
|
@@ -25,10 +27,13 @@
|
|
25
27
|
],
|
26
28
|
"homepage": "https://github.com/etherisc/gif-next#readme",
|
27
29
|
"devDependencies": {
|
28
|
-
"@nomicfoundation/hardhat-foundry": "^1.
|
30
|
+
"@nomicfoundation/hardhat-foundry": "^1.1.1",
|
29
31
|
"@nomicfoundation/hardhat-toolbox": "^3.0.0",
|
32
|
+
"@nomicfoundation/hardhat-verify": "^1.1.1",
|
30
33
|
"dotenv": "^16.3.1",
|
31
|
-
"hardhat": "^2.17.
|
34
|
+
"hardhat": "^2.17.2",
|
35
|
+
"prettier": "^3.0.3",
|
36
|
+
"prettier-plugin-solidity": "^1.1.3"
|
32
37
|
},
|
33
38
|
"dependencies": {
|
34
39
|
"@openzeppelin/contracts": "^4.9.3",
|