56 lines
1.6 KiB
Go
56 lines
1.6 KiB
Go
// Copyright 2010 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 textproto
|
|
|
|
// A MIMEHeader represents a MIME-style header mapping
|
|
// keys to sets of values.
|
|
type MIMEHeader map[string][]string
|
|
|
|
// Add adds the key, value pair to the header.
|
|
// It appends to any existing values associated with key.
|
|
func (h MIMEHeader) Add(key, value string) {
|
|
key = CanonicalMIMEHeaderKey(key)
|
|
h[key] = append(h[key], value)
|
|
}
|
|
|
|
// Set sets the header entries associated with key to
|
|
// the single element value. It replaces any existing
|
|
// values associated with key.
|
|
func (h MIMEHeader) Set(key, value string) {
|
|
h[CanonicalMIMEHeaderKey(key)] = []string{value}
|
|
}
|
|
|
|
// Get gets the first value associated with the given key.
|
|
// It is case insensitive; CanonicalMIMEHeaderKey is used
|
|
// to canonicalize the provided key.
|
|
// If there are no values associated with the key, Get returns "".
|
|
// To use non-canonical keys, access the map directly.
|
|
func (h MIMEHeader) Get(key string) string {
|
|
if h == nil {
|
|
return ""
|
|
}
|
|
v := h[CanonicalMIMEHeaderKey(key)]
|
|
if len(v) == 0 {
|
|
return ""
|
|
}
|
|
return v[0]
|
|
}
|
|
|
|
// Values returns all values associated with the given key.
|
|
// It is case insensitive; CanonicalMIMEHeaderKey is
|
|
// used to canonicalize the provided key. To use non-canonical
|
|
// keys, access the map directly.
|
|
// The returned slice is not a copy.
|
|
func (h MIMEHeader) Values(key string) []string {
|
|
if h == nil {
|
|
return nil
|
|
}
|
|
return h[CanonicalMIMEHeaderKey(key)]
|
|
}
|
|
|
|
// Del deletes the values associated with key.
|
|
func (h MIMEHeader) Del(key string) {
|
|
delete(h, CanonicalMIMEHeaderKey(key))
|
|
}
|