mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 21:16:26 +01:00 
			
		
		
		
	* 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
 | 
						|
}
 |