OSDN Git Service

new repo
[bytom/vapor.git] / vendor / golang.org / x / text / encoding / internal / internal.go
1 // Copyright 2015 The Go Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style
3 // license that can be found in the LICENSE file.
4
5 // Package internal contains code that is shared among encoding implementations.
6 package internal
7
8 import (
9         "golang.org/x/text/encoding"
10         "golang.org/x/text/encoding/internal/identifier"
11         "golang.org/x/text/transform"
12 )
13
14 // Encoding is an implementation of the Encoding interface that adds the String
15 // and ID methods to an existing encoding.
16 type Encoding struct {
17         encoding.Encoding
18         Name string
19         MIB  identifier.MIB
20 }
21
22 // _ verifies that Encoding implements identifier.Interface.
23 var _ identifier.Interface = (*Encoding)(nil)
24
25 func (e *Encoding) String() string {
26         return e.Name
27 }
28
29 func (e *Encoding) ID() (mib identifier.MIB, other string) {
30         return e.MIB, ""
31 }
32
33 // SimpleEncoding is an Encoding that combines two Transformers.
34 type SimpleEncoding struct {
35         Decoder transform.Transformer
36         Encoder transform.Transformer
37 }
38
39 func (e *SimpleEncoding) NewDecoder() *encoding.Decoder {
40         return &encoding.Decoder{Transformer: e.Decoder}
41 }
42
43 func (e *SimpleEncoding) NewEncoder() *encoding.Encoder {
44         return &encoding.Encoder{Transformer: e.Encoder}
45 }
46
47 // FuncEncoding is an Encoding that combines two functions returning a new
48 // Transformer.
49 type FuncEncoding struct {
50         Decoder func() transform.Transformer
51         Encoder func() transform.Transformer
52 }
53
54 func (e FuncEncoding) NewDecoder() *encoding.Decoder {
55         return &encoding.Decoder{Transformer: e.Decoder()}
56 }
57
58 func (e FuncEncoding) NewEncoder() *encoding.Encoder {
59         return &encoding.Encoder{Transformer: e.Encoder()}
60 }
61
62 // A RepertoireError indicates a rune is not in the repertoire of a destination
63 // encoding. It is associated with an encoding-specific suggested replacement
64 // byte.
65 type RepertoireError byte
66
67 // Error implements the error interrface.
68 func (r RepertoireError) Error() string {
69         return "encoding: rune not supported by encoding."
70 }
71
72 // Replacement returns the replacement string associated with this error.
73 func (r RepertoireError) Replacement() byte { return byte(r) }
74
75 var ErrASCIIReplacement = RepertoireError(encoding.ASCIISub)