@etherisc/gif-next 0.0.2-ad36bbd → 0.0.2-b1fb5f9

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 (130) hide show
  1. package/README.md +24 -0
  2. package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
  3. package/artifacts/contracts/components/Component.sol/Component.json +7 -7
  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 +6 -6
  8. package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +8 -8
  10. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  11. package/artifacts/contracts/components/Pool.sol/Pool.json +29 -11
  12. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  13. package/artifacts/contracts/components/Product.sol/Product.json +31 -13
  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/types/TypeA.sol/TypeALib.dbg.json +1 -1
  29. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
  30. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  31. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
  32. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  33. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +60 -60
  34. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  35. package/artifacts/contracts/instance/Instance.sol/Instance.json +122 -64
  36. package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +1 -1
  37. package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +1 -1
  38. package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +1 -1
  39. package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +1 -1
  40. package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +1 -1
  41. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
  42. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.json +24 -24
  43. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +1 -1
  44. package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +48 -6
  45. package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +1 -1
  46. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +1 -1
  47. package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.json +6 -6
  48. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +1 -1
  49. package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +26 -26
  50. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +1 -1
  51. package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +3 -3
  52. package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +1 -1
  53. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
  54. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
  55. package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.json +18 -18
  56. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
  57. package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +18 -18
  58. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +1 -1
  59. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
  60. package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.json +10 -10
  61. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
  62. package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.json +10 -10
  63. package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +1 -1
  64. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +1 -1
  65. package/artifacts/contracts/instance/product/IProductService.sol/IProductService.json +8 -8
  66. package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +1 -1
  67. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +1 -1
  68. package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +54 -12
  69. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  70. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  71. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
  72. package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +1 -1
  73. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +1 -1
  74. package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.json +6 -6
  75. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  76. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +16 -16
  77. package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +1 -1
  78. package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +1 -1
  79. package/artifacts/contracts/registry/Registry.sol/Registerable.json +7 -7
  80. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  81. package/artifacts/contracts/registry/Registry.sol/Registry.json +62 -20
  82. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +1 -1
  83. package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +2 -2
  84. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  85. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +174 -0
  86. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  87. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
  88. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  89. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +85 -3
  90. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +4 -0
  91. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +174 -0
  92. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +4 -0
  93. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +453 -0
  94. package/contracts/components/Component.sol +17 -19
  95. package/contracts/components/IPool.sol +3 -3
  96. package/contracts/components/IProduct.sol +4 -6
  97. package/contracts/components/Pool.sol +6 -13
  98. package/contracts/components/Product.sol +12 -22
  99. package/contracts/experiment/errors/Require.sol +12 -7
  100. package/contracts/experiment/errors/Revert.sol +13 -8
  101. package/contracts/experiment/inheritance/A.sol +8 -11
  102. package/contracts/experiment/inheritance/B.sol +10 -5
  103. package/contracts/experiment/inheritance/C.sol +11 -5
  104. package/contracts/experiment/inheritance/IA.sol +2 -7
  105. package/contracts/experiment/inheritance/IB.sol +3 -2
  106. package/contracts/experiment/inheritance/IC.sol +4 -3
  107. package/contracts/experiment/types/TypeA.sol +14 -9
  108. package/contracts/experiment/types/TypeB.sol +14 -9
  109. package/contracts/instance/IInstance.sol +1 -3
  110. package/contracts/instance/Instance.sol +15 -14
  111. package/contracts/instance/access/Access.sol +63 -116
  112. package/contracts/instance/access/IAccess.sol +28 -48
  113. package/contracts/instance/component/ComponentModule.sol +84 -130
  114. package/contracts/instance/component/IComponent.sol +32 -53
  115. package/contracts/instance/policy/IPolicy.sol +12 -27
  116. package/contracts/instance/policy/PolicyModule.sol +25 -40
  117. package/contracts/instance/pool/IPoolModule.sol +10 -21
  118. package/contracts/instance/pool/PoolModule.sol +28 -38
  119. package/contracts/instance/product/IProductService.sol +9 -18
  120. package/contracts/instance/product/ProductService.sol +54 -47
  121. package/contracts/registry/ChainNft.sol +23 -61
  122. package/contracts/registry/IChainNft.sol +10 -7
  123. package/contracts/registry/IRegistry.sol +51 -39
  124. package/contracts/registry/Registry.sol +99 -66
  125. package/contracts/types/Blocknumber.sol +118 -0
  126. package/contracts/types/ChainId.sol +24 -10
  127. package/contracts/types/NftId.sol +36 -10
  128. package/contracts/types/Timestamp.sol +102 -0
  129. package/contracts/types/UFixed.sol +205 -0
  130. package/package.json +8 -4
