mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00: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>
		
			
				
	
	
		
			46 lines
		
	
	
	
		
			870 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			46 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
 | |
| }
 |