@etherisc/gif-next 0.0.2-c40f9a5 → 0.0.2-c6846dc-026

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 (171) hide show
  1. package/README.md +33 -0
  2. package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
  3. package/artifacts/contracts/components/Component.sol/Component.json +28 -2
  4. package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +1 -1
  5. package/artifacts/contracts/components/Component.sol/InstanceLinked.json +2 -2
  6. package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +1 -1
  7. package/artifacts/contracts/components/IPool.sol/IPoolComponent.json +78 -2
  8. package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +32 -150
  10. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  11. package/artifacts/contracts/components/Pool.sol/Pool.json +121 -6
  12. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  13. package/artifacts/contracts/components/Product.sol/Product.json +121 -6
  14. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  15. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
  16. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  17. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
  18. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  19. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
  20. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  21. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
  22. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
  23. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
  24. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
  25. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
  26. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
  27. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +4 -0
  29. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +59 -0
  30. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +4 -0
  31. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +124 -0
  32. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +4 -0
  33. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +74 -0
  34. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +4 -0
  35. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +124 -0
  36. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +4 -0
  37. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +207 -0
  38. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  39. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
  40. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  41. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
  42. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  43. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +686 -99
  44. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  45. package/artifacts/contracts/instance/Instance.sol/Instance.json +757 -99
  46. package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +1 -1
  47. package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +1 -1
  48. package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +1 -1
  49. package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +1 -1
  50. package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +1 -1
  51. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
  52. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.json +14 -42
  53. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
  54. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +65 -10
  55. package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +1 -1
  56. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +1 -1
  57. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.json +28 -2
  58. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
  59. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +12 -40
  60. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
  61. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +47 -0
  62. package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +1 -1
  63. package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  64. package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycle.json +134 -0
  65. package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycleModule.dbg.json +4 -0
  66. package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycleModule.json +182 -0
  67. package/artifacts/contracts/instance/lifecycle/LifecycleModule.sol/LifecycleModule.dbg.json +4 -0
  68. package/artifacts/contracts/instance/lifecycle/LifecycleModule.sol/LifecycleModule.json +221 -0
  69. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
  70. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
  71. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.json +26 -3
  72. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
  73. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +26 -3
  74. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +1 -1
  75. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
  76. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.json +15 -35
  77. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
  78. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.json +22 -29
  79. package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +1 -1
  80. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +1 -1
  81. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.json +13 -0
  82. package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +1 -1
  83. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +1 -1
  84. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +41 -12
  85. package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasury.dbg.json +4 -0
  86. package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasury.json +10 -0
  87. package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasuryModule.dbg.json +4 -0
  88. package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasuryModule.json +490 -0
  89. package/artifacts/contracts/instance/treasury/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  90. package/artifacts/contracts/instance/treasury/TokenHandler.sol/TokenHandler.json +45 -0
  91. package/artifacts/contracts/instance/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +4 -0
  92. package/artifacts/contracts/instance/treasury/TreasuryModule.sol/TreasuryModule.json +490 -0
  93. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  94. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  95. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
  96. package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +1 -1
  97. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +1 -1
  98. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.json +2 -2
  99. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  100. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +4 -95
  101. package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +1 -1
  102. package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +1 -1
  103. package/artifacts/contracts/registry/Registry.sol/Registerable.json +2 -2
  104. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  105. package/artifacts/contracts/registry/Registry.sol/Registry.json +14 -105
  106. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +1 -1
  107. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +2 -2
  108. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  109. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
  110. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  111. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
  112. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  113. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
  114. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  115. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +92 -0
  116. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +4 -0
  117. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +92 -0
  118. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  119. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +2 -2
  120. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +1 -1
  121. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +2 -2
  122. package/contracts/components/Component.sol +38 -23
  123. package/contracts/components/IPool.sol +9 -3
  124. package/contracts/components/IProduct.sol +10 -6
  125. package/contracts/components/Pool.sol +37 -14
  126. package/contracts/components/Product.sol +46 -23
  127. package/contracts/experiment/errors/Require.sol +10 -5
  128. package/contracts/experiment/errors/Revert.sol +13 -8
  129. package/contracts/experiment/inheritance/A.sol +8 -11
  130. package/contracts/experiment/inheritance/B.sol +10 -5
  131. package/contracts/experiment/inheritance/C.sol +11 -5
  132. package/contracts/experiment/inheritance/IA.sol +2 -7
  133. package/contracts/experiment/inheritance/IB.sol +3 -2
  134. package/contracts/experiment/inheritance/IC.sol +4 -3
  135. package/contracts/experiment/statemachine/Dummy.sol +27 -0
  136. package/contracts/experiment/statemachine/ISM.sol +25 -0
  137. package/contracts/experiment/statemachine/README.md +112 -0
  138. package/contracts/experiment/statemachine/SM.sol +57 -0
  139. package/contracts/experiment/statemachine/SimpleStateMachine.sol +31 -0
  140. package/contracts/experiment/types/TypeA.sol +14 -9
  141. package/contracts/experiment/types/TypeB.sol +14 -9
  142. package/contracts/instance/IInstance.sol +8 -3
  143. package/contracts/instance/Instance.sol +22 -14
  144. package/contracts/instance/access/Access.sol +63 -116
  145. package/contracts/instance/access/IAccess.sol +28 -48
  146. package/contracts/instance/component/ComponentModule.sol +144 -118
  147. package/contracts/instance/component/IComponent.sol +39 -60
  148. package/contracts/instance/lifecycle/ILifecycle.sol +47 -0
  149. package/contracts/instance/lifecycle/LifecycleModule.sol +88 -0
  150. package/contracts/instance/policy/IPolicy.sol +16 -32
  151. package/contracts/instance/policy/PolicyModule.sol +47 -40
  152. package/contracts/instance/pool/IPoolModule.sol +7 -25
  153. package/contracts/instance/pool/PoolModule.sol +40 -45
  154. package/contracts/instance/product/IProductService.sol +6 -16
  155. package/contracts/instance/product/ProductService.sol +76 -48
  156. package/contracts/instance/treasury/ITreasury.sol +91 -0
  157. package/contracts/instance/treasury/TokenHandler.sol +24 -0
  158. package/contracts/instance/treasury/TreasuryModule.sol +168 -0
  159. package/contracts/registry/ChainNft.sol +23 -61
  160. package/contracts/registry/IChainNft.sol +10 -7
  161. package/contracts/registry/IRegistry.sol +35 -38
  162. package/contracts/registry/Registry.sol +57 -57
  163. package/contracts/types/Blocknumber.sol +76 -18
  164. package/contracts/types/ChainId.sol +18 -10
  165. package/contracts/types/Fee.sol +32 -0
  166. package/contracts/types/NftId.sol +29 -13
  167. package/contracts/types/ObjectType.sol +107 -0
  168. package/contracts/types/StateId.sol +91 -0
  169. package/contracts/types/Timestamp.sol +63 -16
  170. package/contracts/types/UFixed.sol +59 -64
  171. package/package.json +12 -5