@@ -3,102 +3,132 @@ pragma solidity ^0.8.19;
3
3
 
4
4
  import {IChainNft} from "./IChainNft.sol";
5
5
  import {IRegistry, IRegistryLinked, IRegisterable} from "./IRegistry.sol";
6
+ import {NftId, toNftId} from "../types/NftId.sol";
7
+ import {NftIdLib} from "../types/NftId.sol";
6
8
 
7
9
  contract RegistryLinked is IRegistryLinked {
8
-
9
10
  IRegistry internal _registry;
10
-
11
+
11
12
  constructor(address registry) {
12
13
  _registry = IRegistry(registry);
13
14
  }
14
15
 
15
- function getRegistry() external view override returns(IRegistry registry) {
16
+ function getRegistry() external view override returns (IRegistry registry) {
16
17
  return _registry;
17
18
  }
18
-
19
19
  }
20
20
 
21
-
22
- abstract contract Registerable is
23
- RegistryLinked,
24
- IRegisterable
25
- {
21
+ abstract contract Registerable is RegistryLinked, IRegisterable {
22
+ using NftIdLib for NftId;
26
23
 
27
24
  address private _initialOwner;
28
-
29
- constructor(address registry)
30
- RegistryLinked(registry)
31
- {
25
+
26
+ constructor(address registry) RegistryLinked(registry) {
32
27
  _initialOwner = msg.sender;
33
28
  }
34
29
 
35
30
  // getType, getData and register need to be implemented by concrete contract
36
31
 
37
- function isRegisterable() external pure override returns(bool) {
32
+ function isRegisterable() external pure override returns (bool) {
38
33
  return true;
39
34
  }
40
35
 
41
- function getInitialOwner() public view override returns(address deployer) {
36
+ function getInitialOwner() public view override returns (address deployer) {
42
37
  return _initialOwner;
43
38
  }
44
39
 
45
- function isRegistered() public view override returns(bool) {
46
- return _registry.getNftId(address(this)) > 0;
40
+ function isRegistered() public view override returns (bool) {
41
+ NftId nftId = _registry.getNftId(address(this));
42
+ return nftId.gtz();
47
43
  }
48
44
 
49
- function getNftId() public view override returns(uint256 id) {
45
+ function getNftId() public view override returns (NftId nftId) {
50
46
  return _registry.getNftId(address(this));
51
47
  }
52
48
 
53
- function getOwner() public view override returns(address owner) {
54
- uint256 id = _registry.getNftId(address(this));
49
+ function getOwner() public view override returns (address owner) {
50
+ NftId id = _registry.getNftId(address(this));
55
51
  owner = _registry.getOwner(id);
56
52
  return owner != address(0) ? owner : _initialOwner;
57
53
  }
58
-
59
54
  }
60
55
 
61
56
  contract Registry is IRegistry {
62
-
57
+ using NftIdLib for NftId;
63
58
  string public constant EMPTY_URI = "";
64
59
 
65
- mapping(uint256 id => RegistryInfo info) private _info;
66
- mapping(uint256 id => address owner) private _owner;
67
- mapping(address object => uint256 id) private _idByAddress;
60
+ mapping(NftId nftId => RegistryInfo info) private _info;
61
+ mapping(NftId nftId => address owner) private _owner;
62
+ mapping(address object => NftId nftId) private _nftIdByAddress;
68
63
 
69
64
  IChainNft private _chainNft;
70
65
 
71
66
  function initialize(address chainNft) external {
72
- require(address(_chainNft) == address(0), "ERROR:REG-001:ALREADY_INITIALIZED");
67
+ require(
68
+ address(_chainNft) == address(0),
69
+ "ERROR:REG-001:ALREADY_INITIALIZED"
70
+ );
73
71
  _chainNft = IChainNft(chainNft);
74
72
  }
75
73
 
76
- function TOKEN() public pure override returns(uint256) { return 30; }
77
- function INSTANCE() public pure override returns(uint256) { return 40; }
78
- function PRODUCT() public pure override returns(uint256) { return 50; }
79
- function ORACLE() public pure override returns(uint256) { return 60; }
80
- function POOL() public pure override returns(uint256) { return 70; }
81
- function POLICY() public pure override returns(uint256) { return 80; }
82
- function BUNDLE() public pure override returns(uint256) { return 90; }
74
+ function TOKEN() public pure override returns (uint256) {
75
+ return 30;
76
+ }
83
77
 
84
- function register(address objectAddress) external override returns(uint256 nftId) {
85
- require(_idByAddress[objectAddress] == 0, "ERROR:REG-001:ALREADY_REGISTERED");
78
+ function INSTANCE() public pure override returns (uint256) {
79
+ return 40;
80
+ }
81
+
82
+ function PRODUCT() public pure override returns (uint256) {
83
+ return 50;
84
+ }
85
+
86
+ function ORACLE() public pure override returns (uint256) {
87
+ return 60;
88
+ }
89
+
90
+ function POOL() public pure override returns (uint256) {
91
+ return 70;
92
+ }
93
+
94
+ function POLICY() public pure override returns (uint256) {
95
+ return 80;
96
+ }
97
+
98
+ function BUNDLE() public pure override returns (uint256) {
99
+ return 90;
100
+ }
101
+
102
+ function register(
103
+ address objectAddress
104
+ ) external override returns (NftId nftId) {
105
+ require(
106
+ _nftIdByAddress[objectAddress].eqz(),
107
+ "ERROR:REG-002:ALREADY_REGISTERED"
108
+ );
86
109
 
87
110
  IRegisterable registerable = IRegisterable(objectAddress);
88
- require(registerable.isRegisterable(), "ERROR:REG-002:NOT_REGISTERABLE");
111
+ require(
112
+ registerable.isRegisterable(),
113
+ "ERROR:REG-003:NOT_REGISTERABLE"
114
+ );
89
115
 
90
116
  // check parent exists (for objects not instances)
91
- if(registerable.getType() != INSTANCE()) {
92
- RegistryInfo memory parentInfo = _info[registerable.getParentNftId()];
93
- require(parentInfo.nftId > 0, "ERROR:REG-003:PARENT_NOT_FOUND");
117
+ if (registerable.getType() != INSTANCE()) {
118
+ RegistryInfo memory parentInfo = _info[
119
+ registerable.getParentNftId()
120
+ ];
121
+ require(parentInfo.nftId.gtz(), "ERROR:REG-004:PARENT_NOT_FOUND");
94
122
  // check validity of parent relation, valid relations are
95
123
  // policy -> product, bundle -> pool, product -> instance, pool -> instance
96
124
  }
97
125
 
98
- nftId = _chainNft.mint(
99
- registerable.getInitialOwner(),
100
- EMPTY_URI);
101
-
126
+ uint256 mintedTokenId = _chainNft.mint(
127
+ registerable.getInitialOwner(),
128
+ EMPTY_URI
129
+ );
130
+ nftId = toNftId(mintedTokenId);
131
+
102
132
  RegistryInfo memory info = RegistryInfo(
103
133
  nftId,
104
134
  registerable.getParentNftId(),
@@ -108,30 +138,31 @@ contract Registry is IRegistry {
108
138
  );
109
139
 
110
140
  _info[nftId] = info;
111
- _idByAddress[objectAddress] = nftId;
141
+ _nftIdByAddress[objectAddress] = nftId;
112
142
 
113
143
  // add logging
114
144
  }
115
145
 
116
-
117
146
  function registerObjectForInstance(
118
- uint256 parentNftId,
147
+ NftId parentNftId,
119
148
  uint256 objectType,
120
149
  address initialOwner
121
150
  )
122
- external
151
+ external
123
152
  override
124
- // TODO add onlyRegisteredInstance
125
- returns(uint256 nftId)
153
+ returns (
154
+ // TODO add onlyRegisteredInstance
155
+ NftId nftId
156
+ )
126
157
  {
127
158
  // TODO add more validation
128
159
  require(
129
160
  objectType == POLICY() || objectType == BUNDLE(),
130
- "ERROR:REG-005:TYPE_INVALID");
161
+ "ERROR:REG-005:TYPE_INVALID"
162
+ );
131
163
 
132
- nftId = _chainNft.mint(
133
- initialOwner,
134
- EMPTY_URI);
164
+ uint256 mintedTokenId = _chainNft.mint(initialOwner, EMPTY_URI);
165
+ nftId = toNftId(mintedTokenId);
135
166
 
136
167
  RegistryInfo memory info = RegistryInfo(
137
168
  nftId,
@@ -146,31 +177,33 @@ contract Registry is IRegistry {
146
177
  // add logging
147
178
  }
148
179
 
149
-
150
- function getObjectCount() external view override returns(uint256) {
180
+ function getObjectCount() external view override returns (uint256) {
151
181
  return _chainNft.totalSupply();
152
182
  }
153
183
 
154
-
155
- function getNftId(address object) external view override returns(uint256 id) {
156
- return _idByAddress[object];
184
+ function getNftId(
185
+ address object
186
+ ) external view override returns (NftId id) {
187
+ return _nftIdByAddress[object];
157
188
  }
158
189
 
159
-
160
- function isRegistered(address object) external view override returns(bool) {
161
- return _idByAddress[object] > 0;
190
+ function isRegistered(
191
+ address object
192
+ ) external view override returns (bool) {
193
+ return _nftIdByAddress[object].gtz();
162
194
  }
163
195
 
164
-
165
- function getInfo(uint256 nftId) external view override returns(RegistryInfo memory info) {
196
+ function getInfo(
197
+ NftId nftId
198
+ ) external view override returns (RegistryInfo memory info) {
166
199
  return _info[nftId];
167
200
  }
168
201
 
169
- function getOwner(uint256 nftId) external view override returns(address) {
170
- return _chainNft.ownerOf(nftId);
202
+ function getOwner(NftId nftId) external view override returns (address) {
203
+ return _chainNft.ownerOf(nftId.toInt());
171
204
  }
172
205
 
173
- function getNftAddress() external view override returns(address nft) {
206
+ function getNftAddress() external view override returns (address nft) {
174
207
  return address(_chainNft);
175
208
  }
176
209
  }
@@ -0,0 +1,118 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.19;
3
+
4
+ type Blocknumber is uint32;
5
+
6
+ using {
7
+ gtBlocknumber as >,
8
+ gteBlocknumber as >=,
9
+ ltBlocknumber as <,
10
+ lteBlocknumber as <=,
11
+ eqBlocknumber as ==,
12
+ neBlocknumber as !=,
13
+ BlocknumberLib.toInt
14
+ } for Blocknumber global;
15
+
16
+ /// @dev return true if Blocknumber a is greater than Blocknumber b
17
+ function gtBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
18
+ return Blocknumber.unwrap(a) > Blocknumber.unwrap(b);
19
+ }
20
+
21
+ /// @dev return true if Blocknumber a is greater than or equal to Blocknumber b
22
+ function gteBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
23
+ return Blocknumber.unwrap(a) >= Blocknumber.unwrap(b);
24
+ }
25
+
26
+ /// @dev return true if Blocknumber a is less than Blocknumber b
27
+ function ltBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
28
+ return Blocknumber.unwrap(a) < Blocknumber.unwrap(b);
29
+ }
30
+
31
+ /// @dev return true if Blocknumber a is less than or equal to Blocknumber b
32
+ function lteBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
33
+ return Blocknumber.unwrap(a) <= Blocknumber.unwrap(b);
34
+ }
35
+
36
+ /// @dev return true if Blocknumber a is equal to Blocknumber b
37
+ function eqBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
38
+ return Blocknumber.unwrap(a) == Blocknumber.unwrap(b);
39
+ }
40
+
41
+ /// @dev return true if Blocknumber a is not equal to Blocknumber b
42
+ function neBlocknumber(Blocknumber a, Blocknumber b) pure returns (bool) {
43
+ return Blocknumber.unwrap(a) != Blocknumber.unwrap(b);
44
+ }
45
+
46
+ /// @dev Converts the uint256 to a Blocknumber.
47
+ function toBlocknumber(uint256 blocknum) pure returns (Blocknumber) {
48
+ return Blocknumber.wrap(uint32(blocknum));
49
+ }
50
+
51
+ function blockBlocknumber() view returns (Blocknumber) {
52
+ return toBlocknumber(block.number);
53
+ }
54
+
55
+ /// @dev Return the Blocknumber zero (0)
56
+ function zeroBlocknumber() pure returns (Blocknumber) {
57
+ return toBlocknumber(0);
58
+ }
59
+
60
+ /// @dev Return the current block number
61
+ function blockNumber() view returns (Blocknumber) {
62
+ return toBlocknumber(block.number);
63
+ }
64
+
65
+ library BlocknumberLib {
66
+ /// @dev return true if Blocknumber a is greater than Blocknumber b
67
+ function gt(
68
+ Blocknumber a,
69
+ Blocknumber b
70
+ ) public pure returns (bool isAfter) {
71
+ return gtBlocknumber(a, b);
72
+ }
73
+
74
+ /// @dev return true if Blocknumber a is greater than or equal to Blocknumber b
75
+ function gte(
76
+ Blocknumber a,
77
+ Blocknumber b
78
+ ) public pure returns (bool isAfterOrSame) {
79
+ return gteBlocknumber(a, b);
80
+ }
81
+
82
+ /// @dev return true if Blocknumber a is less than Blocknumber b
83
+ function lt(
84
+ Blocknumber a,
85
+ Blocknumber b
86
+ ) public pure returns (bool isBefore) {
87
+ return ltBlocknumber(a, b);
88
+ }
89
+
90
+ /// @dev return true if Blocknumber a is less than or equal to Blocknumber b
91
+ function lte(
92
+ Blocknumber a,
93
+ Blocknumber b
94
+ ) public pure returns (bool isBeforeOrSame) {
95
+ return lteBlocknumber(a, b);
96
+ }
97
+
98
+ /// @dev return true if Blocknumber a is equal to Blocknumber b
99
+ function eq(
100
+ Blocknumber a,
101
+ Blocknumber b
102
+ ) public pure returns (bool isSame) {
103
+ return eqBlocknumber(a, b);
104
+ }
105
+
106
+ /// @dev return true if Blocknumber a is not equal to Blocknumber b
107
+ function ne(
108
+ Blocknumber a,
109
+ Blocknumber b
110
+ ) public pure returns (bool isDifferent) {
111
+ return neBlocknumber(a, b);
112
+ }
113
+
114
+ /// @dev converts the Blocknumber to a uint256
115
+ function toInt(Blocknumber blocknumber) public pure returns (uint256) {
116
+ return uint256(uint32(Blocknumber.unwrap(blocknumber)));
117
+ }
118
+ }
@@ -1,24 +1,38 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.19;
3
3
 
4
- // bytes5 (uint40) allows for chain ids up to 13 digits
4
+ /// @dev bytes5 (uint40) allows for chain ids up to 13 digits
5
5
  type ChainId is bytes5;
6
6
 
7
7
  // type bindings
8
- using {
9
- eqChainId as ==,
10
- neChainId as !=,
11
- ChainIdLib.toInt
12
- } for ChainId global;
8
+ using {eqChainId as ==, neChainId as !=, ChainIdLib.toInt} for ChainId global;
13
9
 
14
10
  // general pure free functions
15
- function toChainId(uint256 chainId) pure returns(ChainId) { return ChainId.wrap(bytes5(uint40(chainId))); }
11
+ /// @dev Converts the uint256 to a ChainId.
12
+ function toChainId(uint256 chainId) pure returns (ChainId) {
13
+ return ChainId.wrap(bytes5(uint40(chainId)));
14
+ }
15
+
16
+ /// @dev Return the ChainId for the chain the contract is deployed to
17
+ function thisChainId() view returns (ChainId) {
18
+ return toChainId(block.chainid);
19
+ }
16
20
 
17
21
  // pure free functions for operators
18
- function eqChainId(ChainId a, ChainId b) pure returns(bool isSame) { return ChainId.unwrap(a) == ChainId.unwrap(b); }
19
- function neChainId(ChainId a, ChainId b) pure returns(bool isDifferent) { return ChainId.unwrap(a) != ChainId.unwrap(b); }
22
+ /// @dev Returns true if the values are equal (==).
23
+ function eqChainId(ChainId a, ChainId b) pure returns (bool isSame) {
24
+ return ChainId.unwrap(a) == ChainId.unwrap(b);
25
+ }
26
+
27
+ /// @dev Returns true if the values are not equal (!=).
28
+ function neChainId(ChainId a, ChainId b) pure returns (bool isDifferent) {
29
+ return ChainId.unwrap(a) != ChainId.unwrap(b);
30
+ }
20
31
 
21
32
  // library functions that operate on user defined type
22
33
  library ChainIdLib {
23
- function toInt(ChainId chainId) internal pure returns(uint256) { return uint256(uint40(ChainId.unwrap(chainId))); }
34
+ /// @dev Converts the ChainId to a uint256.
35
+ function toInt(ChainId chainId) internal pure returns (uint256) {
36
+ return uint256(uint40(ChainId.unwrap(chainId)));
37
+ }
24
38
  }
@@ -5,21 +5,47 @@ pragma solidity ^0.8.19;
5
5
  type NftId is uint96;
6
6
 
7
7
  // type bindings
8
- using {
9
- eqNftId as ==,
10
- neNftId as !=,
11
- NftIdLib.toInt
12
- } for NftId global;
8
+ using {eqNftId as ==, neNftId as !=, NftIdLib.toInt} for NftId global;
13
9
 
14
10
  // general pure free functions
15
- function toNftId(uint256 id) pure returns(NftId) { return NftId.wrap(uint96(id)); }
16
- function gtz(NftId a) pure returns(bool) { return NftId.unwrap(a) > 0; }
11
+ /// @dev Converts the uint256 to a NftId.
12
+ function toNftId(uint256 id) pure returns (NftId) {
13
+ return NftId.wrap(uint96(id));
14
+ }
15
+
16
+ /// @dev Return the NftId zero (0)
17
+ function zeroNftId() pure returns (NftId) {
18
+ return NftId.wrap(0);
19
+ }
17
20
 
18
21
  // pure free functions for operators
19
- function eqNftId(NftId a, NftId b) pure returns(bool isSame) { return NftId.unwrap(a) == NftId.unwrap(b); }
20
- function neNftId(NftId a, NftId b) pure returns(bool isDifferent) { return NftId.unwrap(a) != NftId.unwrap(b); }
22
+ function eqNftId(NftId a, NftId b) pure returns (bool isSame) {
23
+ return NftId.unwrap(a) == NftId.unwrap(b);
24
+ }
25
+
26
+ function neNftId(NftId a, NftId b) pure returns (bool isDifferent) {
27
+ return NftId.unwrap(a) != NftId.unwrap(b);
28
+ }
21
29
 
22
30
  // library functions that operate on user defined type
23
31
  library NftIdLib {
24
- function toInt(NftId nftId) internal pure returns(uint256) { return uint256(NftId.unwrap(nftId)); }
32
+ /// @dev Converts the NftId to a uint256.
33
+ function toInt(NftId nftId) public pure returns (uint96) {
34
+ return uint96(NftId.unwrap(nftId));
35
+ }
36
+
37
+ /// @dev Returns true if the value is non-zero (> 0).
38
+ function gtz(NftId a) public pure returns (bool) {
39
+ return NftId.unwrap(a) > 0;
40
+ }
41
+
42
+ /// @dev Returns true if the value is zero (== 0).
43
+ function eqz(NftId a) public pure returns (bool) {
44
+ return NftId.unwrap(a) == 0;
45
+ }
46
+
47
+ /// @dev Returns true if the values are equal (==).
48
+ function eq(NftId a, NftId b) public pure returns (bool isSame) {
49
+ return eqNftId(a, b);
50
+ }
25
51
  }
@@ -0,0 +1,102 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.19;
3
+
4
+ type Timestamp is uint40;
5
+
6
+ using {
7
+ gtTimestamp as >,
8
+ gteTimestamp as >=,
9
+ ltTimestamp as <,
10
+ lteTimestamp as <=,
11
+ eqTimestamp as ==,
12
+ neTimestamp as !=
13
+ } for Timestamp global;
14
+
15
+ /// @dev return true if Timestamp a is after Timestamp b
16
+ function gtTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
17
+ return Timestamp.unwrap(a) > Timestamp.unwrap(b);
18
+ }
19
+
20
+ /// @dev return true if Timestamp a is after or equal to Timestamp b
21
+ function gteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
22
+ return Timestamp.unwrap(a) >= Timestamp.unwrap(b);
23
+ }
24
+
25
+ /// @dev return true if Timestamp a is before Timestamp b
26
+ function ltTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
27
+ return Timestamp.unwrap(a) < Timestamp.unwrap(b);
28
+ }
29
+
30
+ /// @dev return true if Timestamp a is before or equal to Timestamp b
31
+ function lteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
32
+ return Timestamp.unwrap(a) <= Timestamp.unwrap(b);
33
+ }
34
+
35
+ /// @dev return true if Timestamp a is equal to Timestamp b
36
+ function eqTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
37
+ return Timestamp.unwrap(a) == Timestamp.unwrap(b);
38
+ }
39
+
40
+ /// @dev return true if Timestamp a is not equal to Timestamp b
41
+ function neTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
42
+ return Timestamp.unwrap(a) != Timestamp.unwrap(b);
43
+ }
44
+
45
+ /// @dev Converts the uint256 to a Timestamp.
46
+ function toTimestamp(uint256 timestamp) pure returns (Timestamp) {
47
+ return Timestamp.wrap(uint40(timestamp));
48
+ }
49
+
50
+ function blockTimestamp() view returns (Timestamp) {
51
+ return toTimestamp(block.timestamp);
52
+ }
53
+
54
+ /// @dev Return the Timestamp zero (0)
55
+ function zeroTimestamp() pure returns (Timestamp) {
56
+ return toTimestamp(0);
57
+ }
58
+
59
+ library TimestampLib {
60
+ /// @dev return true if Timestamp a is after Timestamp b
61
+ function gt(Timestamp a, Timestamp b) public pure returns (bool isAfter) {
62
+ return gtTimestamp(a, b);
63
+ }
64
+
65
+ /// @dev return true if Timestamp a is after or the same than Timestamp b
66
+ function gte(
67
+ Timestamp a,
68
+ Timestamp b
69
+ ) public pure returns (bool isAfterOrSame) {
70
+ return gteTimestamp(a, b);
71
+ }
72
+
73
+ /// @dev return true if Timestamp a is before Timestamp b
74
+ function lt(Timestamp a, Timestamp b) public pure returns (bool isBefore) {
75
+ return ltTimestamp(a, b);
76
+ }
77
+
78
+ /// @dev return true if Timestamp a is before or the same than Timestamp b
79
+ function lte(
80
+ Timestamp a,
81
+ Timestamp b
82
+ ) public pure returns (bool isBeforeOrSame) {
83
+ return lteTimestamp(a, b);
84
+ }
85
+
86
+ /// @dev return true if Timestamp a is equal to Timestamp b
87
+ function eq(Timestamp a, Timestamp b) public pure returns (bool isSame) {
88
+ return eqTimestamp(a, b);
89
+ }
90
+
91
+ /// @dev return true if Timestamp a is not equal to Timestamp b
92
+ function ne(
93
+ Timestamp a,
94
+ Timestamp b
95
+ ) public pure returns (bool isDifferent) {
96
+ return neTimestamp(a, b);
97
+ }
98
+
99
+ function toInt(Timestamp timestamp) public pure returns (uint256) {
100
+ return uint256(uint40(Timestamp.unwrap(timestamp)));
101
+ }
102
+ }