mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-22 14:22:51 +00:00
48abe41ea8
* Only generate bindata if necessary * Only generate bindata if they are not up-to-date * generate a hash of the fileinfo and use that to keep up-to-date * Newer test is redundant * handle missing bindata and clean * Only update hash after successful write * switch to sha1 hash * Apply suggestions from code review Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com>
47 lines
870 B
Go
47 lines
870 B
Go
// Copyright 2016 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package options
|
|
|
|
type directorySet map[string][]string
|
|
|
|
func (s directorySet) Add(key string, value []string) {
|
|
_, ok := s[key]
|
|
|
|
if !ok {
|
|
s[key] = make([]string, 0, len(value))
|
|
}
|
|
|
|
s[key] = append(s[key], value...)
|
|
}
|
|
|
|
func (s directorySet) Get(key string) []string {
|
|
_, ok := s[key]
|
|
|
|
if ok {
|
|
result := []string{}
|
|
seen := map[string]string{}
|
|
|
|
for _, val := range s[key] {
|
|
if _, ok := seen[val]; !ok {
|
|
result = append(result, val)
|
|
seen[val] = val
|
|
}
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
return []string{}
|
|
}
|
|
|
|
func (s directorySet) AddAndGet(key string, value []string) []string {
|
|
s.Add(key, value)
|
|
return s.Get(key)
|
|
}
|
|
|
|
func (s directorySet) Filled(key string) bool {
|
|
return len(s[key]) > 0
|
|
}
|