@@ -13,43 +13,90 @@ using {
13
13
  } for Timestamp global;
14
14
 
15
15
  /// @dev return true if Timestamp a is after Timestamp b
16
- function gtTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) > Timestamp.unwrap(b); }
16
+ function gtTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
17
+ return Timestamp.unwrap(a) > Timestamp.unwrap(b);
18
+ }
19
+
17
20
  /// @dev return true if Timestamp a is after or equal to Timestamp b
18
- function gteTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) >= Timestamp.unwrap(b); }
21
+ function gteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
22
+ return Timestamp.unwrap(a) >= Timestamp.unwrap(b);
23
+ }
19
24
 
20
25
  /// @dev return true if Timestamp a is before Timestamp b
21
- function ltTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) < Timestamp.unwrap(b); }
26
+ function ltTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
27
+ return Timestamp.unwrap(a) < Timestamp.unwrap(b);
28
+ }
29
+
22
30
  /// @dev return true if Timestamp a is before or equal to Timestamp b
23
- function lteTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) <= Timestamp.unwrap(b); }
31
+ function lteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
32
+ return Timestamp.unwrap(a) <= Timestamp.unwrap(b);
33
+ }
24
34
 
25
35
  /// @dev return true if Timestamp a is equal to Timestamp b
26
- function eqTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) == Timestamp.unwrap(b); }
36
+ function eqTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
37
+ return Timestamp.unwrap(a) == Timestamp.unwrap(b);
38
+ }
39
+
27
40
  /// @dev return true if Timestamp a is not equal to Timestamp b
