2020-12-16 17:16:37 +00:00
// Code generated - DO NOT EDIT.
// This file is a generated binding and any manual changes will be lost.
package contracts
import (
"math/big"
"strings"
2021-05-21 01:25:53 +07:00
ethereum "github.com/ledgerwatch/erigon"
"github.com/ledgerwatch/erigon/accounts/abi"
"github.com/ledgerwatch/erigon/accounts/abi/bind"
"github.com/ledgerwatch/erigon/common"
"github.com/ledgerwatch/erigon/core/types"
"github.com/ledgerwatch/erigon/event"
2020-12-16 17:16:37 +00:00
)
// Reference imports to suppress errors if they are not otherwise used.
var (
_ = big . NewInt
_ = strings . NewReader
_ = ethereum . NotFound
_ = bind . Bind
_ = common . Big1
_ = types . BloomLookup
_ = event . NewSubscription
)
// Revive2ABI is the input ABI used to generate the binding from.
const Revive2ABI = "[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"contractPhoenix\",\"name\":\"d\",\"type\":\"address\"}],\"name\":\"DeployEvent\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"salt\",\"type\":\"bytes32\"}],\"name\":\"deploy\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}]"
// Revive2Bin is the compiled bytecode used for deploying new contracts.
var Revive2Bin = "0x608060405234801561001057600080fd5b5061020c806100206000396000f3fe608060405234801561001057600080fd5b506004361061002b5760003560e01c80632b85ba3814610030575b600080fd5b61004d6004803603602081101561004657600080fd5b503561004f565b005b60008160405161005e906100c3565b8190604051809103906000f590508015801561007e573d6000803e3d6000fd5b50604080516001600160a01b038316815290519192507f68f6a0f063c25c6678c443b9a484086f15ba8f91f60218695d32a5251f2050eb919081900360200190a15050565b60e2806100d08339019056fe6080604052348015600f57600080fd5b5060c48061001e6000396000f3fe60806040526004361060295760003560e01c806335f46994146034578063d09de08a14604857602f565b36602f57005b600080fd5b348015603f57600080fd5b506046605a565b005b348015605357600080fd5b506046605e565b6000ff5b60008054600101905556fea26469706673582212208a7813270390a5ca21790c2447b46da471493e99b652d00cbd4751eb47b7e70164736f6c637827302e372e352d646576656c6f702e323032302e31322e392b636f6d6d69742e65623737656430380058a264697066735822122036eaf56869ab01a8cf151f996b101556189836230bfa0508485784d1821bc2fa64736f6c637827302e372e352d646576656c6f702e323032302e31322e392b636f6d6d69742e65623737656430380058"
// DeployRevive2 deploys a new Ethereum contract, binding an instance of Revive2 to it.
2021-04-22 18:11:37 +01:00
func DeployRevive2 ( auth * bind . TransactOpts , backend bind . ContractBackend ) ( common . Address , types . Transaction , * Revive2 , error ) {
2020-12-16 17:16:37 +00:00
parsed , err := abi . JSON ( strings . NewReader ( Revive2ABI ) )
if err != nil {
return common . Address { } , nil , nil , err
}
address , tx , contract , err := bind . DeployContract ( auth , parsed , common . FromHex ( Revive2Bin ) , backend )
if err != nil {
return common . Address { } , nil , nil , err
}
return address , tx , & Revive2 { Revive2Caller : Revive2Caller { contract : contract } , Revive2Transactor : Revive2Transactor { contract : contract } , Revive2Filterer : Revive2Filterer { contract : contract } } , nil
}
// Revive2 is an auto generated Go binding around an Ethereum contract.
type Revive2 struct {
Revive2Caller // Read-only binding to the contract
Revive2Transactor // Write-only binding to the contract
Revive2Filterer // Log filterer for contract events
}
// Revive2Caller is an auto generated read-only Go binding around an Ethereum contract.
type Revive2Caller struct {
contract * bind . BoundContract // Generic contract wrapper for the low level calls
}
// Revive2Transactor is an auto generated write-only Go binding around an Ethereum contract.
type Revive2Transactor struct {
contract * bind . BoundContract // Generic contract wrapper for the low level calls
}
// Revive2Filterer is an auto generated log filtering Go binding around an Ethereum contract events.
type Revive2Filterer struct {
contract * bind . BoundContract // Generic contract wrapper for the low level calls
}
// Revive2Session is an auto generated Go binding around an Ethereum contract,
// with pre-set call and transact options.
type Revive2Session struct {
Contract * Revive2 // Generic contract binding to set the session for
CallOpts bind . CallOpts // Call options to use throughout this session
TransactOpts bind . TransactOpts // Transaction auth options to use throughout this session
}
// Revive2CallerSession is an auto generated read-only Go binding around an Ethereum contract,
// with pre-set call options.
type Revive2CallerSession struct {
Contract * Revive2Caller // Generic contract caller binding to set the session for
CallOpts bind . CallOpts // Call options to use throughout this session
}
// Revive2TransactorSession is an auto generated write-only Go binding around an Ethereum contract,
// with pre-set transact options.
type Revive2TransactorSession struct {
Contract * Revive2Transactor // Generic contract transactor binding to set the session for
TransactOpts bind . TransactOpts // Transaction auth options to use throughout this session
}
// Revive2Raw is an auto generated low-level Go binding around an Ethereum contract.
type Revive2Raw struct {
Contract * Revive2 // Generic contract binding to access the raw methods on
}
// Revive2CallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract.
type Revive2CallerRaw struct {
Contract * Revive2Caller // Generic read-only contract binding to access the raw methods on
}
// Revive2TransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract.
type Revive2TransactorRaw struct {
Contract * Revive2Transactor // Generic write-only contract binding to access the raw methods on
}
// NewRevive2 creates a new instance of Revive2, bound to a specific deployed contract.
func NewRevive2 ( address common . Address , backend bind . ContractBackend ) ( * Revive2 , error ) {
contract , err := bindRevive2 ( address , backend , backend , backend )
if err != nil {
return nil , err
}
return & Revive2 { Revive2Caller : Revive2Caller { contract : contract } , Revive2Transactor : Revive2Transactor { contract : contract } , Revive2Filterer : Revive2Filterer { contract : contract } } , nil
}
// NewRevive2Caller creates a new read-only instance of Revive2, bound to a specific deployed contract.
func NewRevive2Caller ( address common . Address , caller bind . ContractCaller ) ( * Revive2Caller , error ) {
contract , err := bindRevive2 ( address , caller , nil , nil )
if err != nil {
return nil , err
}
return & Revive2Caller { contract : contract } , nil
}
// NewRevive2Transactor creates a new write-only instance of Revive2, bound to a specific deployed contract.
func NewRevive2Transactor ( address common . Address , transactor bind . ContractTransactor ) ( * Revive2Transactor , error ) {
contract , err := bindRevive2 ( address , nil , transactor , nil )
if err != nil {
return nil , err
}
return & Revive2Transactor { contract : contract } , nil
}
// NewRevive2Filterer creates a new log filterer instance of Revive2, bound to a specific deployed contract.
func NewRevive2Filterer ( address common . Address , filterer bind . ContractFilterer ) ( * Revive2Filterer , error ) {
contract , err := bindRevive2 ( address , nil , nil , filterer )
if err != nil {
return nil , err
}
return & Revive2Filterer { contract : contract } , nil
}
// bindRevive2 binds a generic wrapper to an already deployed contract.
func bindRevive2 ( address common . Address , caller bind . ContractCaller , transactor bind . ContractTransactor , filterer bind . ContractFilterer ) ( * bind . BoundContract , error ) {
parsed , err := abi . JSON ( strings . NewReader ( Revive2ABI ) )
if err != nil {
return nil , err
}
return bind . NewBoundContract ( address , parsed , caller , transactor , filterer ) , nil
}
// Call invokes the (constant) contract method with params as input values and
// sets the output to result. The result type might be a single field for simple
// returns, a slice of interfaces for anonymous returns and a struct for named
// returns.
func ( _Revive2 * Revive2Raw ) Call ( opts * bind . CallOpts , result * [ ] interface { } , method string , params ... interface { } ) error {
return _Revive2 . Contract . Revive2Caller . contract . Call ( opts , result , method , params ... )
}
// Transfer initiates a plain transaction to move funds to the contract, calling
// its default method if one is available.
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2Raw ) Transfer ( opts * bind . TransactOpts ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . Revive2Transactor . contract . Transfer ( opts )
}
// Transact invokes the (paid) contract method with params as input values.
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2Raw ) Transact ( opts * bind . TransactOpts , method string , params ... interface { } ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . Revive2Transactor . contract . Transact ( opts , method , params ... )
}
// Call invokes the (constant) contract method with params as input values and
// sets the output to result. The result type might be a single field for simple
// returns, a slice of interfaces for anonymous returns and a struct for named
// returns.
func ( _Revive2 * Revive2CallerRaw ) Call ( opts * bind . CallOpts , result * [ ] interface { } , method string , params ... interface { } ) error {
return _Revive2 . Contract . contract . Call ( opts , result , method , params ... )
}
// Transfer initiates a plain transaction to move funds to the contract, calling
// its default method if one is available.
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2TransactorRaw ) Transfer ( opts * bind . TransactOpts ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . contract . Transfer ( opts )
}
// Transact invokes the (paid) contract method with params as input values.
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2TransactorRaw ) Transact ( opts * bind . TransactOpts , method string , params ... interface { } ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . contract . Transact ( opts , method , params ... )
}
// Deploy is a paid mutator transaction binding the contract method 0x2b85ba38.
//
// Solidity: function deploy(bytes32 salt) returns()
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2Transactor ) Deploy ( opts * bind . TransactOpts , salt [ 32 ] byte ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . contract . Transact ( opts , "deploy" , salt )
}
// Deploy is a paid mutator transaction binding the contract method 0x2b85ba38.
//
// Solidity: function deploy(bytes32 salt) returns()
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2Session ) Deploy ( salt [ 32 ] byte ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . Deploy ( & _Revive2 . TransactOpts , salt )
}
// Deploy is a paid mutator transaction binding the contract method 0x2b85ba38.
//
// Solidity: function deploy(bytes32 salt) returns()
2021-04-22 18:11:37 +01:00
func ( _Revive2 * Revive2TransactorSession ) Deploy ( salt [ 32 ] byte ) ( types . Transaction , error ) {
2020-12-16 17:16:37 +00:00
return _Revive2 . Contract . Deploy ( & _Revive2 . TransactOpts , salt )
}
// Revive2DeployEventIterator is returned from FilterDeployEvent and is used to iterate over the raw logs and unpacked data for DeployEvent events raised by the Revive2 contract.
type Revive2DeployEventIterator struct {
Event * Revive2DeployEvent // Event containing the contract specifics and raw log
contract * bind . BoundContract // Generic contract to use for unpacking event data
event string // Event name to use for unpacking event data
logs chan types . Log // Log channel receiving the found contract events
sub ethereum . Subscription // Subscription for errors, completion and termination
done bool // Whether the subscription completed delivering logs
fail error // Occurred error to stop iteration
}
// Next advances the iterator to the subsequent event, returning whether there
// are any more events found. In case of a retrieval or parsing error, false is
// returned and Error() can be queried for the exact failure.
func ( it * Revive2DeployEventIterator ) Next ( ) bool {
// If the iterator failed, stop iterating
if it . fail != nil {
return false
}
// If the iterator completed, deliver directly whatever's available
if it . done {
select {
case log := <- it . logs :
it . Event = new ( Revive2DeployEvent )
if err := it . contract . UnpackLog ( it . Event , it . event , log ) ; err != nil {
it . fail = err
return false
}
it . Event . Raw = log
return true
default :
return false
}
}
// Iterator still in progress, wait for either a data or an error event
select {
case log := <- it . logs :
it . Event = new ( Revive2DeployEvent )
if err := it . contract . UnpackLog ( it . Event , it . event , log ) ; err != nil {
it . fail = err
return false
}
it . Event . Raw = log
return true
case err := <- it . sub . Err ( ) :
it . done = true
it . fail = err
return it . Next ( )
}
}
// Error returns any retrieval or parsing error occurred during filtering.
func ( it * Revive2DeployEventIterator ) Error ( ) error {
return it . fail
}
// Close terminates the iteration process, releasing any pending underlying
// resources.
func ( it * Revive2DeployEventIterator ) Close ( ) error {
it . sub . Unsubscribe ( )
return nil
}
// Revive2DeployEvent represents a DeployEvent event raised by the Revive2 contract.
type Revive2DeployEvent struct {
D common . Address
Raw types . Log // Blockchain specific contextual infos
}
// FilterDeployEvent is a free log retrieval operation binding the contract event 0x68f6a0f063c25c6678c443b9a484086f15ba8f91f60218695d32a5251f2050eb.
//
// Solidity: event DeployEvent(address d)
func ( _Revive2 * Revive2Filterer ) FilterDeployEvent ( opts * bind . FilterOpts ) ( * Revive2DeployEventIterator , error ) {
logs , sub , err := _Revive2 . contract . FilterLogs ( opts , "DeployEvent" )
if err != nil {
return nil , err
}
return & Revive2DeployEventIterator { contract : _Revive2 . contract , event : "DeployEvent" , logs : logs , sub : sub } , nil
}
// WatchDeployEvent is a free log subscription operation binding the contract event 0x68f6a0f063c25c6678c443b9a484086f15ba8f91f60218695d32a5251f2050eb.
//
// Solidity: event DeployEvent(address d)
func ( _Revive2 * Revive2Filterer ) WatchDeployEvent ( opts * bind . WatchOpts , sink chan <- * Revive2DeployEvent ) ( event . Subscription , error ) {
logs , sub , err := _Revive2 . contract . WatchLogs ( opts , "DeployEvent" )
if err != nil {
return nil , err
}
return event . NewSubscription ( func ( quit <- chan struct { } ) error {
defer sub . Unsubscribe ( )
for {
select {
case log := <- logs :
// New log arrived, parse the event and forward to the user
event := new ( Revive2DeployEvent )
if err := _Revive2 . contract . UnpackLog ( event , "DeployEvent" , log ) ; err != nil {
return err
}
event . Raw = log
select {
case sink <- event :
case err := <- sub . Err ( ) :
return err
case <- quit :
return nil
}
case err := <- sub . Err ( ) :
return err
case <- quit :
return nil
}
}
} ) , nil
}
// ParseDeployEvent is a log parse operation binding the contract event 0x68f6a0f063c25c6678c443b9a484086f15ba8f91f60218695d32a5251f2050eb.
//
// Solidity: event DeployEvent(address d)
func ( _Revive2 * Revive2Filterer ) ParseDeployEvent ( log types . Log ) ( * Revive2DeployEvent , error ) {
event := new ( Revive2DeployEvent )
if err := _Revive2 . contract . UnpackLog ( event , "DeployEvent" , log ) ; err != nil {
return nil , err
}
return event , nil
}