encoder_example_test.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // Copyright 2014 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 rlp
  17. import (
  18. "fmt"
  19. "io"
  20. )
  21. type MyCoolType struct {
  22. Name string
  23. a, b uint
  24. }
  25. // EncodeRLP writes x as RLP list [a, b] that omits the Name field.
  26. func (x *MyCoolType) EncodeRLP(w io.Writer) (err error) {
  27. // Note: the receiver can be a nil pointer. This allows you to
  28. // control the encoding of nil, but it also means that you have to
  29. // check for a nil receiver.
  30. if x == nil {
  31. err = Encode(w, []uint{0, 0})
  32. } else {
  33. err = Encode(w, []uint{x.a, x.b})
  34. }
  35. return err
  36. }
  37. func ExampleEncoder() {
  38. var t *MyCoolType // t is nil pointer to MyCoolType
  39. bytes, _ := EncodeToBytes(t)
  40. fmt.Printf("%v → %X\n", t, bytes)
  41. t = &MyCoolType{Name: "foobar", a: 5, b: 6}
  42. bytes, _ = EncodeToBytes(t)
  43. fmt.Printf("%v → %X\n", t, bytes)
  44. // Output:
  45. // <nil> → C28080
  46. // &{foobar 5 6} → C20506
  47. }