@etherisc/gif-next 0.0.2-ebbe63d → 0.0.2-efdb520-159
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 +220 -1
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +174 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +174 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +356 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +279 -0
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/components/Pool.sol/Pool.json +387 -0
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/components/Product.sol/Product.json +305 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +105 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +105 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +128 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +42 -0
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +76 -0
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +89 -0
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +128 -0
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +37 -0
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +50 -0
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +63 -0
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +59 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +74 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +207 -0
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +4 -0
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +10 -0
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +4 -0
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +10 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +2022 -0
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +24 -0
- package/artifacts/contracts/instance/IServiceLinked.sol/IServiceLinked.dbg.json +4 -0
- package/artifacts/contracts/instance/IServiceLinked.sol/IServiceLinked.json +50 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +4 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2288 -0
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +313 -0
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +333 -0
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.json +10 -0
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +333 -0
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +276 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.json +10 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +276 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +188 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +10 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +188 -0
- package/artifacts/contracts/instance/module/lifecycle/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/lifecycle/ILifecycle.sol/ILifecycle.json +134 -0
- package/artifacts/contracts/instance/module/lifecycle/ILifecycle.sol/ILifecycleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/lifecycle/ILifecycle.sol/ILifecycleModule.json +182 -0
- package/artifacts/contracts/instance/module/lifecycle/LifecycleModule.sol/LifecycleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/lifecycle/LifecycleModule.sol/LifecycleModule.json +221 -0
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.json +10 -0
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +261 -0
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +261 -0
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +4 -0
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +10 -0
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +149 -0
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +149 -0
- package/artifacts/contracts/instance/module/product/IProductModule.sol/IProductModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/product/IProductModule.sol/IProductModule.json +10 -0
- package/artifacts/contracts/instance/module/product/ProductModule.sol/ProductModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/product/ProductModule.sol/ProductModule.json +10 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.json +10 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +538 -0
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +76 -0
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +538 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +519 -0
- package/artifacts/contracts/instance/service/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentServiceBase.sol/ComponentServiceBase.json +300 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +364 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +376 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +477 -0
- package/artifacts/contracts/instance/service/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IService.sol/IService.json +300 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +499 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +685 -0
- package/artifacts/contracts/instance/service/ServiceBase.sol/ServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ServiceBase.sol/ServiceBase.json +300 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +597 -0
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +452 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +305 -0
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +24 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +4 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.json +472 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +35 -0
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +24 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +121 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +164 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +121 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +164 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +4 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +95 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +4 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +387 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +4 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +393 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +4 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +137 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +4 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +82 -0
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +4 -0
- package/artifacts/contracts/test/TestService.sol/TestService.json +407 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +4 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +338 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +222 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +230 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +10 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +174 -0
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +10 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +92 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +10 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +92 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +92 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +236 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +453 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.json +78 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +30 -0
- package/contracts/components/BaseComponent.sol +89 -0
- package/contracts/components/IBaseComponent.sol +19 -0
- package/contracts/components/IPoolComponent.sol +57 -0
- package/contracts/components/IProductComponent.sol +19 -0
- package/contracts/components/Pool.sol +174 -0
- package/contracts/components/Product.sol +117 -0
- package/contracts/experiment/errors/Require.sol +38 -0
- package/contracts/experiment/errors/Revert.sol +44 -0
- package/contracts/experiment/inheritance/A.sol +53 -0
- package/contracts/experiment/inheritance/B.sol +28 -0
- package/contracts/experiment/inheritance/C.sol +34 -0
- package/contracts/experiment/inheritance/IA.sol +13 -0
- package/contracts/experiment/inheritance/IB.sol +10 -0
- package/contracts/experiment/inheritance/IC.sol +12 -0
- package/contracts/experiment/statemachine/Dummy.sol +27 -0
- package/contracts/experiment/statemachine/ISM.sol +25 -0
- package/contracts/experiment/statemachine/README.md +112 -0
- package/contracts/experiment/statemachine/SM.sol +57 -0
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +31 -0
- package/contracts/experiment/types/TypeA.sol +47 -0
- package/contracts/experiment/types/TypeB.sol +29 -0
- package/contracts/instance/IInstance.sol +50 -0
- package/contracts/instance/IInstanceLinked.sol +8 -0
- package/contracts/instance/IServiceLinked.sol +12 -0
- package/contracts/instance/Instance.sol +62 -0
- package/contracts/instance/InstanceBase.sol +74 -0
- package/contracts/instance/module/access/Access.sol +149 -0
- package/contracts/instance/module/access/IAccess.sol +53 -0
- package/contracts/instance/module/bundle/BundleModule.sol +228 -0
- package/contracts/instance/module/bundle/IBundle.sol +53 -0
- package/contracts/instance/module/component/ComponentModule.sol +104 -0
- package/contracts/instance/module/component/IComponent.sol +53 -0
- package/contracts/instance/module/lifecycle/ILifecycle.sol +47 -0
- package/contracts/instance/module/lifecycle/LifecycleModule.sol +89 -0
- package/contracts/instance/module/policy/IPolicy.sol +60 -0
- package/contracts/instance/module/policy/PolicyModule.sol +84 -0
- package/contracts/instance/module/pool/IPoolModule.sol +41 -0
- package/contracts/instance/module/pool/PoolModule.sol +87 -0
- package/contracts/instance/module/product/IProductModule.sol +6 -0
- package/contracts/instance/module/product/ProductModule.sol +8 -0
- package/contracts/instance/module/treasury/ITreasury.sol +104 -0
- package/contracts/instance/module/treasury/TokenHandler.sol +48 -0
- package/contracts/instance/module/treasury/TreasuryModule.sol +148 -0
- package/contracts/instance/service/ComponentOwnerService.sol +174 -0
- package/contracts/instance/service/ComponentServiceBase.sol +41 -0
- package/contracts/instance/service/IComponentOwnerService.sol +22 -0
- package/contracts/instance/service/IPoolService.sol +30 -0
- package/contracts/instance/service/IProductService.sol +58 -0
- package/contracts/instance/service/IService.sol +15 -0
- package/contracts/instance/service/PoolService.sol +98 -0
- package/contracts/instance/service/ProductService.sol +358 -0
- package/contracts/instance/service/ServiceBase.sol +39 -0
- package/contracts/registry/ChainNft.sol +159 -0
- package/contracts/registry/IChainNft.sol +21 -0
- package/contracts/registry/IRegistry.sol +57 -0
- package/contracts/registry/IRegistryLinked.sol +8 -0
- package/contracts/registry/Registry.sol +381 -0
- package/contracts/shared/ERC165.sol +21 -0
- package/contracts/shared/IOwnable.sol +6 -0
- package/contracts/shared/IRegisterable.sol +24 -0
- package/contracts/shared/IVersionable.sol +52 -0
- package/contracts/shared/Registerable.sol +86 -0
- package/contracts/shared/Versionable.sol +92 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestPool.sol +22 -0
- package/contracts/test/TestProduct.sol +44 -0
- package/contracts/test/TestRegisterable.sol +19 -0
- package/contracts/test/TestRoleId.sol +14 -0
- package/contracts/test/TestService.sol +35 -0
- package/contracts/{Dip.sol → test/TestToken.sol} +5 -5
- package/contracts/test/TestVersion.sol +47 -0
- package/contracts/test/TestVersionable.sol +20 -0
- package/contracts/types/AddressSet.sol +58 -0
- package/contracts/types/Blocknumber.sol +118 -0
- package/contracts/types/ChainId.sol +38 -0
- package/contracts/types/Fee.sol +32 -0
- package/contracts/types/NftId.sol +57 -0
- package/contracts/types/NftIdSet.sol +60 -0
- package/contracts/types/ObjectType.sol +115 -0
- package/contracts/types/RoleId.sol +36 -0
- package/contracts/types/StateId.sol +95 -0
- package/contracts/types/Timestamp.sol +123 -0
- package/contracts/types/UFixed.sol +206 -0
- package/contracts/types/Version.sol +91 -0
- package/package.json +24 -9
- package/artifacts/contracts/Dip.sol/DIP.dbg.json +0 -4
- package/artifacts/contracts/Dip.sol/DIP.json +0 -338
- package/artifacts/contracts/Lock.sol/Lock.dbg.json +0 -4
- package/artifacts/contracts/Lock.sol/Lock.json +0 -74
- package/contracts/Lock.sol +0 -34
@@ -0,0 +1,206 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";
|
5
|
+
|
6
|
+
/// @dev UFixed is a fixed point number with 18 decimals precision.
|
7
|
+
type UFixed is uint256;
|
8
|
+
|
9
|
+
using {
|
10
|
+
addUFixed as +,
|
11
|
+
subUFixed as -,
|
12
|
+
mulUFixed as *,
|
13
|
+
divUFixed as /,
|
14
|
+
gtUFixed as >,
|
15
|
+
gteUFixed as >=,
|
16
|
+
ltUFixed as <,
|
17
|
+
lteUFixed as <=,
|
18
|
+
eqUFixed as ==,
|
19
|
+
UFixedMathLib.toInt
|
20
|
+
} for UFixed global;
|
21
|
+
|
22
|
+
function addUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
23
|
+
return UFixed.wrap(UFixed.unwrap(a) + UFixed.unwrap(b));
|
24
|
+
}
|
25
|
+
|
26
|
+
function subUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
27
|
+
require(a >= b, "ERROR:UFM-010:NEGATIVE_RESULT");
|
28
|
+
return UFixed.wrap(UFixed.unwrap(a) - UFixed.unwrap(b));
|
29
|
+
}
|
30
|
+
|
31
|
+
function mulUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
32
|
+
return
|
33
|
+
UFixed.wrap(Math.mulDiv(UFixed.unwrap(a), UFixed.unwrap(b), 10 ** 18));
|
34
|
+
}
|
35
|
+
|
36
|
+
function divUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
37
|
+
require(UFixed.unwrap(b) > 0, "ERROR:UFM-020:DIVISOR_ZERO");
|
38
|
+
|
39
|
+
return
|
40
|
+
UFixed.wrap(Math.mulDiv(UFixed.unwrap(a), 10 ** 18, UFixed.unwrap(b)));
|
41
|
+
}
|
42
|
+
|
43
|
+
function gtUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
44
|
+
return UFixed.unwrap(a) > UFixed.unwrap(b);
|
45
|
+
}
|
46
|
+
|
47
|
+
function gteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
48
|
+
return UFixed.unwrap(a) >= UFixed.unwrap(b);
|
49
|
+
}
|
50
|
+
|
51
|
+
function ltUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
52
|
+
return UFixed.unwrap(a) < UFixed.unwrap(b);
|
53
|
+
}
|
54
|
+
|
55
|
+
function lteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
|
56
|
+
return UFixed.unwrap(a) <= UFixed.unwrap(b);
|
57
|
+
}
|
58
|
+
|
59
|
+
function eqUFixed(UFixed a, UFixed b) pure returns (bool isEqual) {
|
60
|
+
return UFixed.unwrap(a) == UFixed.unwrap(b);
|
61
|
+
}
|
62
|
+
|
63
|
+
function gtzUFixed(UFixed a) pure returns (bool isZero) {
|
64
|
+
return UFixed.unwrap(a) > 0;
|
65
|
+
}
|
66
|
+
|
67
|
+
function eqzUFixed(UFixed a) pure returns (bool isZero) {
|
68
|
+
return UFixed.unwrap(a) == 0;
|
69
|
+
}
|
70
|
+
|
71
|
+
function deltaUFixed(UFixed a, UFixed b) pure returns (UFixed) {
|
72
|
+
if (a > b) {
|
73
|
+
return a - b;
|
74
|
+
}
|
75
|
+
|
76
|
+
return b - a;
|
77
|
+
}
|
78
|
+
|
79
|
+
library UFixedMathLib {
|
80
|
+
enum Rounding {
|
81
|
+
/// @dev Round down - floor(value)
|
82
|
+
Down,
|
83
|
+
/// @dev Round up - ceil(value)
|
84
|
+
Up,
|
85
|
+
/// @dev Round half up - round(value)
|
86
|
+
HalfUp
|
87
|
+
}
|
88
|
+
|
89
|
+
int8 public constant EXP = 18;
|
90
|
+
uint256 public constant MULTIPLIER = 10 ** uint256(int256(EXP));
|
91
|
+
uint256 public constant MULTIPLIER_HALF = MULTIPLIER / 2;
|
92
|
+
|
93
|
+
/// @dev Converts the uint256 to a UFixed.
|
94
|
+
function toUFixed(uint256 a) public pure returns (UFixed) {
|
95
|
+
return UFixed.wrap(a * MULTIPLIER);
|
96
|
+
}
|
97
|
+
|
98
|
+
/// @dev Converts the uint256 to a UFixed with given exponent.
|
99
|
+
function toUFixed(uint256 a, int8 exp) public pure returns (UFixed) {
|
100
|
+
require(EXP + exp >= 0, "ERROR:FM-010:EXPONENT_TOO_SMALL");
|
101
|
+
require(EXP + exp <= 64, "ERROR:FM-011:EXPONENT_TOO_LARGE");
|
102
|
+
|
103
|
+
return UFixed.wrap(a * 10 ** uint8(EXP + exp));
|
104
|
+
}
|
105
|
+
|
106
|
+
/// @dev Default rounding mode used by ftoi is HalfUp
|
107
|
+
Rounding public constant ROUNDING_DEFAULT = Rounding.HalfUp;
|
108
|
+
|
109
|
+
/// @dev returns the decimals precision of the UFixed type
|
110
|
+
function decimals() public pure returns (uint256) {
|
111
|
+
return uint8(EXP);
|
112
|
+
}
|
113
|
+
|
114
|
+
/// @dev Converts a UFixed to a uint256.
|
115
|
+
function toInt(UFixed a) public pure returns (uint256) {
|
116
|
+
return toIntWithRounding(a, ROUNDING_DEFAULT);
|
117
|
+
}
|
118
|
+
|
119
|
+
/// @dev Converts a UFixed to a uint256 with given rounding mode.
|
120
|
+
function toIntWithRounding(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
|
+
);
|
137
|
+
} else {
|
138
|
+
return
|
139
|
+
Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Up);
|
140
|
+
}
|
141
|
+
}
|
142
|
+
|
143
|
+
/// @dev adds two UFixed numbers
|
144
|
+
function add(UFixed a, UFixed b) public pure returns (UFixed) {
|
145
|
+
return addUFixed(a, b);
|
146
|
+
}
|
147
|
+
|
148
|
+
/// @dev subtracts two UFixed numbers
|
149
|
+
function sub(UFixed a, UFixed b) public pure returns (UFixed) {
|
150
|
+
return subUFixed(a, b);
|
151
|
+
}
|
152
|
+
|
153
|
+
/// @dev multiplies two UFixed numbers
|
154
|
+
function mul(UFixed a, UFixed b) public pure returns (UFixed) {
|
155
|
+
return mulUFixed(a, b);
|
156
|
+
}
|
157
|
+
|
158
|
+
/// @dev divides two UFixed numbers
|
159
|
+
function div(UFixed a, UFixed b) public pure returns (UFixed) {
|
160
|
+
return divUFixed(a, b);
|
161
|
+
}
|
162
|
+
|
163
|
+
/// @dev return true if UFixed a is greater than UFixed b
|
164
|
+
function gt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
165
|
+
return gtUFixed(a, b);
|
166
|
+
}
|
167
|
+
|
168
|
+
/// @dev return true if UFixed a is greater than or equal to UFixed b
|
169
|
+
function gte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
170
|
+
return gteUFixed(a, b);
|
171
|
+
}
|
172
|
+
|
173
|
+
/// @dev return true if UFixed a is less than UFixed b
|
174
|
+
function lt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
175
|
+
return ltUFixed(a, b);
|
176
|
+
}
|
177
|
+
|
178
|
+
/// @dev return true if UFixed a is less than or equal to UFixed b
|
179
|
+
function lte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
|
180
|
+
return lteUFixed(a, b);
|
181
|
+
}
|
182
|
+
|
183
|
+
/// @dev return true if UFixed a is equal to UFixed b
|
184
|
+
function eq(UFixed a, UFixed b) public pure returns (bool isEqual) {
|
185
|
+
return eqUFixed(a, b);
|
186
|
+
}
|
187
|
+
|
188
|
+
/// @dev return true if UFixed a is not zero
|
189
|
+
function gtz(UFixed a) public pure returns (bool isZero) {
|
190
|
+
return gtzUFixed(a);
|
191
|
+
}
|
192
|
+
|
193
|
+
/// @dev return true if UFixed a is zero
|
194
|
+
function eqz(UFixed a) public pure returns (bool isZero) {
|
195
|
+
return eqzUFixed(a);
|
196
|
+
}
|
197
|
+
|
198
|
+
function zero() public pure returns (UFixed) {
|
199
|
+
return UFixed.wrap(0);
|
200
|
+
}
|
201
|
+
|
202
|
+
/// @dev return the absolute delta between two UFixed numbers
|
203
|
+
function delta(UFixed a, UFixed b) public pure returns (UFixed) {
|
204
|
+
return deltaUFixed(a, b);
|
205
|
+
}
|
206
|
+
}
|
@@ -0,0 +1,91 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
type VersionPart is uint8;
|
5
|
+
|
6
|
+
using {
|
7
|
+
versionPartGt as >,
|
8
|
+
versionPartEq as ==,
|
9
|
+
VersionPartLib.toInt
|
10
|
+
}
|
11
|
+
for VersionPart global;
|
12
|
+
|
13
|
+
function versionPartGt(VersionPart a, VersionPart b) pure returns(bool isGreaterThan) { return VersionPart.unwrap(a) > VersionPart.unwrap(b); }
|
14
|
+
function versionPartEq(VersionPart a, VersionPart b) pure returns(bool isSame) { return VersionPart.unwrap(a) == VersionPart.unwrap(b); }
|
15
|
+
function toVersionPart(uint8 versionPart) pure returns(VersionPart) { return VersionPart.wrap(versionPart); }
|
16
|
+
|
17
|
+
library VersionPartLib {
|
18
|
+
function toInt(VersionPart x) external pure returns(uint) { return VersionPart.unwrap(x); }
|
19
|
+
}
|
20
|
+
|
21
|
+
type Version is uint24; // contains major,minor,patch version parts
|
22
|
+
|
23
|
+
using {
|
24
|
+
versionGt as >,
|
25
|
+
versionEq as ==,
|
26
|
+
VersionLib.toInt,
|
27
|
+
VersionLib.toMajorPart,
|
28
|
+
VersionLib.toVersionParts
|
29
|
+
}
|
30
|
+
for Version global;
|
31
|
+
|
32
|
+
function versionGt(Version a, Version b) pure returns(bool isGreaterThan) { return Version.unwrap(a) > Version.unwrap(b); }
|
33
|
+
function versionEq(Version a, Version b) pure returns(bool isSame) { return Version.unwrap(a) == Version.unwrap(b); }
|
34
|
+
|
35
|
+
function toVersion(
|
36
|
+
VersionPart major,
|
37
|
+
VersionPart minor,
|
38
|
+
VersionPart patch
|
39
|
+
)
|
40
|
+
pure
|
41
|
+
returns(Version)
|
42
|
+
{
|
43
|
+
uint majorInt = major.toInt();
|
44
|
+
uint minorInt = minor.toInt();
|
45
|
+
uint patchInt = patch.toInt();
|
46
|
+
|
47
|
+
return Version.wrap(
|
48
|
+
uint24(
|
49
|
+
(majorInt << 16) + (minorInt << 8) + patchInt));
|
50
|
+
}
|
51
|
+
|
52
|
+
function zeroVersion() pure returns(Version) {
|
53
|
+
return toVersion(toVersionPart(0), toVersionPart(0), toVersionPart(0));
|
54
|
+
}
|
55
|
+
|
56
|
+
library VersionLib {
|
57
|
+
function toInt(Version version) external pure returns(uint) { return Version.unwrap(version); }
|
58
|
+
|
59
|
+
function toMajorPart(Version version)
|
60
|
+
external
|
61
|
+
pure
|
62
|
+
returns(VersionPart major)
|
63
|
+
{
|
64
|
+
uint24 versionInt = Version.unwrap(version);
|
65
|
+
uint8 majorInt = uint8(versionInt >> 16);
|
66
|
+
return VersionPart.wrap(majorInt);
|
67
|
+
}
|
68
|
+
|
69
|
+
function toVersionParts(Version version)
|
70
|
+
external
|
71
|
+
pure
|
72
|
+
returns(
|
73
|
+
VersionPart major,
|
74
|
+
VersionPart minor,
|
75
|
+
VersionPart patch
|
76
|
+
)
|
77
|
+
{
|
78
|
+
uint24 versionInt = Version.unwrap(version);
|
79
|
+
uint8 majorInt = uint8(versionInt >> 16);
|
80
|
+
|
81
|
+
versionInt -= majorInt << 16;
|
82
|
+
uint8 minorInt = uint8(versionInt >> 8);
|
83
|
+
uint8 patchInt = uint8(versionInt - (minorInt << 8));
|
84
|
+
|
85
|
+
return (
|
86
|
+
toVersionPart(majorInt),
|
87
|
+
toVersionPart(minorInt),
|
88
|
+
toVersionPart(patchInt)
|
89
|
+
);
|
90
|
+
}
|
91
|
+
}
|
package/package.json
CHANGED
@@ -1,14 +1,18 @@
|
|
1
1
|
{
|
2
2
|
"name": "@etherisc/gif-next",
|
3
|
-
"version": "0.0.2-
|
3
|
+
"version": "0.0.2-efdb520-159",
|
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": {
|
7
|
-
"build": "
|
8
|
-
"test": "
|
9
|
-
"ptest": "
|
10
|
-
"test-with-gas": "REPORT_GAS=true
|
11
|
-
"coverage": "
|
7
|
+
"build": "hh compile",
|
8
|
+
"test": "hh test",
|
9
|
+
"ptest": "hh test --parallel",
|
10
|
+
"test-with-gas": "REPORT_GAS=true hh test",
|
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'",
|
15
|
+
"eslint": "eslint ."
|
12
16
|
},
|
13
17
|
"repository": {
|
14
18
|
"type": "git",
|
@@ -25,12 +29,23 @@
|
|
25
29
|
],
|
26
30
|
"homepage": "https://github.com/etherisc/gif-next#readme",
|
27
31
|
"devDependencies": {
|
28
|
-
"@nomicfoundation/hardhat-foundry": "^1.
|
32
|
+
"@nomicfoundation/hardhat-foundry": "^1.1.1",
|
29
33
|
"@nomicfoundation/hardhat-toolbox": "^3.0.0",
|
30
|
-
"hardhat": "^
|
34
|
+
"@nomicfoundation/hardhat-verify": "^1.1.1",
|
35
|
+
"@typescript-eslint/eslint-plugin": "^6.7.2",
|
36
|
+
"@typescript-eslint/parser": "^6.7.2",
|
37
|
+
"dotenv": "^16.3.1",
|
38
|
+
"eslint": "^8.50.0",
|
39
|
+
"hardhat": "^2.17.2",
|
40
|
+
"prettier": "^3.0.3",
|
41
|
+
"prettier-plugin-solidity": "^1.1.3",
|
42
|
+
"typescript": "^5"
|
31
43
|
},
|
32
44
|
"dependencies": {
|
33
45
|
"@openzeppelin/contracts": "^4.9.3",
|
34
|
-
"@openzeppelin/contracts-upgradeable": "^4.9.3"
|
46
|
+
"@openzeppelin/contracts-upgradeable": "^4.9.3",
|
47
|
+
"abi-coder": "^5.0.0",
|
48
|
+
"ethers": "^6.7.1",
|
49
|
+
"winston": "^3.10.0"
|
35
50
|
}
|
36
51
|
}
|