go-ethereum/state/log.go

92 lines
1.5 KiB
Go
Raw Normal View History

2014-10-31 08:43:14 -05:00
package state
2014-10-27 05:44:16 -05:00
2014-11-11 05:16:36 -06:00
import (
"fmt"
2015-03-16 05:27:38 -05:00
"github.com/ethereum/go-ethereum/common"
2014-11-11 05:16:36 -06:00
)
2014-10-27 05:44:16 -05:00
2014-12-04 05:35:23 -06:00
type Log interface {
2015-03-16 05:27:38 -05:00
common.RlpEncodable
2014-12-04 05:35:23 -06:00
2015-03-16 12:42:18 -05:00
Address() common.Address
2014-12-04 05:35:23 -06:00
Topics() [][]byte
Data() []byte
2015-02-22 06:24:26 -06:00
Number() uint64
2014-12-04 05:35:23 -06:00
}
type StateLog struct {
2015-03-16 12:42:18 -05:00
address common.Address
2014-12-04 05:35:23 -06:00
topics [][]byte
data []byte
2015-02-22 06:24:26 -06:00
number uint64
2014-12-04 05:35:23 -06:00
}
2015-03-16 12:42:18 -05:00
func NewLog(address common.Address, topics [][]byte, data []byte, number uint64) *StateLog {
2015-02-22 06:24:26 -06:00
return &StateLog{address, topics, data, number}
2014-12-04 05:35:23 -06:00
}
2015-03-16 12:42:18 -05:00
func (self *StateLog) Address() common.Address {
2014-12-04 05:35:23 -06:00
return self.address
}
func (self *StateLog) Topics() [][]byte {
return self.topics
2014-10-27 05:44:16 -05:00
}
2014-12-04 05:35:23 -06:00
func (self *StateLog) Data() []byte {
return self.data
}
2015-02-22 06:24:26 -06:00
func (self *StateLog) Number() uint64 {
return self.number
}
2015-03-16 12:42:18 -05:00
/*
2015-03-16 05:27:38 -05:00
func NewLogFromValue(decoder *common.Value) *StateLog {
2015-03-16 12:42:18 -05:00
var extlog struct {
}
2014-12-04 05:35:23 -06:00
log := &StateLog{
address: decoder.Get(0).Bytes(),
data: decoder.Get(2).Bytes(),
}
it := decoder.Get(1).NewIterator()
for it.Next() {
2014-12-04 05:35:23 -06:00
log.topics = append(log.topics, it.Value().Bytes())
}
return log
}
2015-03-16 12:42:18 -05:00
*/
2014-12-04 05:35:23 -06:00
func (self *StateLog) RlpData() interface{} {
2015-03-16 05:27:38 -05:00
return []interface{}{self.address, common.ByteSliceToInterface(self.topics), self.data}
}
2014-12-04 05:35:23 -06:00
func (self *StateLog) String() string {
return fmt.Sprintf(`log: %x %x %x`, self.address, self.topics, self.data)
2014-11-11 05:16:36 -06:00
}
2014-12-04 05:35:23 -06:00
type Logs []Log
func (self Logs) RlpData() interface{} {
data := make([]interface{}, len(self))
for i, log := range self {
data[i] = log.RlpData()
}
return data
}
2014-11-11 05:16:36 -06:00
2014-12-04 05:35:23 -06:00
func (self Logs) String() (ret string) {
2014-11-11 05:16:36 -06:00
for _, log := range self {
2014-12-04 05:35:23 -06:00
ret += fmt.Sprintf("%v", log)
2014-11-11 05:16:36 -06:00
}
2014-12-04 05:35:23 -06:00
return "[" + ret + "]"
2014-11-11 05:16:36 -06:00
}