decoder.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package encoding
  2. import (
  3. "sync"
  4. )
  5. // Decoder decodes the contents of b into v.
  6. // It's primarily used for decoding contents of a file into a map[string]interface{}.
  7. type Decoder interface {
  8. Decode(b []byte, v map[string]interface{}) error
  9. }
  10. const (
  11. // ErrDecoderNotFound is returned when there is no decoder registered for a format.
  12. ErrDecoderNotFound = encodingError("decoder not found for this format")
  13. // ErrDecoderFormatAlreadyRegistered is returned when an decoder is already registered for a format.
  14. ErrDecoderFormatAlreadyRegistered = encodingError("decoder already registered for this format")
  15. )
  16. // DecoderRegistry can choose an appropriate Decoder based on the provided format.
  17. type DecoderRegistry struct {
  18. decoders map[string]Decoder
  19. mu sync.RWMutex
  20. }
  21. // NewDecoderRegistry returns a new, initialized DecoderRegistry.
  22. func NewDecoderRegistry() *DecoderRegistry {
  23. return &DecoderRegistry{
  24. decoders: make(map[string]Decoder),
  25. }
  26. }
  27. // RegisterDecoder registers a Decoder for a format.
  28. // Registering a Decoder for an already existing format is not supported.
  29. func (e *DecoderRegistry) RegisterDecoder(format string, enc Decoder) error {
  30. e.mu.Lock()
  31. defer e.mu.Unlock()
  32. if _, ok := e.decoders[format]; ok {
  33. return ErrDecoderFormatAlreadyRegistered
  34. }
  35. e.decoders[format] = enc
  36. return nil
  37. }
  38. // Decode calls the underlying Decoder based on the format.
  39. func (e *DecoderRegistry) Decode(format string, b []byte, v map[string]interface{}) error {
  40. e.mu.RLock()
  41. decoder, ok := e.decoders[format]
  42. e.mu.RUnlock()
  43. if !ok {
  44. return ErrDecoderNotFound
  45. }
  46. return decoder.Decode(b, v)
  47. }