123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- // Copyright 2015 The Go Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style
- // license that can be found in the LICENSE file.
- // Package internal contains code that is shared among encoding implementations.
- package internal
- import (
- "golang.org/x/text/encoding"
- "golang.org/x/text/encoding/internal/identifier"
- "golang.org/x/text/transform"
- )
- // Encoding is an implementation of the Encoding interface that adds the String
- // and ID methods to an existing encoding.
- type Encoding struct {
- encoding.Encoding
- Name string
- MIB identifier.MIB
- }
- // _ verifies that Encoding implements identifier.Interface.
- var _ identifier.Interface = (*Encoding)(nil)
- func (e *Encoding) String() string {
- return e.Name
- }
- func (e *Encoding) ID() (mib identifier.MIB, other string) {
- return e.MIB, ""
- }
- // SimpleEncoding is an Encoding that combines two Transformers.
- type SimpleEncoding struct {
- Decoder transform.Transformer
- Encoder transform.Transformer
- }
- func (e *SimpleEncoding) NewDecoder() *encoding.Decoder {
- return &encoding.Decoder{Transformer: e.Decoder}
- }
- func (e *SimpleEncoding) NewEncoder() *encoding.Encoder {
- return &encoding.Encoder{Transformer: e.Encoder}
- }
- // FuncEncoding is an Encoding that combines two functions returning a new
- // Transformer.
- type FuncEncoding struct {
- Decoder func() transform.Transformer
- Encoder func() transform.Transformer
- }
- func (e FuncEncoding) NewDecoder() *encoding.Decoder {
- return &encoding.Decoder{Transformer: e.Decoder()}
- }
- func (e FuncEncoding) NewEncoder() *encoding.Encoder {
- return &encoding.Encoder{Transformer: e.Encoder()}
- }
- // A RepertoireError indicates a rune is not in the repertoire of a destination
- // encoding. It is associated with an encoding-specific suggested replacement
- // byte.
- type RepertoireError byte
- // Error implements the error interrface.
- func (r RepertoireError) Error() string {
- return "encoding: rune not supported by encoding."
- }
- // Replacement returns the replacement string associated with this error.
- func (r RepertoireError) Replacement() byte { return byte(r) }
- var ErrASCIIReplacement = RepertoireError(encoding.ASCIISub)
|