mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* Fix validate() function to handle errors in embedded anon structs * Implement webhook branch filter See #2025, #3998.
		
			
				
	
	
		
			155 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package runes
 | |
| 
 | |
| func Index(s, needle []rune) int {
 | |
| 	ls, ln := len(s), len(needle)
 | |
| 
 | |
| 	switch {
 | |
| 	case ln == 0:
 | |
| 		return 0
 | |
| 	case ln == 1:
 | |
| 		return IndexRune(s, needle[0])
 | |
| 	case ln == ls:
 | |
| 		if Equal(s, needle) {
 | |
| 			return 0
 | |
| 		}
 | |
| 		return -1
 | |
| 	case ln > ls:
 | |
| 		return -1
 | |
| 	}
 | |
| 
 | |
| head:
 | |
| 	for i := 0; i < ls && ls-i >= ln; i++ {
 | |
| 		for y := 0; y < ln; y++ {
 | |
| 			if s[i+y] != needle[y] {
 | |
| 				continue head
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return i
 | |
| 	}
 | |
| 
 | |
| 	return -1
 | |
| }
 | |
| 
 | |
| func LastIndex(s, needle []rune) int {
 | |
| 	ls, ln := len(s), len(needle)
 | |
| 
 | |
| 	switch {
 | |
| 	case ln == 0:
 | |
| 		if ls == 0 {
 | |
| 			return 0
 | |
| 		}
 | |
| 		return ls
 | |
| 	case ln == 1:
 | |
| 		return IndexLastRune(s, needle[0])
 | |
| 	case ln == ls:
 | |
| 		if Equal(s, needle) {
 | |
| 			return 0
 | |
| 		}
 | |
| 		return -1
 | |
| 	case ln > ls:
 | |
| 		return -1
 | |
| 	}
 | |
| 
 | |
| head:
 | |
| 	for i := ls - 1; i >= 0 && i >= ln; i-- {
 | |
| 		for y := ln - 1; y >= 0; y-- {
 | |
| 			if s[i-(ln-y-1)] != needle[y] {
 | |
| 				continue head
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return i - ln + 1
 | |
| 	}
 | |
| 
 | |
| 	return -1
 | |
| }
 | |
| 
 | |
| // IndexAny returns the index of the first instance of any Unicode code point
 | |
| // from chars in s, or -1 if no Unicode code point from chars is present in s.
 | |
| func IndexAny(s, chars []rune) int {
 | |
| 	if len(chars) > 0 {
 | |
| 		for i, c := range s {
 | |
| 			for _, m := range chars {
 | |
| 				if c == m {
 | |
| 					return i
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	return -1
 | |
| }
 | |
| 
 | |
| func Contains(s, needle []rune) bool {
 | |
| 	return Index(s, needle) >= 0
 | |
| }
 | |
| 
 | |
| func Max(s []rune) (max rune) {
 | |
| 	for _, r := range s {
 | |
| 		if r > max {
 | |
| 			max = r
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return
 | |
| }
 | |
| 
 | |
| func Min(s []rune) rune {
 | |
| 	min := rune(-1)
 | |
| 	for _, r := range s {
 | |
| 		if min == -1 {
 | |
| 			min = r
 | |
| 			continue
 | |
| 		}
 | |
| 
 | |
| 		if r < min {
 | |
| 			min = r
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return min
 | |
| }
 | |
| 
 | |
| func IndexRune(s []rune, r rune) int {
 | |
| 	for i, c := range s {
 | |
| 		if c == r {
 | |
| 			return i
 | |
| 		}
 | |
| 	}
 | |
| 	return -1
 | |
| }
 | |
| 
 | |
| func IndexLastRune(s []rune, r rune) int {
 | |
| 	for i := len(s) - 1; i >= 0; i-- {
 | |
| 		if s[i] == r {
 | |
| 			return i
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return -1
 | |
| }
 | |
| 
 | |
| func Equal(a, b []rune) bool {
 | |
| 	if len(a) == len(b) {
 | |
| 		for i := 0; i < len(a); i++ {
 | |
| 			if a[i] != b[i] {
 | |
| 				return false
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return true
 | |
| 	}
 | |
| 
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| // HasPrefix tests whether the string s begins with prefix.
 | |
| func HasPrefix(s, prefix []rune) bool {
 | |
| 	return len(s) >= len(prefix) && Equal(s[0:len(prefix)], prefix)
 | |
| }
 | |
| 
 | |
| // HasSuffix tests whether the string s ends with suffix.
 | |
| func HasSuffix(s, suffix []rune) bool {
 | |
| 	return len(s) >= len(suffix) && Equal(s[len(s)-len(suffix):], suffix)
 | |
| }
 |