errors.go 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. // Copyright 2015 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 node
  17. import (
  18. "errors"
  19. "fmt"
  20. "reflect"
  21. "syscall"
  22. )
  23. var (
  24. ErrDatadirUsed = errors.New("datadir already used by another process")
  25. ErrNodeStopped = errors.New("node not started")
  26. ErrNodeRunning = errors.New("node already running")
  27. ErrServiceUnknown = errors.New("unknown service")
  28. datadirInUseErrnos = map[uint]bool{11: true, 32: true, 35: true}
  29. )
  30. func convertFileLockError(err error) error {
  31. if errno, ok := err.(syscall.Errno); ok && datadirInUseErrnos[uint(errno)] {
  32. return ErrDatadirUsed
  33. }
  34. return err
  35. }
  36. // DuplicateServiceError is returned during Node startup if a registered service
  37. // constructor returns a service of the same type that was already started.
  38. type DuplicateServiceError struct {
  39. Kind reflect.Type
  40. }
  41. // Error generates a textual representation of the duplicate service error.
  42. func (e *DuplicateServiceError) Error() string {
  43. return fmt.Sprintf("duplicate service: %v", e.Kind)
  44. }
  45. // StopError is returned if a Node fails to stop either any of its registered
  46. // services or itself.
  47. type StopError struct {
  48. Server error
  49. Services map[reflect.Type]error
  50. }
  51. // Error generates a textual representation of the stop error.
  52. func (e *StopError) Error() string {
  53. return fmt.Sprintf("server: %v, services: %v", e.Server, e.Services)
  54. }