28
- function neTimestamp(Timestamp a, Timestamp b) pure returns(bool) { return Timestamp.unwrap(a) != Timestamp.unwrap(b); }
41
+ function neTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
42
+ return Timestamp.unwrap(a) != Timestamp.unwrap(b);
43
+ }
29
44
 
30
45
  /// @dev Converts the uint256 to a Timestamp.
31
- function toTimestamp(uint256 timestamp) pure returns(Timestamp) { return Timestamp.wrap(uint40(timestamp));}
46
+ function toTimestamp(uint256 timestamp) pure returns (Timestamp) {
47
+ return Timestamp.wrap(uint40(timestamp));
48
+ }
32
49
 
33
- function blockTimestamp() view returns(Timestamp) { return toTimestamp(block.timestamp); }
50
+ function blockTimestamp() view returns (Timestamp) {
51
+ return toTimestamp(block.timestamp);
52
+ }
34
53
 
35
54
  /// @dev Return the Timestamp zero (0)
36
- function zeroTimestamp() pure returns(Timestamp) { return toTimestamp(0); }
55
+ function zeroTimestamp() pure returns (Timestamp) {
56
+ return toTimestamp(0);
57
+ }
37
58
 
38
59
  library TimestampLib {
39
60
  /// @dev return true if Timestamp a is after Timestamp b
40
- function gt(Timestamp a, Timestamp b) public pure returns(bool isAfter) { return gtTimestamp(a, b); }
61
+ function gt(Timestamp a, Timestamp b) public pure returns (bool isAfter) {
62
+ return gtTimestamp(a, b);
63
+ }
64
+
41
65
  /// @dev return true if Timestamp a is after or the same than Timestamp b
42
- function gte(Timestamp a, Timestamp b) public pure returns(bool isAfterOrSame) { return gteTimestamp(a, b); }
66
+ function gte(
67
+ Timestamp a,
68
+ Timestamp b
69
+ ) public pure returns (bool isAfterOrSame) {
70
+ return gteTimestamp(a, b);
71
+ }
43
72
 
44
73
  /// @dev return true if Timestamp a is before Timestamp b
45
- function lt(Timestamp a, Timestamp b) public pure returns(bool isBefore) { return ltTimestamp(a, b); }
74
+ function lt(Timestamp a, Timestamp b) public pure returns (bool isBefore) {
75
+ return ltTimestamp(a, b);
76
+ }
77
+
46
78
  /// @dev return true if Timestamp a is before or the same than Timestamp b
47
- function lte(Timestamp a, Timestamp b) public pure returns(bool isBeforeOrSame) { return lteTimestamp(a, b); }
79
+ function lte(
80
+ Timestamp a,
81
+ Timestamp b
82
+ ) public pure returns (bool isBeforeOrSame) {
83
+ return lteTimestamp(a, b);
84
+ }
48
85
 
49
86
  /// @dev return true if Timestamp a is equal to Timestamp b
50
- function eq(Timestamp a, Timestamp b) public pure returns(bool isSame) { return eqTimestamp(a, b); }
87
+ function eq(Timestamp a, Timestamp b) public pure returns (bool isSame) {
88
+ return eqTimestamp(a, b);
89
+ }
90
+
51
91
  /// @dev return true if Timestamp a is not equal to Timestamp b
52
- function ne(Timestamp a, Timestamp b) public pure returns(bool isDifferent) { return neTimestamp(a, b); }
92
+ function ne(
93
+ Timestamp a,
94
+ Timestamp b
95
+ ) public pure returns (bool isDifferent) {
96
+ return neTimestamp(a, b);
97
+ }
53
98
 
54
- function toInt(Timestamp timestamp) public pure returns(uint256) { return uint256(uint40(Timestamp.unwrap(timestamp))); }
99
+ function toInt(Timestamp timestamp) public pure returns (uint256) {
100
+ return uint256(uint40(Timestamp.unwrap(timestamp)));
101
+ }
55
102
  }
