Logs are now recorded per transactions instead of tossing them out after each transaction. This should also fix an issue with `eth_getFilterLogs` (#629) Also now implemented are the `transactionHash, blockHash, transactionIndex, logIndex` on logs. Closes #654.
		
			
				
	
	
		
			44 lines
		
	
	
		
			860 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			860 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package state
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 
 | |
| 	"github.com/ethereum/go-ethereum/common"
 | |
| 	"github.com/ethereum/go-ethereum/rlp"
 | |
| )
 | |
| 
 | |
| type Log struct {
 | |
| 	Address common.Address
 | |
| 	Topics  []common.Hash
 | |
| 	Data    []byte
 | |
| 	Number  uint64
 | |
| 
 | |
| 	TxHash    common.Hash
 | |
| 	TxIndex   uint
 | |
| 	BlockHash common.Hash
 | |
| 	Index     uint
 | |
| }
 | |
| 
 | |
| func NewLog(address common.Address, topics []common.Hash, data []byte, number uint64) *Log {
 | |
| 	return &Log{Address: address, Topics: topics, Data: data, Number: number}
 | |
| }
 | |
| 
 | |
| func (self *Log) EncodeRLP(w io.Writer) error {
 | |
| 	return rlp.Encode(w, []interface{}{self.Address, self.Topics, self.Data})
 | |
| }
 | |
| 
 | |
| func (self *Log) String() string {
 | |
| 	return fmt.Sprintf(`log: %x %x %x`, self.Address, self.Topics, self.Data)
 | |
| }
 | |
| 
 | |
| type Logs []*Log
 | |
| 
 | |
| func (self Logs) String() (ret string) {
 | |
| 	for _, log := range self {
 | |
| 		ret += fmt.Sprintf("%v", log)
 | |
| 	}
 | |
| 
 | |
| 	return "[" + ret + "]"
 | |
| }
 |