源码:
pragma solidity ^0.8.7;
contract TestContract1 {
address public owner = msg.sender;
function setOwner(address _owner) public {
require(msg.sender == owner, "not owner");
owner = _owner;
}
}
contract TestContract2 {
address public owner = msg.sender;
uint public value = msg.value;
uint public x;
uint public y;
constructor(uint _x, uint _y) payable {
x = _x;
y = _y;
}
}
contract Proxy {
event Deploy(address);
function deploy(bytes memory _code) external payable returns (address addr) {
assembly {
// create(v, p, n)
// v 代表发送以太坊主币的数量
// p 代表内存中机器码开始的位置
// n 代表内存中机器码整个的大小
addr := create(callvalue(), add(_code, 0x20), mload(_code))
}
require(addr != address(0), "deploy failed");
emit Deploy(addr);
}
function execute(address _target, bytes memory _data) external payable {
(bool success,) = _target.call{value:msg.value}(_data);
require(success,"failed");
}
}
contract Helper {
function getBytecode1() external pure returns (bytes memory) {
bytes memory bytecode = type(TestContract1).creationCode;
return bytecode;
}
function getBytecode2(uint _x, uint _y) external pure returns (bytes memory) {
bytes memory bytecode = type(TestContract2).creationCode;
return abi.encodePacked(bytecode, abi.encode(_x, _y));
}
function grtCalldata(address _owner) external pure returns (bytes memory) {
return abi.encodeWithSignature("setOwner(address)", _owner);
}
}
这一节有点复杂,和前面的课程衔接性不强,需要仔细学习几遍,还有几个没有学过的知识点,需要先了解一下。