Skip to content

Commit

Permalink
finish breaking up function casts and adding natspec
Browse files Browse the repository at this point in the history
  • Loading branch information
0age committed Nov 4, 2024
1 parent 430864c commit e4a386d
Show file tree
Hide file tree
Showing 13 changed files with 2,052 additions and 2,932 deletions.
2 changes: 1 addition & 1 deletion foundry.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ extra_output_files = ["irOptimized"]
# TODO: use default with everything but FunctionSpecializer (F)

[fmt]
line_length = 200
line_length = 210
tab_width = 4
bracket_spacing = true
15 changes: 3 additions & 12 deletions src/interfaces/ITheCompact.sol
Original file line number Diff line number Diff line change
Expand Up @@ -193,18 +193,9 @@ interface ITheCompact {
* @param signature The Permit2 signature from the depositor authorizing the deposit.
* @return id The ERC6909 token identifier of the associated resource lock.
*/
function deposit(
address token,
uint256 amount,
uint256 nonce,
uint256 deadline,
address depositor,
address allocator,
ResetPeriod resetPeriod,
Scope scope,
address recipient,
bytes calldata signature
) external returns (uint256 id);
function deposit(address token, uint256 amount, uint256 nonce, uint256 deadline, address depositor, address allocator, ResetPeriod resetPeriod, Scope scope, address recipient, bytes calldata signature)
external
returns (uint256 id);

/**
* @notice External function for depositing ERC20 tokens using Permit2 authorization and
Expand Down
1,021 changes: 1,021 additions & 0 deletions src/lib/ClaimHashFunctionCastLib.sol

Large diffs are not rendered by default.

70 changes: 30 additions & 40 deletions src/lib/ClaimHashLib.sol
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ import { ResetPeriod } from "../types/ResetPeriod.sol";
import { Scope } from "../types/Scope.sol";

import { EfficiencyLib } from "./EfficiencyLib.sol";
import { FunctionCastLib } from "./FunctionCastLib.sol";
import { ClaimHashFunctionCastLib } from "./ClaimHashFunctionCastLib.sol";
import { HashLib } from "./HashLib.sol";

/**
Expand All @@ -80,25 +80,25 @@ import { HashLib } from "./HashLib.sol";
* claims, allocated transfers, and withdrawals.
*/
library ClaimHashLib {
using ClaimHashFunctionCastLib for function(uint256, uint256) internal pure returns (uint256);
using ClaimHashFunctionCastLib for function(uint256, uint256) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(uint256, uint256, function(uint256, uint256) internal view returns (bytes32)) internal view returns (bytes32);
using ClaimHashFunctionCastLib for function(uint256, uint256, function(uint256, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(uint256, uint256, function(uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(uint256, uint256, function(uint256, uint256) internal view returns (bytes32, bytes32)) internal view returns (bytes32, bytes32, bytes32);
using ClaimHashFunctionCastLib for function(uint256, uint256, function (uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32, bytes32);
using ClaimHashFunctionCastLib for function(BasicClaim calldata) internal view returns (bytes32);
using ClaimHashFunctionCastLib for function(MultichainClaim calldata) internal view returns (bytes32);
using ClaimHashFunctionCastLib for function(ExogenousMultichainClaim calldata) internal view returns (bytes32);
using ClaimHashFunctionCastLib for function(QualifiedClaim calldata) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(QualifiedMultichainClaim calldata) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(ExogenousQualifiedMultichainClaim calldata) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(MultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(ExogenousMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32);
using ClaimHashFunctionCastLib for function(QualifiedClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using ClaimHashFunctionCastLib for function(QualifiedMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using ClaimHashFunctionCastLib for function(ExogenousQualifiedMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using EfficiencyLib for uint256;
using FunctionCastLib for function (uint256, uint256) internal pure returns (uint256);
using FunctionCastLib for function (uint256, uint256) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (uint256, uint256, function(uint256, uint256) internal view returns (bytes32)) internal view returns (bytes32);
using FunctionCastLib for function (uint256, uint256, function(uint256, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (uint256, uint256, function(uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (uint256, uint256, function(uint256, uint256) internal view returns (bytes32, bytes32)) internal view returns (bytes32, bytes32, bytes32);
using FunctionCastLib for function (uint256, uint256, function (uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32)) internal view returns (bytes32, bytes32, bytes32);
using FunctionCastLib for function (BasicClaim calldata) internal view returns (bytes32);
using FunctionCastLib for function (MultichainClaim calldata) internal view returns (bytes32);
using FunctionCastLib for function (ExogenousMultichainClaim calldata) internal view returns (bytes32);
using FunctionCastLib for function (QualifiedClaim calldata) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (QualifiedMultichainClaim calldata) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (ExogenousQualifiedMultichainClaim calldata) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (MultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (ExogenousMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32);
using FunctionCastLib for function (QualifiedClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using FunctionCastLib for function (QualifiedMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using FunctionCastLib for function (ExogenousQualifiedMultichainClaimWithWitness calldata) internal view returns (bytes32, bytes32, bytes32);
using HashLib for uint256;
using HashLib for BatchClaimComponent[];
using HashLib for SplitBatchClaimComponent[];
Expand Down Expand Up @@ -215,14 +215,12 @@ library ClaimHashLib {
}

function toMessageHashes(ExogenousQualifiedBatchMultichainClaim calldata claim) internal view returns (bytes32 claimHash, bytes32 qualificationHash) {
return
_toGenericMessageHashWithQualificationHash.usingExogenousQualifiedBatchMultichainClaim()(claim, claim.claims.toIdsAndAmountsHash(), HashLib.toExogenousQualifiedMultichainClaimMessageHash);
return _toGenericMessageHashWithQualificationHash.usingExogenousQualifiedBatchMultichainClaim()(claim, claim.claims.toIdsAndAmountsHash(), HashLib.toExogenousQualifiedMultichainClaimMessageHash);
}

function toMessageHashes(ExogenousQualifiedSplitBatchMultichainClaim calldata claim) internal view returns (bytes32 claimHash, bytes32 qualificationHash) {
return _toGenericMessageHashWithQualificationHash.usingExogenousQualifiedSplitBatchMultichainClaim()(
claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toExogenousQualifiedMultichainClaimMessageHash
);
return
_toGenericMessageHashWithQualificationHash.usingExogenousQualifiedSplitBatchMultichainClaim()(claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toExogenousQualifiedMultichainClaimMessageHash);
}

///// CATEGORY 4: Claim with witness message & type hashes /////
Expand Down Expand Up @@ -271,9 +269,7 @@ library ClaimHashLib {
}

function toMessageHashes(ExogenousSplitBatchMultichainClaimWithWitness calldata claim) internal view returns (bytes32 claimHash, bytes32 typehash) {
return _toGenericMultichainClaimWithWitnessMessageHash.usingExogenousSplitBatchMultichainClaimWithWitness()(
claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toExogenousMultichainClaimMessageHash
);
return _toGenericMultichainClaimWithWitnessMessageHash.usingExogenousSplitBatchMultichainClaimWithWitness()(claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toExogenousMultichainClaimMessageHash);
}

///// CATEGORY 5: Qualified claim with witness message, qualification, & type hashes /////
Expand Down Expand Up @@ -306,9 +302,7 @@ library ClaimHashLib {
}

function toMessageHashes(QualifiedSplitBatchMultichainClaimWithWitness calldata claim) internal view returns (bytes32 claimHash, bytes32 qualificationHash, bytes32 typehash) {
return _toGenericQualifiedMultichainClaimWithWitnessMessageHash.usingQualifiedSplitBatchMultichainClaimWithWitness()(
claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toMultichainClaimMessageHash
);
return _toGenericQualifiedMultichainClaimWithWitnessMessageHash.usingQualifiedSplitBatchMultichainClaimWithWitness()(claim, claim.claims.toSplitIdsAndAmountsHash(), HashLib.toMultichainClaimMessageHash);
}

function toMessageHashes(ExogenousQualifiedMultichainClaimWithWitness calldata claim) internal view returns (bytes32 claimHash, bytes32 qualificationHash, bytes32 typehash) {
Expand Down Expand Up @@ -418,20 +412,16 @@ library ClaimHashLib {
return _toGenericQualifiedClaimWithWitnessMessageHash.usingQualifiedClaimWithWitness()(claim, uint256(0x40).asStubborn(), HashLib.toMessageHashWithWitness);
}

function _toGenericQualifiedMultichainClaimWithWitnessMessageHash(
uint256 claim,
uint256 additionalInput,
function (uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32) hashFn
) private view returns (bytes32, /* claimHash */ bytes32 qualificationHash, bytes32 /* typehash */ ) {
function _toGenericQualifiedMultichainClaimWithWitnessMessageHash(uint256 claim, uint256 additionalInput, function (uint256, uint256, bytes32, bytes32, uint256) internal view returns (bytes32) hashFn)
private
view
returns (bytes32, /* claimHash */ bytes32 qualificationHash, bytes32 /* typehash */ )
{
(bytes32 messageHash, bytes32 typehash) = _toGenericMultichainClaimWithWitnessMessageHashPriorToQualification(claim, additionalInput, hashFn);
return (messageHash, claim.toQualificationMessageHash(messageHash, uint256(0x40).asStubborn()), typehash);
}

function _toQualifiedMultichainClaimWithWitnessMessageHash(QualifiedMultichainClaimWithWitness calldata claim)
private
view
returns (bytes32 claimHash, bytes32 qualificationHash, bytes32 typehash)
{
function _toQualifiedMultichainClaimWithWitnessMessageHash(QualifiedMultichainClaimWithWitness calldata claim) private view returns (bytes32 claimHash, bytes32 qualificationHash, bytes32 typehash) {
return _toGenericQualifiedMultichainClaimWithWitnessMessageHash.usingQualifiedMultichainClaimWithWitness()(
claim, HashLib.toSingleIdAndAmountHash.usingQualifiedMultichainClaimWithWitness()(claim, uint256(0x80).asStubborn()), HashLib.toMultichainClaimMessageHash
);
Expand Down
Loading

0 comments on commit e4a386d

Please sign in to comment.