mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-10-26 05:33:43 +08:00 
			
		
		
		
	
							
								
								
									
										2
									
								
								vendor/github.com/docker/docker/api/types/swarm/swarm.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/docker/docker/api/types/swarm/swarm.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -209,6 +209,8 @@ type Info struct { | ||||
| 	Managers       int `json:",omitempty"` | ||||
|  | ||||
| 	Cluster *ClusterInfo `json:",omitempty"` | ||||
|  | ||||
| 	Warnings []string `json:",omitempty"` | ||||
| } | ||||
|  | ||||
| // Peer represents a peer. | ||||
|   | ||||
							
								
								
									
										298
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										298
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,298 @@ | ||||
| package fileutils // import "github.com/docker/docker/pkg/fileutils" | ||||
|  | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"regexp" | ||||
| 	"strings" | ||||
| 	"text/scanner" | ||||
|  | ||||
| 	"github.com/sirupsen/logrus" | ||||
| ) | ||||
|  | ||||
| // PatternMatcher allows checking paths against a list of patterns | ||||
| type PatternMatcher struct { | ||||
| 	patterns   []*Pattern | ||||
| 	exclusions bool | ||||
| } | ||||
|  | ||||
| // NewPatternMatcher creates a new matcher object for specific patterns that can | ||||
| // be used later to match against patterns against paths | ||||
| func NewPatternMatcher(patterns []string) (*PatternMatcher, error) { | ||||
| 	pm := &PatternMatcher{ | ||||
| 		patterns: make([]*Pattern, 0, len(patterns)), | ||||
| 	} | ||||
| 	for _, p := range patterns { | ||||
| 		// Eliminate leading and trailing whitespace. | ||||
| 		p = strings.TrimSpace(p) | ||||
| 		if p == "" { | ||||
| 			continue | ||||
| 		} | ||||
| 		p = filepath.Clean(p) | ||||
| 		newp := &Pattern{} | ||||
| 		if p[0] == '!' { | ||||
| 			if len(p) == 1 { | ||||
| 				return nil, errors.New("illegal exclusion pattern: \"!\"") | ||||
| 			} | ||||
| 			newp.exclusion = true | ||||
| 			p = p[1:] | ||||
| 			pm.exclusions = true | ||||
| 		} | ||||
| 		// Do some syntax checking on the pattern. | ||||
| 		// filepath's Match() has some really weird rules that are inconsistent | ||||
| 		// so instead of trying to dup their logic, just call Match() for its | ||||
| 		// error state and if there is an error in the pattern return it. | ||||
| 		// If this becomes an issue we can remove this since its really only | ||||
| 		// needed in the error (syntax) case - which isn't really critical. | ||||
| 		if _, err := filepath.Match(p, "."); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		newp.cleanedPattern = p | ||||
| 		newp.dirs = strings.Split(p, string(os.PathSeparator)) | ||||
| 		pm.patterns = append(pm.patterns, newp) | ||||
| 	} | ||||
| 	return pm, nil | ||||
| } | ||||
|  | ||||
| // Matches matches path against all the patterns. Matches is not safe to be | ||||
| // called concurrently | ||||
| func (pm *PatternMatcher) Matches(file string) (bool, error) { | ||||
| 	matched := false | ||||
| 	file = filepath.FromSlash(file) | ||||
| 	parentPath := filepath.Dir(file) | ||||
| 	parentPathDirs := strings.Split(parentPath, string(os.PathSeparator)) | ||||
|  | ||||
| 	for _, pattern := range pm.patterns { | ||||
| 		negative := false | ||||
|  | ||||
| 		if pattern.exclusion { | ||||
| 			negative = true | ||||
| 		} | ||||
|  | ||||
| 		match, err := pattern.match(file) | ||||
| 		if err != nil { | ||||
| 			return false, err | ||||
| 		} | ||||
|  | ||||
| 		if !match && parentPath != "." { | ||||
| 			// Check to see if the pattern matches one of our parent dirs. | ||||
| 			if len(pattern.dirs) <= len(parentPathDirs) { | ||||
| 				match, _ = pattern.match(strings.Join(parentPathDirs[:len(pattern.dirs)], string(os.PathSeparator))) | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if match { | ||||
| 			matched = !negative | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if matched { | ||||
| 		logrus.Debugf("Skipping excluded path: %s", file) | ||||
| 	} | ||||
|  | ||||
| 	return matched, nil | ||||
| } | ||||
|  | ||||
| // Exclusions returns true if any of the patterns define exclusions | ||||
| func (pm *PatternMatcher) Exclusions() bool { | ||||
| 	return pm.exclusions | ||||
| } | ||||
|  | ||||
| // Patterns returns array of active patterns | ||||
| func (pm *PatternMatcher) Patterns() []*Pattern { | ||||
| 	return pm.patterns | ||||
| } | ||||
|  | ||||
| // Pattern defines a single regexp used to filter file paths. | ||||
| type Pattern struct { | ||||
| 	cleanedPattern string | ||||
| 	dirs           []string | ||||
| 	regexp         *regexp.Regexp | ||||
| 	exclusion      bool | ||||
| } | ||||
|  | ||||
| func (p *Pattern) String() string { | ||||
| 	return p.cleanedPattern | ||||
| } | ||||
|  | ||||
| // Exclusion returns true if this pattern defines exclusion | ||||
| func (p *Pattern) Exclusion() bool { | ||||
| 	return p.exclusion | ||||
| } | ||||
|  | ||||
| func (p *Pattern) match(path string) (bool, error) { | ||||
|  | ||||
| 	if p.regexp == nil { | ||||
| 		if err := p.compile(); err != nil { | ||||
| 			return false, filepath.ErrBadPattern | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	b := p.regexp.MatchString(path) | ||||
|  | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| func (p *Pattern) compile() error { | ||||
| 	regStr := "^" | ||||
| 	pattern := p.cleanedPattern | ||||
| 	// Go through the pattern and convert it to a regexp. | ||||
| 	// We use a scanner so we can support utf-8 chars. | ||||
| 	var scan scanner.Scanner | ||||
| 	scan.Init(strings.NewReader(pattern)) | ||||
|  | ||||
| 	sl := string(os.PathSeparator) | ||||
| 	escSL := sl | ||||
| 	if sl == `\` { | ||||
| 		escSL += `\` | ||||
| 	} | ||||
|  | ||||
| 	for scan.Peek() != scanner.EOF { | ||||
| 		ch := scan.Next() | ||||
|  | ||||
| 		if ch == '*' { | ||||
| 			if scan.Peek() == '*' { | ||||
| 				// is some flavor of "**" | ||||
| 				scan.Next() | ||||
|  | ||||
| 				// Treat **/ as ** so eat the "/" | ||||
| 				if string(scan.Peek()) == sl { | ||||
| 					scan.Next() | ||||
| 				} | ||||
|  | ||||
| 				if scan.Peek() == scanner.EOF { | ||||
| 					// is "**EOF" - to align with .gitignore just accept all | ||||
| 					regStr += ".*" | ||||
| 				} else { | ||||
| 					// is "**" | ||||
| 					// Note that this allows for any # of /'s (even 0) because | ||||
| 					// the .* will eat everything, even /'s | ||||
| 					regStr += "(.*" + escSL + ")?" | ||||
| 				} | ||||
| 			} else { | ||||
| 				// is "*" so map it to anything but "/" | ||||
| 				regStr += "[^" + escSL + "]*" | ||||
| 			} | ||||
| 		} else if ch == '?' { | ||||
| 			// "?" is any char except "/" | ||||
| 			regStr += "[^" + escSL + "]" | ||||
| 		} else if ch == '.' || ch == '$' { | ||||
| 			// Escape some regexp special chars that have no meaning | ||||
| 			// in golang's filepath.Match | ||||
| 			regStr += `\` + string(ch) | ||||
| 		} else if ch == '\\' { | ||||
| 			// escape next char. Note that a trailing \ in the pattern | ||||
| 			// will be left alone (but need to escape it) | ||||
| 			if sl == `\` { | ||||
| 				// On windows map "\" to "\\", meaning an escaped backslash, | ||||
| 				// and then just continue because filepath.Match on | ||||
| 				// Windows doesn't allow escaping at all | ||||
| 				regStr += escSL | ||||
| 				continue | ||||
| 			} | ||||
| 			if scan.Peek() != scanner.EOF { | ||||
| 				regStr += `\` + string(scan.Next()) | ||||
| 			} else { | ||||
| 				regStr += `\` | ||||
| 			} | ||||
| 		} else { | ||||
| 			regStr += string(ch) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	regStr += "$" | ||||
|  | ||||
| 	re, err := regexp.Compile(regStr) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	p.regexp = re | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // Matches returns true if file matches any of the patterns | ||||
| // and isn't excluded by any of the subsequent patterns. | ||||
| func Matches(file string, patterns []string) (bool, error) { | ||||
| 	pm, err := NewPatternMatcher(patterns) | ||||
| 	if err != nil { | ||||
| 		return false, err | ||||
| 	} | ||||
| 	file = filepath.Clean(file) | ||||
|  | ||||
| 	if file == "." { | ||||
| 		// Don't let them exclude everything, kind of silly. | ||||
| 		return false, nil | ||||
| 	} | ||||
|  | ||||
| 	return pm.Matches(file) | ||||
| } | ||||
|  | ||||
| // CopyFile copies from src to dst until either EOF is reached | ||||
| // on src or an error occurs. It verifies src exists and removes | ||||
| // the dst if it exists. | ||||
| func CopyFile(src, dst string) (int64, error) { | ||||
| 	cleanSrc := filepath.Clean(src) | ||||
| 	cleanDst := filepath.Clean(dst) | ||||
| 	if cleanSrc == cleanDst { | ||||
| 		return 0, nil | ||||
| 	} | ||||
| 	sf, err := os.Open(cleanSrc) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	defer sf.Close() | ||||
| 	if err := os.Remove(cleanDst); err != nil && !os.IsNotExist(err) { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	df, err := os.Create(cleanDst) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	defer df.Close() | ||||
| 	return io.Copy(df, sf) | ||||
| } | ||||
|  | ||||
| // ReadSymlinkedDirectory returns the target directory of a symlink. | ||||
| // The target of the symbolic link may not be a file. | ||||
| func ReadSymlinkedDirectory(path string) (string, error) { | ||||
| 	var realPath string | ||||
| 	var err error | ||||
| 	if realPath, err = filepath.Abs(path); err != nil { | ||||
| 		return "", fmt.Errorf("unable to get absolute path for %s: %s", path, err) | ||||
| 	} | ||||
| 	if realPath, err = filepath.EvalSymlinks(realPath); err != nil { | ||||
| 		return "", fmt.Errorf("failed to canonicalise path for %s: %s", path, err) | ||||
| 	} | ||||
| 	realPathInfo, err := os.Stat(realPath) | ||||
| 	if err != nil { | ||||
| 		return "", fmt.Errorf("failed to stat target '%s' of '%s': %s", realPath, path, err) | ||||
| 	} | ||||
| 	if !realPathInfo.Mode().IsDir() { | ||||
| 		return "", fmt.Errorf("canonical path points to a file '%s'", realPath) | ||||
| 	} | ||||
| 	return realPath, nil | ||||
| } | ||||
|  | ||||
| // CreateIfNotExists creates a file or a directory only if it does not already exist. | ||||
| func CreateIfNotExists(path string, isDir bool) error { | ||||
| 	if _, err := os.Stat(path); err != nil { | ||||
| 		if os.IsNotExist(err) { | ||||
| 			if isDir { | ||||
| 				return os.MkdirAll(path, 0755) | ||||
| 			} | ||||
| 			if err := os.MkdirAll(filepath.Dir(path), 0755); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			f, err := os.OpenFile(path, os.O_CREATE, 0755) | ||||
| 			if err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			f.Close() | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										27
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_darwin.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_darwin.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| package fileutils // import "github.com/docker/docker/pkg/fileutils" | ||||
|  | ||||
| import ( | ||||
| 	"os" | ||||
| 	"os/exec" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // GetTotalUsedFds returns the number of used File Descriptors by | ||||
| // executing `lsof -p PID` | ||||
| func GetTotalUsedFds() int { | ||||
| 	pid := os.Getpid() | ||||
|  | ||||
| 	cmd := exec.Command("lsof", "-p", strconv.Itoa(pid)) | ||||
|  | ||||
| 	output, err := cmd.CombinedOutput() | ||||
| 	if err != nil { | ||||
| 		return -1 | ||||
| 	} | ||||
|  | ||||
| 	outputStr := strings.TrimSpace(string(output)) | ||||
|  | ||||
| 	fds := strings.Split(outputStr, "\n") | ||||
|  | ||||
| 	return len(fds) - 1 | ||||
| } | ||||
							
								
								
									
										22
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_unix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_unix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| // +build linux freebsd | ||||
|  | ||||
| package fileutils // import "github.com/docker/docker/pkg/fileutils" | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"io/ioutil" | ||||
| 	"os" | ||||
|  | ||||
| 	"github.com/sirupsen/logrus" | ||||
| ) | ||||
|  | ||||
| // GetTotalUsedFds Returns the number of used File Descriptors by | ||||
| // reading it via /proc filesystem. | ||||
| func GetTotalUsedFds() int { | ||||
| 	if fds, err := ioutil.ReadDir(fmt.Sprintf("/proc/%d/fd", os.Getpid())); err != nil { | ||||
| 		logrus.Errorf("Error opening /proc/%d/fd: %s", os.Getpid(), err) | ||||
| 	} else { | ||||
| 		return len(fds) | ||||
| 	} | ||||
| 	return -1 | ||||
| } | ||||
							
								
								
									
										7
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_windows.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								vendor/github.com/docker/docker/pkg/fileutils/fileutils_windows.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| package fileutils // import "github.com/docker/docker/pkg/fileutils" | ||||
|  | ||||
| // GetTotalUsedFds Returns the number of used File Descriptors. Not supported | ||||
| // on Windows. | ||||
| func GetTotalUsedFds() int { | ||||
| 	return -1 | ||||
| } | ||||
							
								
								
									
										33
									
								
								vendor/github.com/docker/go-units/MAINTAINERS
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								vendor/github.com/docker/go-units/MAINTAINERS
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| # go-units maintainers file | ||||
| # go-connections maintainers file | ||||
| # | ||||
| # This file describes who runs the docker/go-units project and how. | ||||
| # This file describes who runs the docker/go-connections project and how. | ||||
| # This is a living document - if you see something out of date or missing, speak up! | ||||
| # | ||||
| # It is structured to be consumable by both humans and programs. | ||||
| @@ -11,10 +11,7 @@ | ||||
| [Org] | ||||
| 	[Org."Core maintainers"] | ||||
| 		people = [ | ||||
| 			"akihirosuda", | ||||
| 			"dnephin", | ||||
| 			"thajeztah", | ||||
| 			"vdemeester", | ||||
| 			"calavera", | ||||
| 		] | ||||
|  | ||||
| [people] | ||||
| @@ -24,23 +21,7 @@ | ||||
| # in the people section. | ||||
|  | ||||
| 	# ADD YOURSELF HERE IN ALPHABETICAL ORDER | ||||
|  | ||||
| 	[people.akihirosuda] | ||||
| 	Name = "Akihiro Suda" | ||||
| 	Email = "suda.akihiro@lab.ntt.co.jp" | ||||
| 	GitHub = "AkihiroSuda" | ||||
|  | ||||
| 	[people.dnephin] | ||||
| 	Name = "Daniel Nephin" | ||||
| 	Email = "dnephin@gmail.com" | ||||
| 	GitHub = "dnephin" | ||||
| 	 | ||||
| 	[people.thajeztah] | ||||
| 	Name = "Sebastiaan van Stijn" | ||||
| 	Email = "github@gone.nl" | ||||
| 	GitHub = "thaJeztah" | ||||
|  | ||||
| 	[people.vdemeester] | ||||
| 	Name = "Vincent Demeester" | ||||
| 	Email = "vincent@sbr.pm" | ||||
| 	GitHub = "vdemeester" | ||||
| 	[people.calavera] | ||||
| 	Name = "David Calavera" | ||||
| 	Email = "david.calavera@gmail.com" | ||||
| 	GitHub = "calavera" | ||||
|   | ||||
							
								
								
									
										8
									
								
								vendor/github.com/docker/go-units/duration.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								vendor/github.com/docker/go-units/duration.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -12,21 +12,19 @@ import ( | ||||
| func HumanDuration(d time.Duration) string { | ||||
| 	if seconds := int(d.Seconds()); seconds < 1 { | ||||
| 		return "Less than a second" | ||||
| 	} else if seconds == 1 { | ||||
| 		return "1 second" | ||||
| 	} else if seconds < 60 { | ||||
| 		return fmt.Sprintf("%d seconds", seconds) | ||||
| 	} else if minutes := int(d.Minutes()); minutes == 1 { | ||||
| 		return "About a minute" | ||||
| 	} else if minutes < 46 { | ||||
| 	} else if minutes < 60 { | ||||
| 		return fmt.Sprintf("%d minutes", minutes) | ||||
| 	} else if hours := int(d.Hours() + 0.5); hours == 1 { | ||||
| 	} else if hours := int(d.Hours()); hours == 1 { | ||||
| 		return "About an hour" | ||||
| 	} else if hours < 48 { | ||||
| 		return fmt.Sprintf("%d hours", hours) | ||||
| 	} else if hours < 24*7*2 { | ||||
| 		return fmt.Sprintf("%d days", hours/24) | ||||
| 	} else if hours < 24*30*2 { | ||||
| 	} else if hours < 24*30*3 { | ||||
| 		return fmt.Sprintf("%d weeks", hours/24/7) | ||||
| 	} else if hours < 24*365*2 { | ||||
| 		return fmt.Sprintf("%d months", hours/24/30) | ||||
|   | ||||
							
								
								
									
										26
									
								
								vendor/github.com/docker/go-units/size.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								vendor/github.com/docker/go-units/size.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -31,46 +31,34 @@ type unitMap map[string]int64 | ||||
| var ( | ||||
| 	decimalMap = unitMap{"k": KB, "m": MB, "g": GB, "t": TB, "p": PB} | ||||
| 	binaryMap  = unitMap{"k": KiB, "m": MiB, "g": GiB, "t": TiB, "p": PiB} | ||||
| 	sizeRegex  = regexp.MustCompile(`^(\d+(\.\d+)*) ?([kKmMgGtTpP])?[iI]?[bB]?$`) | ||||
| 	sizeRegex  = regexp.MustCompile(`^(\d+(\.\d+)*) ?([kKmMgGtTpP])?[bB]?$`) | ||||
| ) | ||||
|  | ||||
| var decimapAbbrs = []string{"B", "kB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"} | ||||
| var binaryAbbrs = []string{"B", "KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"} | ||||
|  | ||||
| func getSizeAndUnit(size float64, base float64, _map []string) (float64, string) { | ||||
| // CustomSize returns a human-readable approximation of a size | ||||
| // using custom format. | ||||
| func CustomSize(format string, size float64, base float64, _map []string) string { | ||||
| 	i := 0 | ||||
| 	unitsLimit := len(_map) - 1 | ||||
| 	for size >= base && i < unitsLimit { | ||||
| 		size = size / base | ||||
| 		i++ | ||||
| 	} | ||||
| 	return size, _map[i] | ||||
| } | ||||
|  | ||||
| // CustomSize returns a human-readable approximation of a size | ||||
| // using custom format. | ||||
| func CustomSize(format string, size float64, base float64, _map []string) string { | ||||
| 	size, unit := getSizeAndUnit(size, base, _map) | ||||
| 	return fmt.Sprintf(format, size, unit) | ||||
| } | ||||
|  | ||||
| // HumanSizeWithPrecision allows the size to be in any precision, | ||||
| // instead of 4 digit precision used in units.HumanSize. | ||||
| func HumanSizeWithPrecision(size float64, precision int) string { | ||||
| 	size, unit := getSizeAndUnit(size, 1000.0, decimapAbbrs) | ||||
| 	return fmt.Sprintf("%.*g%s", precision, size, unit) | ||||
| 	return fmt.Sprintf(format, size, _map[i]) | ||||
| } | ||||
|  | ||||
| // HumanSize returns a human-readable approximation of a size | ||||
| // capped at 4 valid numbers (eg. "2.746 MB", "796 KB"). | ||||
| func HumanSize(size float64) string { | ||||
| 	return HumanSizeWithPrecision(size, 4) | ||||
| 	return CustomSize("%.4g %s", size, 1000.0, decimapAbbrs) | ||||
| } | ||||
|  | ||||
| // BytesSize returns a human-readable size in bytes, kibibytes, | ||||
| // mebibytes, gibibytes, or tebibytes (eg. "44kiB", "17MiB"). | ||||
| func BytesSize(size float64) string { | ||||
| 	return CustomSize("%.4g%s", size, 1024.0, binaryAbbrs) | ||||
| 	return CustomSize("%.4g %s", size, 1024.0, binaryAbbrs) | ||||
| } | ||||
|  | ||||
| // FromHumanSize returns an integer from a human-readable specification of a | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Tonis Tiigi
					Tonis Tiigi