* Fix validate() function to handle errors in embedded anon structs * Implement webhook branch filter See #2025, #3998.
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package match
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| )
 | |
| 
 | |
| type Row struct {
 | |
| 	Matchers    Matchers
 | |
| 	RunesLength int
 | |
| 	Segments    []int
 | |
| }
 | |
| 
 | |
| func NewRow(len int, m ...Matcher) Row {
 | |
| 	return Row{
 | |
| 		Matchers:    Matchers(m),
 | |
| 		RunesLength: len,
 | |
| 		Segments:    []int{len},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (self Row) matchAll(s string) bool {
 | |
| 	var idx int
 | |
| 	for _, m := range self.Matchers {
 | |
| 		length := m.Len()
 | |
| 
 | |
| 		var next, i int
 | |
| 		for next = range s[idx:] {
 | |
| 			i++
 | |
| 			if i == length {
 | |
| 				break
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if i < length || !m.Match(s[idx:idx+next+1]) {
 | |
| 			return false
 | |
| 		}
 | |
| 
 | |
| 		idx += next + 1
 | |
| 	}
 | |
| 
 | |
| 	return true
 | |
| }
 | |
| 
 | |
| func (self Row) lenOk(s string) bool {
 | |
| 	var i int
 | |
| 	for range s {
 | |
| 		i++
 | |
| 		if i > self.RunesLength {
 | |
| 			return false
 | |
| 		}
 | |
| 	}
 | |
| 	return self.RunesLength == i
 | |
| }
 | |
| 
 | |
| func (self Row) Match(s string) bool {
 | |
| 	return self.lenOk(s) && self.matchAll(s)
 | |
| }
 | |
| 
 | |
| func (self Row) Len() (l int) {
 | |
| 	return self.RunesLength
 | |
| }
 | |
| 
 | |
| func (self Row) Index(s string) (int, []int) {
 | |
| 	for i := range s {
 | |
| 		if len(s[i:]) < self.RunesLength {
 | |
| 			break
 | |
| 		}
 | |
| 		if self.matchAll(s[i:]) {
 | |
| 			return i, self.Segments
 | |
| 		}
 | |
| 	}
 | |
| 	return -1, nil
 | |
| }
 | |
| 
 | |
| func (self Row) String() string {
 | |
| 	return fmt.Sprintf("<row_%d:[%s]>", self.RunesLength, self.Matchers)
 | |
| }
 |