event.go 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. // Copyright 2016 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package abi
  17. import (
  18. "fmt"
  19. "strings"
  20. "github.com/ethereum/go-ethereum/common"
  21. "github.com/ethereum/go-ethereum/crypto"
  22. )
  23. // Event is an event potentially triggered by the EVM's LOG mechanism. The Event
  24. // holds type information (inputs) about the yielded output. Anonymous events
  25. // don't get the signature canonical representation as the first LOG topic.
  26. type Event struct {
  27. // Name is the event name used for internal representation. It's derived from
  28. // the raw name and a suffix will be added in the case of a event overload.
  29. //
  30. // e.g.
  31. // There are two events have same name:
  32. // * foo(int,int)
  33. // * foo(uint,uint)
  34. // The event name of the first one wll be resolved as foo while the second one
  35. // will be resolved as foo0.
  36. Name string
  37. // RawName is the raw event name parsed from ABI.
  38. RawName string
  39. Anonymous bool
  40. Inputs Arguments
  41. }
  42. func (e Event) String() string {
  43. inputs := make([]string, len(e.Inputs))
  44. for i, input := range e.Inputs {
  45. inputs[i] = fmt.Sprintf("%v %v", input.Type, input.Name)
  46. if input.Indexed {
  47. inputs[i] = fmt.Sprintf("%v indexed %v", input.Type, input.Name)
  48. }
  49. }
  50. return fmt.Sprintf("event %v(%v)", e.RawName, strings.Join(inputs, ", "))
  51. }
  52. // Sig returns the event string signature according to the ABI spec.
  53. //
  54. // Example
  55. //
  56. // event foo(uint32 a, int b) = "foo(uint32,int256)"
  57. //
  58. // Please note that "int" is substitute for its canonical representation "int256"
  59. func (e Event) Sig() string {
  60. types := make([]string, len(e.Inputs))
  61. for i, input := range e.Inputs {
  62. types[i] = input.Type.String()
  63. }
  64. return fmt.Sprintf("%v(%v)", e.RawName, strings.Join(types, ","))
  65. }
  66. // ID returns the canonical representation of the event's signature used by the
  67. // abi definition to identify event names and types.
  68. func (e Event) ID() common.Hash {
  69. return common.BytesToHash(crypto.Keccak256([]byte(e.Sig())))
  70. }