1 Star 0 Fork 0

非空非零 / jupiter

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
attr.go 1.43 KB
一键复制 编辑 原始数据 按行查看 历史
落舞者 提交于 2020-08-04 01:47 . feat/optimize for version 0.2.0 (#133)
// Copyright 2020 Douyu
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package xattr
import (
"errors"
)
// Attributes ...
type Attributes struct {
m map[interface{}]interface{}
}
var (
// ErrInvalidKVPairs ...
ErrInvalidKVPairs = errors.New("invalid kv pairs")
)
// New ...
func New(kvs ...interface{}) *Attributes {
if len(kvs)%2 != 0 {
panic(ErrInvalidKVPairs)
}
a := &Attributes{m: make(map[interface{}]interface{}, len(kvs)/2)}
for i := 0; i < len(kvs)/2; i++ {
a.m[kvs[i*2]] = kvs[i*2+1]
}
return a
}
// WithValues ...
func (a *Attributes) WithValues(kvs ...interface{}) *Attributes {
if len(kvs)%2 != 0 {
panic(ErrInvalidKVPairs)
}
n := &Attributes{m: make(map[interface{}]interface{}, len(a.m)+len(kvs)/2)}
for k, v := range a.m {
n.m[k] = v
}
for i := 0; i < len(kvs)/2; i++ {
n.m[kvs[i*2]] = kvs[i*2+1]
}
return n
}
// Value ...
func (a *Attributes) Value(key interface{}) interface{} {
return a.m[key]
}
1
https://gitee.com/nonull/eden.git
git@gitee.com:nonull/eden.git
nonull
eden
jupiter
v0.3.1

搜索帮助