mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 11:28:24 +00:00 
			
		
		
		
	* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2019 The Prometheus Authors
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| // http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package util
 | |
| 
 | |
| import (
 | |
| 	"strconv"
 | |
| )
 | |
| 
 | |
| // TODO(mdlayher): util packages are an anti-pattern and this should be moved
 | |
| // somewhere else that is more focused in the future.
 | |
| 
 | |
| // A ValueParser enables parsing a single string into a variety of data types
 | |
| // in a concise and safe way. The Err method must be invoked after invoking
 | |
| // any other methods to ensure a value was successfully parsed.
 | |
| type ValueParser struct {
 | |
| 	v   string
 | |
| 	err error
 | |
| }
 | |
| 
 | |
| // NewValueParser creates a ValueParser using the input string.
 | |
| func NewValueParser(v string) *ValueParser {
 | |
| 	return &ValueParser{v: v}
 | |
| }
 | |
| 
 | |
| // Int interprets the underlying value as an int and returns that value.
 | |
| func (vp *ValueParser) Int() int { return int(vp.int64()) }
 | |
| 
 | |
| // PInt64 interprets the underlying value as an int64 and returns a pointer to
 | |
| // that value.
 | |
| func (vp *ValueParser) PInt64() *int64 {
 | |
| 	if vp.err != nil {
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	v := vp.int64()
 | |
| 	return &v
 | |
| }
 | |
| 
 | |
| // int64 interprets the underlying value as an int64 and returns that value.
 | |
| // TODO: export if/when necessary.
 | |
| func (vp *ValueParser) int64() int64 {
 | |
| 	if vp.err != nil {
 | |
| 		return 0
 | |
| 	}
 | |
| 
 | |
| 	// A base value of zero makes ParseInt infer the correct base using the
 | |
| 	// string's prefix, if any.
 | |
| 	const base = 0
 | |
| 	v, err := strconv.ParseInt(vp.v, base, 64)
 | |
| 	if err != nil {
 | |
| 		vp.err = err
 | |
| 		return 0
 | |
| 	}
 | |
| 
 | |
| 	return v
 | |
| }
 | |
| 
 | |
| // PUInt64 interprets the underlying value as an uint64 and returns a pointer to
 | |
| // that value.
 | |
| func (vp *ValueParser) PUInt64() *uint64 {
 | |
| 	if vp.err != nil {
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	// A base value of zero makes ParseInt infer the correct base using the
 | |
| 	// string's prefix, if any.
 | |
| 	const base = 0
 | |
| 	v, err := strconv.ParseUint(vp.v, base, 64)
 | |
| 	if err != nil {
 | |
| 		vp.err = err
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	return &v
 | |
| }
 | |
| 
 | |
| // Err returns the last error, if any, encountered by the ValueParser.
 | |
| func (vp *ValueParser) Err() error {
 | |
| 	return vp.err
 | |
| }
 |