@@ -1,7 +1,7 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.19;
3
3
 
4
- import { Math } from "@openzeppelin/contracts/utils/math/Math.sol";
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 UFixed.wrap(Math.mulDiv(UFixed.unwrap(a), UFixed.unwrap(b), 10 ** 18));
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 UFixed.wrap(
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,43 +76,35 @@ 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
 
105
+ // TODO rename to toUFixed
112
106
  /// @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
- {
107
+ function itof(uint256 a, int8 exp) public pure returns (UFixed) {
118
108
  require(EXP + exp >= 0, "ERROR:FM-010:EXPONENT_TOO_SMALL");
119
109
  require(EXP + exp <= 64, "ERROR:FM-011:EXPONENT_TOO_LARGE");
120
110
 
@@ -122,90 +112,95 @@ library UFixedMathLib {
122
112
  }
123
113
 
124
114
  /// @dev Converts a UFixed to a uint256.
125
- function ftoi(UFixed a)
126
- public
127
- pure
128
- returns(uint256)
129
- {
115
+ function ftoi(UFixed a) public pure returns (uint256) {
130
116
  return ftoi(a, ROUNDING_DEFAULT);
131
117
  }
132
118
 
133
119
  /// @dev Converts a UFixed to a uint256 with given rounding mode.
134
- function ftoi(UFixed a, Rounding rounding)
135
- public
136
- pure
137
- returns(uint256)
138
- {
139
- if(rounding == Rounding.HalfUp) {
140
- return Math.mulDiv(UFixed.unwrap(a) + MULTIPLIER_HALF, 1, MULTIPLIER, Math.Rounding.Down);
141
- } else if(rounding == Rounding.Down) {
142
- return Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Down);
120
+ function ftoi(UFixed a, Rounding rounding) public pure returns (uint256) {
121
+ if (rounding == Rounding.HalfUp) {
122
+ return
123
+ Math.mulDiv(
124
+ UFixed.unwrap(a) + MULTIPLIER_HALF,
125
+ 1,
126
+ MULTIPLIER,
127
+ Math.Rounding.Down
128
+ );
129
+ } else if (rounding == Rounding.Down) {
130
+ return
131
+ Math.mulDiv(
132
+ UFixed.unwrap(a),
133
+ 1,
134
+ MULTIPLIER,
135
+ Math.Rounding.Down
136
+ );
143
137
  } else {
144
- return Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Up);
138
+ return
139
+ Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Up);
145
140
  }
146
141
  }
147
142
 
148
143
  /// @dev adds two UFixed numbers
149
- function add(UFixed a, UFixed b) public pure returns(UFixed) {
144
+ function add(UFixed a, UFixed b) public pure returns (UFixed) {
150
145
  return addUFixed(a, b);
151
146
  }
152
147
 
153
148
  /// @dev subtracts two UFixed numbers
154
- function sub(UFixed a, UFixed b) public pure returns(UFixed) {
149
+ function sub(UFixed a, UFixed b) public pure returns (UFixed) {
155
150
  return subUFixed(a, b);
156
151
  }
157
152
 
158
153
  /// @dev multiplies two UFixed numbers
159
- function mul(UFixed a, UFixed b) public pure returns(UFixed) {
154
+ function mul(UFixed a, UFixed b) public pure returns (UFixed) {
160
155
  return mulUFixed(a, b);
161
156
  }
162
157
 
163
158
  /// @dev divides two UFixed numbers
164
- function div(UFixed a, UFixed b) public pure returns(UFixed) {
159
+ function div(UFixed a, UFixed b) public pure returns (UFixed) {
165
160
  return divUFixed(a, b);
166
161
  }
167
162
 
168
163
  /// @dev return true if UFixed a is greater than UFixed b
169
- function gt(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
164
+ function gt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
170
165
  return gtUFixed(a, b);
171
166
  }
172
167
 
173
168
  /// @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) {
169
+ function gte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
175
170
  return gteUFixed(a, b);
176
171
  }
177
172
 
178
173
  /// @dev return true if UFixed a is less than UFixed b
179
- function lt(UFixed a, UFixed b) public pure returns(bool isGreaterThan) {
174
+ function lt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
180
175
  return ltUFixed(a, b);
181
176
  }
182
177
 
183
178
  /// @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) {
179
+ function lte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
185
180
  return lteUFixed(a, b);
186
181
  }
187
182
 
188
183
  /// @dev return true if UFixed a is equal to UFixed b
189
- function eq(UFixed a, UFixed b) public pure returns(bool isEqual) {
184
+ function eq(UFixed a, UFixed b) public pure returns (bool isEqual) {
190
185
  return eqUFixed(a, b);
191
186
  }
192
187
 
193
188
  /// @dev return true if UFixed a is not zero
194
- function gtz(UFixed a) public pure returns(bool isZero) {
189
+ function gtz(UFixed a) public pure returns (bool isZero) {
195
190
  return gtzUFixed(a);
196
191
  }
197
192
 
198
193
  /// @dev return true if UFixed a is zero
199
- function eqz(UFixed a) public pure returns(bool isZero) {
194
+ function eqz(UFixed a) public pure returns (bool isZero) {
200
195
  return eqzUFixed(a);
201
196
  }
202
197
 
203
- function zero() public pure returns(UFixed) {
198
+ function zero() public pure returns (UFixed) {
204
199
  return UFixed.wrap(0);
205
200
  }
206
201
 
207
202
  /// @dev return the absolute delta between two UFixed numbers
208
- function delta(UFixed a, UFixed b) public pure returns(UFixed) {
203
+ function delta(UFixed a, UFixed b) public pure returns (UFixed) {
209
204
  return deltaUFixed(a, b);
210
205
  }
211
206
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@etherisc/gif-next",
3
- "version": "0.0.2-c40f9a5",
3
+ "version": "0.0.2-c6846dc-026",
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,10 @@
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
+ "styleFix": "prettier --write --plugin=prettier-plugin-solidity 'contracts/**/*.sol' 'test_forge/**/*.t.sol'",
13
+ "styleCheck": "prettier --check --plugin=prettier-plugin-solidity 'contracts/**/*.sol' 'test_forge/**/*.t.sol'",
14
+ "lint": "solhint 'contracts/**/*.sol' 'test_forge/**/*.t.sol'"
12
15
  },
13
16
  "repository": {
14
17
  "type": "git",
@@ -25,14 +28,18 @@
25
28
  ],
26
29
  "homepage": "https://github.com/etherisc/gif-next#readme",
27
30
  "devDependencies": {
28
- "@nomicfoundation/hardhat-foundry": "^1.0.3",
31
+ "@nomicfoundation/hardhat-foundry": "^1.1.1",
29
32
  "@nomicfoundation/hardhat-toolbox": "^3.0.0",
30
33
  "@nomicfoundation/hardhat-verify": "^1.1.1",
31
34
  "dotenv": "^16.3.1",
32
- "hardhat": "^2.17.1"
35
+ "hardhat": "^2.17.2",
36
+ "prettier": "^3.0.3",
37
+ "prettier-plugin-solidity": "^1.1.3"
33
38
  },
34
39
  "dependencies": {
35
40
  "@openzeppelin/contracts": "^4.9.3",
36
- "@openzeppelin/contracts-upgradeable": "^4.9.3"
41
+ "@openzeppelin/contracts-upgradeable": "^4.9.3",
42
+ "ethers": "^6.7.1",
43
+ "winston": "^3.10.0"
37
44
  }
38
45
  }