// 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.

//go:generate go run gen.go

// Package htmlindex maps character set encoding names to Encodings as // recommended by the W3C for use in HTML 5. See http://www.w3.org/TR/encoding.
package htmlindex // TODO: perhaps have a "bare" version of the index (used by this package) that // is not pre-loaded with all encodings. Global variables in encodings prevent // the linker from being able to purge unneeded tables. This means that // referencing all encodings, as this package does for the default index, links // in all encodings unconditionally. // // This issue can be solved by either solving the linking issue (see // https://github.com/golang/go/issues/6330) or refactoring the encoding tables // (e.g. moving the tables to internal packages that do not use global // variables). // TODO: allow canonicalizing names import ( ) var ( errInvalidName = errors.New("htmlindex: invalid encoding name") errUnknown = errors.New("htmlindex: unknown Encoding") errUnsupported = errors.New("htmlindex: this encoding is not supported") ) var ( matcherOnce sync.Once matcher language.Matcher ) // LanguageDefault returns the canonical name of the default encoding for a // given language. func ( language.Tag) string { matcherOnce.Do(func() { := []language.Tag{} for , := range strings.Split(locales, " ") { = append(, language.MustParse()) } matcher = language.NewMatcher(, language.PreferSameScript(true)) }) , , := matcher.Match() return canonical[localeMap[]] // Default is Windows-1252. } // Get returns an Encoding for one of the names listed in // http://www.w3.org/TR/encoding using the Default Index. Matching is case- // insensitive. func ( string) (encoding.Encoding, error) { , := nameMap[strings.ToLower(strings.TrimSpace())] if ! { return nil, errInvalidName } return encodings[], nil } // Name reports the canonical name of the given Encoding. It will return // an error if e is not associated with a supported encoding scheme. func ( encoding.Encoding) (string, error) { , := .(identifier.Interface) if ! { return "", errUnknown } , := .ID() if == 0 { return "", errUnknown } , := mibMap[] if ! { return "", errUnsupported } return canonical[], nil }