mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 09:34:29 +02:00 
			
		
		
		
	* update github.com/blevesearch/bleve v2.0.2 -> v2.0.3 * github.com/denisenkom/go-mssqldb v0.9.0 -> v0.10.0 * github.com/editorconfig/editorconfig-core-go v2.4.1 -> v2.4.2 * github.com/go-chi/cors v1.1.1 -> v1.2.0 * github.com/go-git/go-billy v5.0.0 -> v5.1.0 * github.com/go-git/go-git v5.2.0 -> v5.3.0 * github.com/go-ldap/ldap v3.2.4 -> v3.3.0 * github.com/go-redis/redis v8.6.0 -> v8.8.2 * github.com/go-sql-driver/mysql v1.5.0 -> v1.6.0 * github.com/go-swagger/go-swagger v0.26.1 -> v0.27.0 * github.com/lib/pq v1.9.0 -> v1.10.1 * github.com/mattn/go-sqlite3 v1.14.6 -> v1.14.7 * github.com/go-testfixtures/testfixtures v3.5.0 -> v3.6.0 * github.com/issue9/identicon v1.0.1 -> v1.2.0 * github.com/klauspost/compress v1.11.8 -> v1.12.1 * github.com/mgechev/revive v1.0.3 -> v1.0.6 * github.com/microcosm-cc/bluemonday v1.0.7 -> v1.0.8 * github.com/niklasfasching/go-org v1.4.0 -> v1.5.0 * github.com/olivere/elastic v7.0.22 -> v7.0.24 * github.com/pelletier/go-toml v1.8.1 -> v1.9.0 * github.com/prometheus/client_golang v1.9.0 -> v1.10.0 * github.com/xanzy/go-gitlab v0.44.0 -> v0.48.0 * github.com/yuin/goldmark v1.3.3 -> v1.3.5 * github.com/6543/go-version v1.2.4 -> v1.3.1 * do github.com/lib/pq v1.10.0 -> v1.10.1 again ...
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2019 The Go Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package protoreflect
 | |
| 
 | |
| import (
 | |
| 	"strconv"
 | |
| )
 | |
| 
 | |
| // SourceLocations is a list of source locations.
 | |
| type SourceLocations interface {
 | |
| 	// Len reports the number of source locations in the proto file.
 | |
| 	Len() int
 | |
| 	// Get returns the ith SourceLocation. It panics if out of bounds.
 | |
| 	Get(int) SourceLocation
 | |
| 
 | |
| 	// ByPath returns the SourceLocation for the given path,
 | |
| 	// returning the first location if multiple exist for the same path.
 | |
| 	// If multiple locations exist for the same path,
 | |
| 	// then SourceLocation.Next index can be used to identify the
 | |
| 	// index of the next SourceLocation.
 | |
| 	// If no location exists for this path, it returns the zero value.
 | |
| 	ByPath(path SourcePath) SourceLocation
 | |
| 
 | |
| 	// ByDescriptor returns the SourceLocation for the given descriptor,
 | |
| 	// returning the first location if multiple exist for the same path.
 | |
| 	// If no location exists for this descriptor, it returns the zero value.
 | |
| 	ByDescriptor(desc Descriptor) SourceLocation
 | |
| 
 | |
| 	doNotImplement
 | |
| }
 | |
| 
 | |
| // SourceLocation describes a source location and
 | |
| // corresponds with the google.protobuf.SourceCodeInfo.Location message.
 | |
| type SourceLocation struct {
 | |
| 	// Path is the path to the declaration from the root file descriptor.
 | |
| 	// The contents of this slice must not be mutated.
 | |
| 	Path SourcePath
 | |
| 
 | |
| 	// StartLine and StartColumn are the zero-indexed starting location
 | |
| 	// in the source file for the declaration.
 | |
| 	StartLine, StartColumn int
 | |
| 	// EndLine and EndColumn are the zero-indexed ending location
 | |
| 	// in the source file for the declaration.
 | |
| 	// In the descriptor.proto, the end line may be omitted if it is identical
 | |
| 	// to the start line. Here, it is always populated.
 | |
| 	EndLine, EndColumn int
 | |
| 
 | |
| 	// LeadingDetachedComments are the leading detached comments
 | |
| 	// for the declaration. The contents of this slice must not be mutated.
 | |
| 	LeadingDetachedComments []string
 | |
| 	// LeadingComments is the leading attached comment for the declaration.
 | |
| 	LeadingComments string
 | |
| 	// TrailingComments is the trailing attached comment for the declaration.
 | |
| 	TrailingComments string
 | |
| 
 | |
| 	// Next is an index into SourceLocations for the next source location that
 | |
| 	// has the same Path. It is zero if there is no next location.
 | |
| 	Next int
 | |
| }
 | |
| 
 | |
| // SourcePath identifies part of a file descriptor for a source location.
 | |
| // The SourcePath is a sequence of either field numbers or indexes into
 | |
| // a repeated field that form a path starting from the root file descriptor.
 | |
| //
 | |
| // See google.protobuf.SourceCodeInfo.Location.path.
 | |
| type SourcePath []int32
 | |
| 
 | |
| // Equal reports whether p1 equals p2.
 | |
| func (p1 SourcePath) Equal(p2 SourcePath) bool {
 | |
| 	if len(p1) != len(p2) {
 | |
| 		return false
 | |
| 	}
 | |
| 	for i := range p1 {
 | |
| 		if p1[i] != p2[i] {
 | |
| 			return false
 | |
| 		}
 | |
| 	}
 | |
| 	return true
 | |
| }
 | |
| 
 | |
| // String formats the path in a humanly readable manner.
 | |
| // The output is guaranteed to be deterministic,
 | |
| // making it suitable for use as a key into a Go map.
 | |
| // It is not guaranteed to be stable as the exact output could change
 | |
| // in a future version of this module.
 | |
| //
 | |
| // Example output:
 | |
| //	.message_type[6].nested_type[15].field[3]
 | |
| func (p SourcePath) String() string {
 | |
| 	b := p.appendFileDescriptorProto(nil)
 | |
| 	for _, i := range p {
 | |
| 		b = append(b, '.')
 | |
| 		b = strconv.AppendInt(b, int64(i), 10)
 | |
| 	}
 | |
| 	return string(b)
 | |
| }
 | |
| 
 | |
| type appendFunc func(*SourcePath, []byte) []byte
 | |
| 
 | |
| func (p *SourcePath) appendSingularField(b []byte, name string, f appendFunc) []byte {
 | |
| 	if len(*p) == 0 {
 | |
| 		return b
 | |
| 	}
 | |
| 	b = append(b, '.')
 | |
| 	b = append(b, name...)
 | |
| 	*p = (*p)[1:]
 | |
| 	if f != nil {
 | |
| 		b = f(p, b)
 | |
| 	}
 | |
| 	return b
 | |
| }
 | |
| 
 | |
| func (p *SourcePath) appendRepeatedField(b []byte, name string, f appendFunc) []byte {
 | |
| 	b = p.appendSingularField(b, name, nil)
 | |
| 	if len(*p) == 0 || (*p)[0] < 0 {
 | |
| 		return b
 | |
| 	}
 | |
| 	b = append(b, '[')
 | |
| 	b = strconv.AppendUint(b, uint64((*p)[0]), 10)
 | |
| 	b = append(b, ']')
 | |
| 	*p = (*p)[1:]
 | |
| 	if f != nil {
 | |
| 		b = f(p, b)
 | |
| 	}
 | |
| 	return b
 | |
| }
 |