forked from toolshed/abra
		
	refactor: urfave v3
This commit is contained in:
		
							
								
								
									
										189
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										189
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,121 +1,122 @@ | ||||
| // Package config implements encoding and decoding of git config files. | ||||
| // | ||||
| //	Configuration File | ||||
| //	------------------ | ||||
| // 	Configuration File | ||||
| // 	------------------ | ||||
| // | ||||
| //	The Git configuration file contains a number of variables that affect | ||||
| //	the Git commands' behavior. The `.git/config` file in each repository | ||||
| //	is used to store the configuration for that repository, and | ||||
| //	`$HOME/.gitconfig` is used to store a per-user configuration as | ||||
| //	fallback values for the `.git/config` file. The file `/etc/gitconfig` | ||||
| //	can be used to store a system-wide default configuration. | ||||
| // 	The Git configuration file contains a number of variables that affect | ||||
| // 	the Git commands' behavior. The `.git/config` file in each repository | ||||
| // 	is used to store the configuration for that repository, and | ||||
| // 	`$HOME/.gitconfig` is used to store a per-user configuration as | ||||
| // 	fallback values for the `.git/config` file. The file `/etc/gitconfig` | ||||
| // 	can be used to store a system-wide default configuration. | ||||
| // | ||||
| //	The configuration variables are used by both the Git plumbing | ||||
| //	and the porcelains. The variables are divided into sections, wherein | ||||
| //	the fully qualified variable name of the variable itself is the last | ||||
| //	dot-separated segment and the section name is everything before the last | ||||
| //	dot. The variable names are case-insensitive, allow only alphanumeric | ||||
| //	characters and `-`, and must start with an alphabetic character.  Some | ||||
| //	variables may appear multiple times; we say then that the variable is | ||||
| //	multivalued. | ||||
| // 	The configuration variables are used by both the Git plumbing | ||||
| // 	and the porcelains. The variables are divided into sections, wherein | ||||
| // 	the fully qualified variable name of the variable itself is the last | ||||
| // 	dot-separated segment and the section name is everything before the last | ||||
| // 	dot. The variable names are case-insensitive, allow only alphanumeric | ||||
| // 	characters and `-`, and must start with an alphabetic character.  Some | ||||
| // 	variables may appear multiple times; we say then that the variable is | ||||
| // 	multivalued. | ||||
| // | ||||
| //	Syntax | ||||
| //	~~~~~~ | ||||
| // 	Syntax | ||||
| // 	~~~~~~ | ||||
| // | ||||
| //	The syntax is fairly flexible and permissive; whitespaces are mostly | ||||
| //	ignored.  The '#' and ';' characters begin comments to the end of line, | ||||
| //	blank lines are ignored. | ||||
| // 	The syntax is fairly flexible and permissive; whitespaces are mostly | ||||
| // 	ignored.  The '#' and ';' characters begin comments to the end of line, | ||||
| // 	blank lines are ignored. | ||||
| // | ||||
| //	The file consists of sections and variables.  A section begins with | ||||
| //	the name of the section in square brackets and continues until the next | ||||
| //	section begins.  Section names are case-insensitive.  Only alphanumeric | ||||
| //	characters, `-` and `.` are allowed in section names.  Each variable | ||||
| //	must belong to some section, which means that there must be a section | ||||
| //	header before the first setting of a variable. | ||||
| // 	The file consists of sections and variables.  A section begins with | ||||
| // 	the name of the section in square brackets and continues until the next | ||||
| // 	section begins.  Section names are case-insensitive.  Only alphanumeric | ||||
| // 	characters, `-` and `.` are allowed in section names.  Each variable | ||||
| // 	must belong to some section, which means that there must be a section | ||||
| // 	header before the first setting of a variable. | ||||
| // | ||||
| //	Sections can be further divided into subsections.  To begin a subsection | ||||
| //	put its name in double quotes, separated by space from the section name, | ||||
| //	in the section header, like in the example below: | ||||
| // 	Sections can be further divided into subsections.  To begin a subsection | ||||
| // 	put its name in double quotes, separated by space from the section name, | ||||
| // 	in the section header, like in the example below: | ||||
| // | ||||
| //	-------- | ||||
| //		[section "subsection"] | ||||
| // 	-------- | ||||
| // 		[section "subsection"] | ||||
| // | ||||
| //	-------- | ||||
| // 	-------- | ||||
| // | ||||
| //	Subsection names are case sensitive and can contain any characters except | ||||
| //	newline (doublequote `"` and backslash can be included by escaping them | ||||
| //	as `\"` and `\\`, respectively).  Section headers cannot span multiple | ||||
| //	lines.  Variables may belong directly to a section or to a given subsection. | ||||
| //	You can have `[section]` if you have `[section "subsection"]`, but you | ||||
| //	don't need to. | ||||
| // 	Subsection names are case sensitive and can contain any characters except | ||||
| // 	newline (doublequote `"` and backslash can be included by escaping them | ||||
| // 	as `\"` and `\\`, respectively).  Section headers cannot span multiple | ||||
| // 	lines.  Variables may belong directly to a section or to a given subsection. | ||||
| // 	You can have `[section]` if you have `[section "subsection"]`, but you | ||||
| // 	don't need to. | ||||
| // | ||||
| //	There is also a deprecated `[section.subsection]` syntax. With this | ||||
| //	syntax, the subsection name is converted to lower-case and is also | ||||
| //	compared case sensitively. These subsection names follow the same | ||||
| //	restrictions as section names. | ||||
| // 	There is also a deprecated `[section.subsection]` syntax. With this | ||||
| // 	syntax, the subsection name is converted to lower-case and is also | ||||
| // 	compared case sensitively. These subsection names follow the same | ||||
| // 	restrictions as section names. | ||||
| // | ||||
| //	All the other lines (and the remainder of the line after the section | ||||
| //	header) are recognized as setting variables, in the form | ||||
| //	'name = value' (or just 'name', which is a short-hand to say that | ||||
| //	the variable is the boolean "true"). | ||||
| //	The variable names are case-insensitive, allow only alphanumeric characters | ||||
| //	and `-`, and must start with an alphabetic character. | ||||
| // 	All the other lines (and the remainder of the line after the section | ||||
| // 	header) are recognized as setting variables, in the form | ||||
| // 	'name = value' (or just 'name', which is a short-hand to say that | ||||
| // 	the variable is the boolean "true"). | ||||
| // 	The variable names are case-insensitive, allow only alphanumeric characters | ||||
| // 	and `-`, and must start with an alphabetic character. | ||||
| // | ||||
| //	A line that defines a value can be continued to the next line by | ||||
| //	ending it with a `\`; the backquote and the end-of-line are | ||||
| //	stripped.  Leading whitespaces after 'name =', the remainder of the | ||||
| //	line after the first comment character '#' or ';', and trailing | ||||
| //	whitespaces of the line are discarded unless they are enclosed in | ||||
| //	double quotes.  Internal whitespaces within the value are retained | ||||
| //	verbatim. | ||||
| // 	A line that defines a value can be continued to the next line by | ||||
| // 	ending it with a `\`; the backquote and the end-of-line are | ||||
| // 	stripped.  Leading whitespaces after 'name =', the remainder of the | ||||
| // 	line after the first comment character '#' or ';', and trailing | ||||
| // 	whitespaces of the line are discarded unless they are enclosed in | ||||
| // 	double quotes.  Internal whitespaces within the value are retained | ||||
| // 	verbatim. | ||||
| // | ||||
| //	Inside double quotes, double quote `"` and backslash `\` characters | ||||
| //	must be escaped: use `\"` for `"` and `\\` for `\`. | ||||
| // 	Inside double quotes, double quote `"` and backslash `\` characters | ||||
| // 	must be escaped: use `\"` for `"` and `\\` for `\`. | ||||
| // | ||||
| //	The following escape sequences (beside `\"` and `\\`) are recognized: | ||||
| //	`\n` for newline character (NL), `\t` for horizontal tabulation (HT, TAB) | ||||
| //	and `\b` for backspace (BS).  Other char escape sequences (including octal | ||||
| //	escape sequences) are invalid. | ||||
| // 	The following escape sequences (beside `\"` and `\\`) are recognized: | ||||
| // 	`\n` for newline character (NL), `\t` for horizontal tabulation (HT, TAB) | ||||
| // 	and `\b` for backspace (BS).  Other char escape sequences (including octal | ||||
| // 	escape sequences) are invalid. | ||||
| // | ||||
| //	Includes | ||||
| //	~~~~~~~~ | ||||
| // 	Includes | ||||
| // 	~~~~~~~~ | ||||
| // | ||||
| //	You can include one config file from another by setting the special | ||||
| //	`include.path` variable to the name of the file to be included. The | ||||
| //	variable takes a pathname as its value, and is subject to tilde | ||||
| //	expansion. | ||||
| // 	You can include one config file from another by setting the special | ||||
| // 	`include.path` variable to the name of the file to be included. The | ||||
| // 	variable takes a pathname as its value, and is subject to tilde | ||||
| // 	expansion. | ||||
| // | ||||
| //	The included file is expanded immediately, as if its contents had been | ||||
| //	found at the location of the include directive. If the value of the | ||||
| //	`include.path` variable is a relative path, the path is considered to be | ||||
| //	relative to the configuration file in which the include directive was | ||||
| //	found.  See below for examples. | ||||
| // 	The included file is expanded immediately, as if its contents had been | ||||
| // 	found at the location of the include directive. If the value of the | ||||
| // 	`include.path` variable is a relative path, the path is considered to be | ||||
| // 	relative to the configuration file in which the include directive was | ||||
| // 	found.  See below for examples. | ||||
| // | ||||
| // | ||||
| //	Example | ||||
| //	~~~~~~~ | ||||
| // 	Example | ||||
| // 	~~~~~~~ | ||||
| // | ||||
| //		# Core variables | ||||
| //		[core] | ||||
| //			; Don't trust file modes | ||||
| //			filemode = false | ||||
| // 		# Core variables | ||||
| // 		[core] | ||||
| // 			; Don't trust file modes | ||||
| // 			filemode = false | ||||
| // | ||||
| //		# Our diff algorithm | ||||
| //		[diff] | ||||
| //			external = /usr/local/bin/diff-wrapper | ||||
| //			renames = true | ||||
| // 		# Our diff algorithm | ||||
| // 		[diff] | ||||
| // 			external = /usr/local/bin/diff-wrapper | ||||
| // 			renames = true | ||||
| // | ||||
| //		[branch "devel"] | ||||
| //			remote = origin | ||||
| //			merge = refs/heads/devel | ||||
| // 		[branch "devel"] | ||||
| // 			remote = origin | ||||
| // 			merge = refs/heads/devel | ||||
| // | ||||
| //		# Proxy settings | ||||
| //		[core] | ||||
| //			gitProxy="ssh" for "kernel.org" | ||||
| //			gitProxy=default-proxy ; for the rest | ||||
| // 		# Proxy settings | ||||
| // 		[core] | ||||
| // 			gitProxy="ssh" for "kernel.org" | ||||
| // 			gitProxy=default-proxy ; for the rest | ||||
| // | ||||
| // 		[include] | ||||
| // 			path = /path/to/foo.inc ; include by absolute path | ||||
| // 			path = foo ; expand "foo" relative to the current file | ||||
| // 			path = ~/foo ; expand "foo" in your `$HOME` directory | ||||
| // | ||||
| //		[include] | ||||
| //			path = /path/to/foo.inc ; include by absolute path | ||||
| //			path = foo ; expand "foo" relative to the current file | ||||
| //			path = ~/foo ; expand "foo" in your `$HOME` directory | ||||
| package config | ||||
|  | ||||
							
								
								
									
										5
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/encoder.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/encoder.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -13,9 +13,8 @@ type Encoder struct { | ||||
|  | ||||
| var ( | ||||
| 	subsectionReplacer = strings.NewReplacer(`"`, `\"`, `\`, `\\`) | ||||
| 	valueReplacer      = strings.NewReplacer(`"`, `\"`, `\`, `\\`, "\n", `\n`, "\t", `\t`, "\b", `\b`) | ||||
| 	valueReplacer = strings.NewReplacer(`"`, `\"`, `\`, `\\`, "\n", `\n`, "\t", `\t`, "\b", `\b`) | ||||
| ) | ||||
|  | ||||
| // NewEncoder returns a new encoder that writes to w. | ||||
| func NewEncoder(w io.Writer) *Encoder { | ||||
| 	return &Encoder{w} | ||||
| @ -64,7 +63,7 @@ func (e *Encoder) encodeOptions(opts Options) error { | ||||
| 	for _, o := range opts { | ||||
| 		var value string | ||||
| 		if strings.ContainsAny(o.Value, "#;\"\t\n\\") || strings.HasPrefix(o.Value, " ") || strings.HasSuffix(o.Value, " ") { | ||||
| 			value = `"` + valueReplacer.Replace(o.Value) + `"` | ||||
| 			value = `"`+valueReplacer.Replace(o.Value)+`"` | ||||
| 		} else { | ||||
| 			value = o.Value | ||||
| 		} | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/option.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/option.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -34,7 +34,7 @@ func (opts Options) GoString() string { | ||||
| // Get gets the value for the given key if set, | ||||
| // otherwise it returns the empty string. | ||||
| // | ||||
| // # Note that there is no difference | ||||
| // Note that there is no difference | ||||
| // | ||||
| // This matches git behaviour since git v1.8.1-rc1, | ||||
| // if there are multiple definitions of a key, the | ||||
|  | ||||
							
								
								
									
										13
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/section.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/config/section.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -12,7 +12,7 @@ import ( | ||||
| // put its name in double quotes, separated by space from the section name, | ||||
| // in the section header, like in the example below: | ||||
| // | ||||
| //	[section "subsection"] | ||||
| //     [section "subsection"] | ||||
| // | ||||
| // All the other lines (and the remainder of the line after the section header) | ||||
| // are recognized as option variables, in the form "name = value" (or just name, | ||||
| @ -20,11 +20,12 @@ import ( | ||||
| // The variable names are case-insensitive, allow only alphanumeric characters | ||||
| // and -, and must start with an alphabetic character: | ||||
| // | ||||
| //	[section "subsection1"] | ||||
| //	    option1 = value1 | ||||
| //	    option2 | ||||
| //	[section "subsection2"] | ||||
| //	    option3 = value2 | ||||
| //     [section "subsection1"] | ||||
| //         option1 = value1 | ||||
| //         option2 | ||||
| //     [section "subsection2"] | ||||
| //         option3 = value2 | ||||
| // | ||||
| type Section struct { | ||||
| 	Name        string | ||||
| 	Options     Options | ||||
|  | ||||
							
								
								
									
										96
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/gitignore/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										96
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/gitignore/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -3,68 +3,68 @@ | ||||
| // priorities. It support all pattern formats as specified in the original gitignore | ||||
| // documentation, copied below: | ||||
| // | ||||
| //	  Pattern format | ||||
| //	  ============== | ||||
| //   Pattern format | ||||
| //   ============== | ||||
| // | ||||
| //			- A blank line matches no files, so it can serve as a separator for readability. | ||||
| //		- A blank line matches no files, so it can serve as a separator for readability. | ||||
| // | ||||
| //			- A line starting with # serves as a comment. Put a backslash ("\") in front of | ||||
| //			  the first hash for patterns that begin with a hash. | ||||
| //		- A line starting with # serves as a comment. Put a backslash ("\") in front of | ||||
| //		  the first hash for patterns that begin with a hash. | ||||
| // | ||||
| //			- Trailing spaces are ignored unless they are quoted with backslash ("\"). | ||||
| //		- Trailing spaces are ignored unless they are quoted with backslash ("\"). | ||||
| // | ||||
| //			- An optional prefix "!" which negates the pattern; any matching file excluded | ||||
| //			  by a previous pattern will become included again. It is not possible to | ||||
| //			  re-include a file if a parent directory of that file is excluded. | ||||
| //			  Git doesn’t list excluded directories for performance reasons, so | ||||
| //			  any patterns on contained files have no effect, no matter where they are | ||||
| //			  defined. Put a backslash ("\") in front of the first "!" for patterns | ||||
| //			  that begin with a literal "!", for example, "\!important!.txt". | ||||
| //		- An optional prefix "!" which negates the pattern; any matching file excluded | ||||
| //		  by a previous pattern will become included again. It is not possible to | ||||
| //		  re-include a file if a parent directory of that file is excluded. | ||||
| //		  Git doesn’t list excluded directories for performance reasons, so | ||||
| //		  any patterns on contained files have no effect, no matter where they are | ||||
| //		  defined. Put a backslash ("\") in front of the first "!" for patterns | ||||
| //		  that begin with a literal "!", for example, "\!important!.txt". | ||||
| // | ||||
| //			- If the pattern ends with a slash, it is removed for the purpose of the | ||||
| //			  following description, but it would only find a match with a directory. | ||||
| //			  In other words, foo/ will match a directory foo and paths underneath it, | ||||
| //			  but will not match a regular file or a symbolic link foo (this is consistent | ||||
| //			  with the way how pathspec works in general in Git). | ||||
| //		- If the pattern ends with a slash, it is removed for the purpose of the | ||||
| //		  following description, but it would only find a match with a directory. | ||||
| //		  In other words, foo/ will match a directory foo and paths underneath it, | ||||
| //		  but will not match a regular file or a symbolic link foo (this is consistent | ||||
| //		  with the way how pathspec works in general in Git). | ||||
| // | ||||
| //			- If the pattern does not contain a slash /, Git treats it as a shell glob | ||||
| //			  pattern and checks for a match against the pathname relative to the location | ||||
| //			  of the .gitignore file (relative to the toplevel of the work tree if not | ||||
| //			  from a .gitignore file). | ||||
| //		- If the pattern does not contain a slash /, Git treats it as a shell glob | ||||
| //		  pattern and checks for a match against the pathname relative to the location | ||||
| //		  of the .gitignore file (relative to the toplevel of the work tree if not | ||||
| //		  from a .gitignore file). | ||||
| // | ||||
| //			- Otherwise, Git treats the pattern as a shell glob suitable for consumption | ||||
| //			  by fnmatch(3) with the FNM_PATHNAME flag: wildcards in the pattern will | ||||
| //			  not match a / in the pathname. For example, "Documentation/*.html" matches | ||||
| //			  "Documentation/git.html" but not "Documentation/ppc/ppc.html" or | ||||
| //			  "tools/perf/Documentation/perf.html". | ||||
| //		- Otherwise, Git treats the pattern as a shell glob suitable for consumption | ||||
| //		  by fnmatch(3) with the FNM_PATHNAME flag: wildcards in the pattern will | ||||
| //		  not match a / in the pathname. For example, "Documentation/*.html" matches | ||||
| //		  "Documentation/git.html" but not "Documentation/ppc/ppc.html" or | ||||
| //		  "tools/perf/Documentation/perf.html". | ||||
| // | ||||
| //			- A leading slash matches the beginning of the pathname. For example, | ||||
| //			  "/*.c" matches "cat-file.c" but not "mozilla-sha1/sha1.c". | ||||
| //		- A leading slash matches the beginning of the pathname. For example, | ||||
| //		  "/*.c" matches "cat-file.c" but not "mozilla-sha1/sha1.c". | ||||
| // | ||||
| //			Two consecutive asterisks ("**") in patterns matched against full pathname | ||||
| //			may have special meaning: | ||||
| //		Two consecutive asterisks ("**") in patterns matched against full pathname | ||||
| //		may have special meaning: | ||||
| // | ||||
| //			- A leading "**" followed by a slash means match in all directories. | ||||
| //			  For example, "**/foo" matches file or directory "foo" anywhere, the same as | ||||
| //			  pattern "foo". "**/foo/bar" matches file or directory "bar" | ||||
| //			  anywhere that is directly under directory "foo". | ||||
| //		- A leading "**" followed by a slash means match in all directories. | ||||
| //		  For example, "**/foo" matches file or directory "foo" anywhere, the same as | ||||
| //		  pattern "foo". "**/foo/bar" matches file or directory "bar" | ||||
| //		  anywhere that is directly under directory "foo". | ||||
| // | ||||
| //			- A trailing "/**" matches everything inside. For example, "abc/**" matches | ||||
| //			  all files inside directory "abc", relative to the location of the | ||||
| //			  .gitignore file, with infinite depth. | ||||
| //		- A trailing "/**" matches everything inside. For example, "abc/**" matches | ||||
| //		  all files inside directory "abc", relative to the location of the | ||||
| //		  .gitignore file, with infinite depth. | ||||
| // | ||||
| //			- A slash followed by two consecutive asterisks then a slash matches | ||||
| //			  zero or more directories. For example, "a/**/b" matches "a/b", "a/x/b", | ||||
| //			  "a/x/y/b" and so on. | ||||
| //		- A slash followed by two consecutive asterisks then a slash matches | ||||
| //		  zero or more directories. For example, "a/**/b" matches "a/b", "a/x/b", | ||||
| //		  "a/x/y/b" and so on. | ||||
| // | ||||
| //			- Other consecutive asterisks are considered invalid. | ||||
| //		- Other consecutive asterisks are considered invalid. | ||||
| // | ||||
| //	  Copyright and license | ||||
| //	  ===================== | ||||
| //   Copyright and license | ||||
| //   ===================== | ||||
| // | ||||
| //			Copyright (c) Oleg Sklyar, Silvertern and source{d} | ||||
| //		Copyright (c) Oleg Sklyar, Silvertern and source{d} | ||||
| // | ||||
| //			The package code was donated to source{d} to include, modify and develop | ||||
| //			further as a part of the `go-git` project, release it on the license of | ||||
| //			the whole project or delete it from the project. | ||||
| //		The package code was donated to source{d} to include, modify and develop | ||||
| //		further as a part of the `go-git` project, release it on the license of | ||||
| //		the whole project or delete it from the project. | ||||
| package gitignore | ||||
|  | ||||
							
								
								
									
										200
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/idxfile/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										200
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/idxfile/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,127 +1,127 @@ | ||||
| // Package idxfile implements encoding and decoding of packfile idx files. | ||||
| // | ||||
| //	== Original (version 1) pack-*.idx files have the following format: | ||||
| //  == Original (version 1) pack-*.idx files have the following format: | ||||
| // | ||||
| //	  - The header consists of 256 4-byte network byte order | ||||
| //	    integers.  N-th entry of this table records the number of | ||||
| //	    objects in the corresponding pack, the first byte of whose | ||||
| //	    object name is less than or equal to N.  This is called the | ||||
| //	    'first-level fan-out' table. | ||||
| //    - The header consists of 256 4-byte network byte order | ||||
| //      integers.  N-th entry of this table records the number of | ||||
| //      objects in the corresponding pack, the first byte of whose | ||||
| //      object name is less than or equal to N.  This is called the | ||||
| //      'first-level fan-out' table. | ||||
| // | ||||
| //	  - The header is followed by sorted 24-byte entries, one entry | ||||
| //	    per object in the pack.  Each entry is: | ||||
| //    - The header is followed by sorted 24-byte entries, one entry | ||||
| //      per object in the pack.  Each entry is: | ||||
| // | ||||
| //	   4-byte network byte order integer, recording where the | ||||
| //	   object is stored in the packfile as the offset from the | ||||
| //	   beginning. | ||||
| //     4-byte network byte order integer, recording where the | ||||
| //     object is stored in the packfile as the offset from the | ||||
| //     beginning. | ||||
| // | ||||
| //	   20-byte object name. | ||||
| //     20-byte object name. | ||||
| // | ||||
| //	 - The file is concluded with a trailer: | ||||
| //   - The file is concluded with a trailer: | ||||
| // | ||||
| //	   A copy of the 20-byte SHA1 checksum at the end of | ||||
| //	   corresponding packfile. | ||||
| //     A copy of the 20-byte SHA1 checksum at the end of | ||||
| //     corresponding packfile. | ||||
| // | ||||
| //	   20-byte SHA1-checksum of all of the above. | ||||
| //     20-byte SHA1-checksum of all of the above. | ||||
| // | ||||
| //	 Pack Idx file: | ||||
| //   Pack Idx file: | ||||
| // | ||||
| //	      --  +--------------------------------+ | ||||
| //	 fanout   | fanout[0] = 2 (for example)    |-. | ||||
| //	 table    +--------------------------------+ | | ||||
| //	          | fanout[1]                      | | | ||||
| //	          +--------------------------------+ | | ||||
| //	          | fanout[2]                      | | | ||||
| //	          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | | ||||
| //	          | fanout[255] = total objects    |---. | ||||
| //	      --  +--------------------------------+ | | | ||||
| //	 main     | offset                         | | | | ||||
| //	 index    | object name 00XXXXXXXXXXXXXXXX | | | | ||||
| //	 tab      +--------------------------------+ | | | ||||
| //	          | offset                         | | | | ||||
| //	          | object name 00XXXXXXXXXXXXXXXX | | | | ||||
| //	          +--------------------------------+<+ | | ||||
| //	        .-| offset                         |   | | ||||
| //	        | | object name 01XXXXXXXXXXXXXXXX |   | | ||||
| //	        | +--------------------------------+   | | ||||
| //	        | | offset                         |   | | ||||
| //	        | | object name 01XXXXXXXXXXXXXXXX |   | | ||||
| //	        | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   | | ||||
| //	        | | offset                         |   | | ||||
| //	        | | object name FFXXXXXXXXXXXXXXXX |   | | ||||
| //	      --| +--------------------------------+<--+ | ||||
| //	trailer | | packfile checksum              | | ||||
| //	        | +--------------------------------+ | ||||
| //	        | | idxfile checksum               | | ||||
| //	        | +--------------------------------+ | ||||
| //	        .---------. | ||||
| //	                  | | ||||
| //	Pack file entry: <+ | ||||
| //        --  +--------------------------------+ | ||||
| //   fanout   | fanout[0] = 2 (for example)    |-. | ||||
| //   table    +--------------------------------+ | | ||||
| //            | fanout[1]                      | | | ||||
| //            +--------------------------------+ | | ||||
| //            | fanout[2]                      | | | ||||
| //            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | | ||||
| //            | fanout[255] = total objects    |---. | ||||
| //        --  +--------------------------------+ | | | ||||
| //   main     | offset                         | | | | ||||
| //   index    | object name 00XXXXXXXXXXXXXXXX | | | | ||||
| //   tab      +--------------------------------+ | | | ||||
| //            | offset                         | | | | ||||
| //            | object name 00XXXXXXXXXXXXXXXX | | | | ||||
| //            +--------------------------------+<+ | | ||||
| //          .-| offset                         |   | | ||||
| //          | | object name 01XXXXXXXXXXXXXXXX |   | | ||||
| //          | +--------------------------------+   | | ||||
| //          | | offset                         |   | | ||||
| //          | | object name 01XXXXXXXXXXXXXXXX |   | | ||||
| //          | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   | | ||||
| //          | | offset                         |   | | ||||
| //          | | object name FFXXXXXXXXXXXXXXXX |   | | ||||
| //        --| +--------------------------------+<--+ | ||||
| //  trailer | | packfile checksum              | | ||||
| //          | +--------------------------------+ | ||||
| //          | | idxfile checksum               | | ||||
| //          | +--------------------------------+ | ||||
| //          .---------. | ||||
| //                    | | ||||
| //  Pack file entry: <+ | ||||
| // | ||||
| //	   packed object header: | ||||
| //	   1-byte size extension bit (MSB) | ||||
| //	         type (next 3 bit) | ||||
| //	         size0 (lower 4-bit) | ||||
| //	       n-byte sizeN (as long as MSB is set, each 7-bit) | ||||
| //	       size0..sizeN form 4+7+7+..+7 bit integer, size0 | ||||
| //	       is the least significant part, and sizeN is the | ||||
| //	       most significant part. | ||||
| //	   packed object data: | ||||
| //	       If it is not DELTA, then deflated bytes (the size above | ||||
| //	       is the size before compression). | ||||
| //	   If it is REF_DELTA, then | ||||
| //	     20-byte base object name SHA1 (the size above is the | ||||
| //	       size of the delta data that follows). | ||||
| //	         delta data, deflated. | ||||
| //	   If it is OFS_DELTA, then | ||||
| //	     n-byte offset (see below) interpreted as a negative | ||||
| //	       offset from the type-byte of the header of the | ||||
| //	       ofs-delta entry (the size above is the size of | ||||
| //	       the delta data that follows). | ||||
| //	     delta data, deflated. | ||||
| //     packed object header: | ||||
| //     1-byte size extension bit (MSB) | ||||
| //           type (next 3 bit) | ||||
| //           size0 (lower 4-bit) | ||||
| //         n-byte sizeN (as long as MSB is set, each 7-bit) | ||||
| //         size0..sizeN form 4+7+7+..+7 bit integer, size0 | ||||
| //         is the least significant part, and sizeN is the | ||||
| //         most significant part. | ||||
| //     packed object data: | ||||
| //         If it is not DELTA, then deflated bytes (the size above | ||||
| //         is the size before compression). | ||||
| //     If it is REF_DELTA, then | ||||
| //       20-byte base object name SHA1 (the size above is the | ||||
| //         size of the delta data that follows). | ||||
| //           delta data, deflated. | ||||
| //     If it is OFS_DELTA, then | ||||
| //       n-byte offset (see below) interpreted as a negative | ||||
| //         offset from the type-byte of the header of the | ||||
| //         ofs-delta entry (the size above is the size of | ||||
| //         the delta data that follows). | ||||
| //       delta data, deflated. | ||||
| // | ||||
| //	   offset encoding: | ||||
| //	     n bytes with MSB set in all but the last one. | ||||
| //	     The offset is then the number constructed by | ||||
| //	     concatenating the lower 7 bit of each byte, and | ||||
| //	     for n >= 2 adding 2^7 + 2^14 + ... + 2^(7*(n-1)) | ||||
| //	     to the result. | ||||
| //     offset encoding: | ||||
| //       n bytes with MSB set in all but the last one. | ||||
| //       The offset is then the number constructed by | ||||
| //       concatenating the lower 7 bit of each byte, and | ||||
| //       for n >= 2 adding 2^7 + 2^14 + ... + 2^(7*(n-1)) | ||||
| //       to the result. | ||||
| // | ||||
| //	 == Version 2 pack-*.idx files support packs larger than 4 GiB, and | ||||
| //	    have some other reorganizations.  They have the format: | ||||
| //   == Version 2 pack-*.idx files support packs larger than 4 GiB, and | ||||
| //      have some other reorganizations.  They have the format: | ||||
| // | ||||
| //	   - A 4-byte magic number '\377tOc' which is an unreasonable | ||||
| //	     fanout[0] value. | ||||
| //     - A 4-byte magic number '\377tOc' which is an unreasonable | ||||
| //       fanout[0] value. | ||||
| // | ||||
| //	   - A 4-byte version number (= 2) | ||||
| //     - A 4-byte version number (= 2) | ||||
| // | ||||
| //	   - A 256-entry fan-out table just like v1. | ||||
| //     - A 256-entry fan-out table just like v1. | ||||
| // | ||||
| //	   - A table of sorted 20-byte SHA1 object names.  These are | ||||
| //	     packed together without offset values to reduce the cache | ||||
| //	     footprint of the binary search for a specific object name. | ||||
| //     - A table of sorted 20-byte SHA1 object names.  These are | ||||
| //       packed together without offset values to reduce the cache | ||||
| //       footprint of the binary search for a specific object name. | ||||
| // | ||||
| //	   - A table of 4-byte CRC32 values of the packed object data. | ||||
| //	     This is new in v2 so compressed data can be copied directly | ||||
| //	     from pack to pack during repacking without undetected | ||||
| //	     data corruption. | ||||
| //     - A table of 4-byte CRC32 values of the packed object data. | ||||
| //       This is new in v2 so compressed data can be copied directly | ||||
| //       from pack to pack during repacking without undetected | ||||
| //       data corruption. | ||||
| // | ||||
| //	   - A table of 4-byte offset values (in network byte order). | ||||
| //	     These are usually 31-bit pack file offsets, but large | ||||
| //	     offsets are encoded as an index into the next table with | ||||
| //	     the msbit set. | ||||
| //     - A table of 4-byte offset values (in network byte order). | ||||
| //       These are usually 31-bit pack file offsets, but large | ||||
| //       offsets are encoded as an index into the next table with | ||||
| //       the msbit set. | ||||
| // | ||||
| //	   - A table of 8-byte offset entries (empty for pack files less | ||||
| //	     than 2 GiB).  Pack files are organized with heavily used | ||||
| //	     objects toward the front, so most object references should | ||||
| //	     not need to refer to this table. | ||||
| //     - A table of 8-byte offset entries (empty for pack files less | ||||
| //       than 2 GiB).  Pack files are organized with heavily used | ||||
| //       objects toward the front, so most object references should | ||||
| //       not need to refer to this table. | ||||
| // | ||||
| //	   - The same trailer as a v1 pack file: | ||||
| //     - The same trailer as a v1 pack file: | ||||
| // | ||||
| //	     A copy of the 20-byte SHA1 checksum at the end of | ||||
| //	     corresponding packfile. | ||||
| //       A copy of the 20-byte SHA1 checksum at the end of | ||||
| //       corresponding packfile. | ||||
| // | ||||
| //	     20-byte SHA1-checksum of all of the above. | ||||
| //       20-byte SHA1-checksum of all of the above. | ||||
| // | ||||
| // Source: | ||||
| // https://www.kernel.org/pub/software/scm/git/docs/v1.7.5/technical/pack-format.txt | ||||
|  | ||||
							
								
								
									
										474
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/index/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										474
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/index/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,360 +1,360 @@ | ||||
| // Package index implements encoding and decoding of index format files. | ||||
| // | ||||
| //	  Git index format | ||||
| //	  ================ | ||||
| //    Git index format | ||||
| //    ================ | ||||
| // | ||||
| //	  == The Git index file has the following format | ||||
| //    == The Git index file has the following format | ||||
| // | ||||
| //	    All binary numbers are in network byte order. Version 2 is described | ||||
| //	    here unless stated otherwise. | ||||
| //      All binary numbers are in network byte order. Version 2 is described | ||||
| //      here unless stated otherwise. | ||||
| // | ||||
| //	    - A 12-byte header consisting of | ||||
| //      - A 12-byte header consisting of | ||||
| // | ||||
| //	      4-byte signature: | ||||
| //	        The signature is { 'D', 'I', 'R', 'C' } (stands for "dircache") | ||||
| //        4-byte signature: | ||||
| //          The signature is { 'D', 'I', 'R', 'C' } (stands for "dircache") | ||||
| // | ||||
| //	      4-byte version number: | ||||
| //	        The current supported versions are 2, 3 and 4. | ||||
| //        4-byte version number: | ||||
| //          The current supported versions are 2, 3 and 4. | ||||
| // | ||||
| //	      32-bit number of index entries. | ||||
| //        32-bit number of index entries. | ||||
| // | ||||
| //	    - A number of sorted index entries (see below). | ||||
| //      - A number of sorted index entries (see below). | ||||
| // | ||||
| //	    - Extensions | ||||
| //      - Extensions | ||||
| // | ||||
| //	      Extensions are identified by signature. Optional extensions can | ||||
| //	      be ignored if Git does not understand them. | ||||
| //        Extensions are identified by signature. Optional extensions can | ||||
| //        be ignored if Git does not understand them. | ||||
| // | ||||
| //	      Git currently supports cached tree and resolve undo extensions. | ||||
| //        Git currently supports cached tree and resolve undo extensions. | ||||
| // | ||||
| //	      4-byte extension signature. If the first byte is 'A'..'Z' the | ||||
| //	      extension is optional and can be ignored. | ||||
| //        4-byte extension signature. If the first byte is 'A'..'Z' the | ||||
| //        extension is optional and can be ignored. | ||||
| // | ||||
| //	      32-bit size of the extension | ||||
| //        32-bit size of the extension | ||||
| // | ||||
| //	      Extension data | ||||
| //        Extension data | ||||
| // | ||||
| //	    - 160-bit SHA-1 over the content of the index file before this | ||||
| //	      checksum. | ||||
| //      - 160-bit SHA-1 over the content of the index file before this | ||||
| //        checksum. | ||||
| // | ||||
| //	  == Index entry | ||||
| //    == Index entry | ||||
| // | ||||
| //	    Index entries are sorted in ascending order on the name field, | ||||
| //	    interpreted as a string of unsigned bytes (i.e. memcmp() order, no | ||||
| //	    localization, no special casing of directory separator '/'). Entries | ||||
| //	    with the same name are sorted by their stage field. | ||||
| //      Index entries are sorted in ascending order on the name field, | ||||
| //      interpreted as a string of unsigned bytes (i.e. memcmp() order, no | ||||
| //      localization, no special casing of directory separator '/'). Entries | ||||
| //      with the same name are sorted by their stage field. | ||||
| // | ||||
| //	    32-bit ctime seconds, the last time a file's metadata changed | ||||
| //	      this is stat(2) data | ||||
| //      32-bit ctime seconds, the last time a file's metadata changed | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit ctime nanosecond fractions | ||||
| //	      this is stat(2) data | ||||
| //      32-bit ctime nanosecond fractions | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit mtime seconds, the last time a file's data changed | ||||
| //	      this is stat(2) data | ||||
| //      32-bit mtime seconds, the last time a file's data changed | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit mtime nanosecond fractions | ||||
| //	      this is stat(2) data | ||||
| //      32-bit mtime nanosecond fractions | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit dev | ||||
| //	      this is stat(2) data | ||||
| //      32-bit dev | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit ino | ||||
| //	      this is stat(2) data | ||||
| //      32-bit ino | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit mode, split into (high to low bits) | ||||
| //      32-bit mode, split into (high to low bits) | ||||
| // | ||||
| //	      4-bit object type | ||||
| //	        valid values in binary are 1000 (regular file), 1010 (symbolic link) | ||||
| //	        and 1110 (gitlink) | ||||
| //        4-bit object type | ||||
| //          valid values in binary are 1000 (regular file), 1010 (symbolic link) | ||||
| //          and 1110 (gitlink) | ||||
| // | ||||
| //	      3-bit unused | ||||
| //        3-bit unused | ||||
| // | ||||
| //	      9-bit unix permission. Only 0755 and 0644 are valid for regular files. | ||||
| //	      Symbolic links and gitlinks have value 0 in this field. | ||||
| //        9-bit unix permission. Only 0755 and 0644 are valid for regular files. | ||||
| //        Symbolic links and gitlinks have value 0 in this field. | ||||
| // | ||||
| //	    32-bit uid | ||||
| //	      this is stat(2) data | ||||
| //      32-bit uid | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit gid | ||||
| //	      this is stat(2) data | ||||
| //      32-bit gid | ||||
| //        this is stat(2) data | ||||
| // | ||||
| //	    32-bit file size | ||||
| //	      This is the on-disk size from stat(2), truncated to 32-bit. | ||||
| //      32-bit file size | ||||
| //        This is the on-disk size from stat(2), truncated to 32-bit. | ||||
| // | ||||
| //	    160-bit SHA-1 for the represented object | ||||
| //      160-bit SHA-1 for the represented object | ||||
| // | ||||
| //	    A 16-bit 'flags' field split into (high to low bits) | ||||
| //      A 16-bit 'flags' field split into (high to low bits) | ||||
| // | ||||
| //	      1-bit assume-valid flag | ||||
| //        1-bit assume-valid flag | ||||
| // | ||||
| //	      1-bit extended flag (must be zero in version 2) | ||||
| //        1-bit extended flag (must be zero in version 2) | ||||
| // | ||||
| //	      2-bit stage (during merge) | ||||
| //        2-bit stage (during merge) | ||||
| // | ||||
| //	      12-bit name length if the length is less than 0xFFF; otherwise 0xFFF | ||||
| //	      is stored in this field. | ||||
| //        12-bit name length if the length is less than 0xFFF; otherwise 0xFFF | ||||
| //        is stored in this field. | ||||
| // | ||||
| //	    (Version 3 or later) A 16-bit field, only applicable if the | ||||
| //	    "extended flag" above is 1, split into (high to low bits). | ||||
| //      (Version 3 or later) A 16-bit field, only applicable if the | ||||
| //      "extended flag" above is 1, split into (high to low bits). | ||||
| // | ||||
| //	      1-bit reserved for future | ||||
| //        1-bit reserved for future | ||||
| // | ||||
| //	      1-bit skip-worktree flag (used by sparse checkout) | ||||
| //        1-bit skip-worktree flag (used by sparse checkout) | ||||
| // | ||||
| //	      1-bit intent-to-add flag (used by "git add -N") | ||||
| //        1-bit intent-to-add flag (used by "git add -N") | ||||
| // | ||||
| //	      13-bit unused, must be zero | ||||
| //        13-bit unused, must be zero | ||||
| // | ||||
| //	    Entry path name (variable length) relative to top level directory | ||||
| //	      (without leading slash). '/' is used as path separator. The special | ||||
| //	      path components ".", ".." and ".git" (without quotes) are disallowed. | ||||
| //	      Trailing slash is also disallowed. | ||||
| //      Entry path name (variable length) relative to top level directory | ||||
| //        (without leading slash). '/' is used as path separator. The special | ||||
| //        path components ".", ".." and ".git" (without quotes) are disallowed. | ||||
| //        Trailing slash is also disallowed. | ||||
| // | ||||
| //	      The exact encoding is undefined, but the '.' and '/' characters | ||||
| //	      are encoded in 7-bit ASCII and the encoding cannot contain a NUL | ||||
| //	      byte (iow, this is a UNIX pathname). | ||||
| //        The exact encoding is undefined, but the '.' and '/' characters | ||||
| //        are encoded in 7-bit ASCII and the encoding cannot contain a NUL | ||||
| //        byte (iow, this is a UNIX pathname). | ||||
| // | ||||
| //	    (Version 4) In version 4, the entry path name is prefix-compressed | ||||
| //	      relative to the path name for the previous entry (the very first | ||||
| //	      entry is encoded as if the path name for the previous entry is an | ||||
| //	      empty string).  At the beginning of an entry, an integer N in the | ||||
| //	      variable width encoding (the same encoding as the offset is encoded | ||||
| //	      for OFS_DELTA pack entries; see pack-format.txt) is stored, followed | ||||
| //	      by a NUL-terminated string S.  Removing N bytes from the end of the | ||||
| //	      path name for the previous entry, and replacing it with the string S | ||||
| //	      yields the path name for this entry. | ||||
| //      (Version 4) In version 4, the entry path name is prefix-compressed | ||||
| //        relative to the path name for the previous entry (the very first | ||||
| //        entry is encoded as if the path name for the previous entry is an | ||||
| //        empty string).  At the beginning of an entry, an integer N in the | ||||
| //        variable width encoding (the same encoding as the offset is encoded | ||||
| //        for OFS_DELTA pack entries; see pack-format.txt) is stored, followed | ||||
| //        by a NUL-terminated string S.  Removing N bytes from the end of the | ||||
| //        path name for the previous entry, and replacing it with the string S | ||||
| //        yields the path name for this entry. | ||||
| // | ||||
| //	    1-8 nul bytes as necessary to pad the entry to a multiple of eight bytes | ||||
| //	    while keeping the name NUL-terminated. | ||||
| //      1-8 nul bytes as necessary to pad the entry to a multiple of eight bytes | ||||
| //      while keeping the name NUL-terminated. | ||||
| // | ||||
| //	    (Version 4) In version 4, the padding after the pathname does not | ||||
| //	    exist. | ||||
| //      (Version 4) In version 4, the padding after the pathname does not | ||||
| //      exist. | ||||
| // | ||||
| //	    Interpretation of index entries in split index mode is completely | ||||
| //	    different. See below for details. | ||||
| //      Interpretation of index entries in split index mode is completely | ||||
| //      different. See below for details. | ||||
| // | ||||
| //	  == Extensions | ||||
| //    == Extensions | ||||
| // | ||||
| //	  === Cached tree | ||||
| //    === Cached tree | ||||
| // | ||||
| //	    Cached tree extension contains pre-computed hashes for trees that can | ||||
| //	    be derived from the index. It helps speed up tree object generation | ||||
| //	    from index for a new commit. | ||||
| //      Cached tree extension contains pre-computed hashes for trees that can | ||||
| //      be derived from the index. It helps speed up tree object generation | ||||
| //      from index for a new commit. | ||||
| // | ||||
| //	    When a path is updated in index, the path must be invalidated and | ||||
| //	    removed from tree cache. | ||||
| //      When a path is updated in index, the path must be invalidated and | ||||
| //      removed from tree cache. | ||||
| // | ||||
| //	    The signature for this extension is { 'T', 'R', 'E', 'E' }. | ||||
| //      The signature for this extension is { 'T', 'R', 'E', 'E' }. | ||||
| // | ||||
| //	    A series of entries fill the entire extension; each of which | ||||
| //	    consists of: | ||||
| //      A series of entries fill the entire extension; each of which | ||||
| //      consists of: | ||||
| // | ||||
| //	    - NUL-terminated path component (relative to its parent directory); | ||||
| //      - NUL-terminated path component (relative to its parent directory); | ||||
| // | ||||
| //	    - ASCII decimal number of entries in the index that is covered by the | ||||
| //	      tree this entry represents (entry_count); | ||||
| //      - ASCII decimal number of entries in the index that is covered by the | ||||
| //        tree this entry represents (entry_count); | ||||
| // | ||||
| //	    - A space (ASCII 32); | ||||
| //      - A space (ASCII 32); | ||||
| // | ||||
| //	    - ASCII decimal number that represents the number of subtrees this | ||||
| //	      tree has; | ||||
| //      - ASCII decimal number that represents the number of subtrees this | ||||
| //        tree has; | ||||
| // | ||||
| //	    - A newline (ASCII 10); and | ||||
| //      - A newline (ASCII 10); and | ||||
| // | ||||
| //	    - 160-bit object name for the object that would result from writing | ||||
| //	      this span of index as a tree. | ||||
| //      - 160-bit object name for the object that would result from writing | ||||
| //        this span of index as a tree. | ||||
| // | ||||
| //	    An entry can be in an invalidated state and is represented by having | ||||
| //	    a negative number in the entry_count field. In this case, there is no | ||||
| //	    object name and the next entry starts immediately after the newline. | ||||
| //	    When writing an invalid entry, -1 should always be used as entry_count. | ||||
| //      An entry can be in an invalidated state and is represented by having | ||||
| //      a negative number in the entry_count field. In this case, there is no | ||||
| //      object name and the next entry starts immediately after the newline. | ||||
| //      When writing an invalid entry, -1 should always be used as entry_count. | ||||
| // | ||||
| //	    The entries are written out in the top-down, depth-first order.  The | ||||
| //	    first entry represents the root level of the repository, followed by the | ||||
| //	    first subtree--let's call this A--of the root level (with its name | ||||
| //	    relative to the root level), followed by the first subtree of A (with | ||||
| //	    its name relative to A), ... | ||||
| //      The entries are written out in the top-down, depth-first order.  The | ||||
| //      first entry represents the root level of the repository, followed by the | ||||
| //      first subtree--let's call this A--of the root level (with its name | ||||
| //      relative to the root level), followed by the first subtree of A (with | ||||
| //      its name relative to A), ... | ||||
| // | ||||
| //	  === Resolve undo | ||||
| //    === Resolve undo | ||||
| // | ||||
| //	    A conflict is represented in the index as a set of higher stage entries. | ||||
| //	    When a conflict is resolved (e.g. with "git add path"), these higher | ||||
| //	    stage entries will be removed and a stage-0 entry with proper resolution | ||||
| //	    is added. | ||||
| //      A conflict is represented in the index as a set of higher stage entries. | ||||
| //      When a conflict is resolved (e.g. with "git add path"), these higher | ||||
| //      stage entries will be removed and a stage-0 entry with proper resolution | ||||
| //      is added. | ||||
| // | ||||
| //	    When these higher stage entries are removed, they are saved in the | ||||
| //	    resolve undo extension, so that conflicts can be recreated (e.g. with | ||||
| //	    "git checkout -m"), in case users want to redo a conflict resolution | ||||
| //	    from scratch. | ||||
| //      When these higher stage entries are removed, they are saved in the | ||||
| //      resolve undo extension, so that conflicts can be recreated (e.g. with | ||||
| //      "git checkout -m"), in case users want to redo a conflict resolution | ||||
| //      from scratch. | ||||
| // | ||||
| //	    The signature for this extension is { 'R', 'E', 'U', 'C' }. | ||||
| //      The signature for this extension is { 'R', 'E', 'U', 'C' }. | ||||
| // | ||||
| //	    A series of entries fill the entire extension; each of which | ||||
| //	    consists of: | ||||
| //      A series of entries fill the entire extension; each of which | ||||
| //      consists of: | ||||
| // | ||||
| //	    - NUL-terminated pathname the entry describes (relative to the root of | ||||
| //	      the repository, i.e. full pathname); | ||||
| //      - NUL-terminated pathname the entry describes (relative to the root of | ||||
| //        the repository, i.e. full pathname); | ||||
| // | ||||
| //	    - Three NUL-terminated ASCII octal numbers, entry mode of entries in | ||||
| //	      stage 1 to 3 (a missing stage is represented by "0" in this field); | ||||
| //	      and | ||||
| //      - Three NUL-terminated ASCII octal numbers, entry mode of entries in | ||||
| //        stage 1 to 3 (a missing stage is represented by "0" in this field); | ||||
| //        and | ||||
| // | ||||
| //	    - At most three 160-bit object names of the entry in stages from 1 to 3 | ||||
| //	      (nothing is written for a missing stage). | ||||
| //      - At most three 160-bit object names of the entry in stages from 1 to 3 | ||||
| //        (nothing is written for a missing stage). | ||||
| // | ||||
| //	  === Split index | ||||
| //    === Split index | ||||
| // | ||||
| //	    In split index mode, the majority of index entries could be stored | ||||
| //	    in a separate file. This extension records the changes to be made on | ||||
| //	    top of that to produce the final index. | ||||
| //      In split index mode, the majority of index entries could be stored | ||||
| //      in a separate file. This extension records the changes to be made on | ||||
| //      top of that to produce the final index. | ||||
| // | ||||
| //	    The signature for this extension is { 'l', 'i', 'n', 'k' }. | ||||
| //      The signature for this extension is { 'l', 'i', 'n', 'k' }. | ||||
| // | ||||
| //	    The extension consists of: | ||||
| //      The extension consists of: | ||||
| // | ||||
| //	    - 160-bit SHA-1 of the shared index file. The shared index file path | ||||
| //	      is $GIT_DIR/sharedindex.<SHA-1>. If all 160 bits are zero, the | ||||
| //	      index does not require a shared index file. | ||||
| //      - 160-bit SHA-1 of the shared index file. The shared index file path | ||||
| //        is $GIT_DIR/sharedindex.<SHA-1>. If all 160 bits are zero, the | ||||
| //        index does not require a shared index file. | ||||
| // | ||||
| //	    - An ewah-encoded delete bitmap, each bit represents an entry in the | ||||
| //	      shared index. If a bit is set, its corresponding entry in the | ||||
| //	      shared index will be removed from the final index.  Note, because | ||||
| //	      a delete operation changes index entry positions, but we do need | ||||
| //	      original positions in replace phase, it's best to just mark | ||||
| //	      entries for removal, then do a mass deletion after replacement. | ||||
| //      - An ewah-encoded delete bitmap, each bit represents an entry in the | ||||
| //        shared index. If a bit is set, its corresponding entry in the | ||||
| //        shared index will be removed from the final index.  Note, because | ||||
| //        a delete operation changes index entry positions, but we do need | ||||
| //        original positions in replace phase, it's best to just mark | ||||
| //        entries for removal, then do a mass deletion after replacement. | ||||
| // | ||||
| //	    - An ewah-encoded replace bitmap, each bit represents an entry in | ||||
| //	      the shared index. If a bit is set, its corresponding entry in the | ||||
| //	      shared index will be replaced with an entry in this index | ||||
| //	      file. All replaced entries are stored in sorted order in this | ||||
| //	      index. The first "1" bit in the replace bitmap corresponds to the | ||||
| //	      first index entry, the second "1" bit to the second entry and so | ||||
| //	      on. Replaced entries may have empty path names to save space. | ||||
| //      - An ewah-encoded replace bitmap, each bit represents an entry in | ||||
| //        the shared index. If a bit is set, its corresponding entry in the | ||||
| //        shared index will be replaced with an entry in this index | ||||
| //        file. All replaced entries are stored in sorted order in this | ||||
| //        index. The first "1" bit in the replace bitmap corresponds to the | ||||
| //        first index entry, the second "1" bit to the second entry and so | ||||
| //        on. Replaced entries may have empty path names to save space. | ||||
| // | ||||
| //	    The remaining index entries after replaced ones will be added to the | ||||
| //	    final index. These added entries are also sorted by entry name then | ||||
| //	    stage. | ||||
| //      The remaining index entries after replaced ones will be added to the | ||||
| //      final index. These added entries are also sorted by entry name then | ||||
| //      stage. | ||||
| // | ||||
| //	  == Untracked cache | ||||
| //    == Untracked cache | ||||
| // | ||||
| //	    Untracked cache saves the untracked file list and necessary data to | ||||
| //	    verify the cache. The signature for this extension is { 'U', 'N', | ||||
| //	    'T', 'R' }. | ||||
| //      Untracked cache saves the untracked file list and necessary data to | ||||
| //      verify the cache. The signature for this extension is { 'U', 'N', | ||||
| //      'T', 'R' }. | ||||
| // | ||||
| //	    The extension starts with | ||||
| //      The extension starts with | ||||
| // | ||||
| //	    - A sequence of NUL-terminated strings, preceded by the size of the | ||||
| //	      sequence in variable width encoding. Each string describes the | ||||
| //	      environment where the cache can be used. | ||||
| //      - A sequence of NUL-terminated strings, preceded by the size of the | ||||
| //        sequence in variable width encoding. Each string describes the | ||||
| //        environment where the cache can be used. | ||||
| // | ||||
| //	    - Stat data of $GIT_DIR/info/exclude. See "Index entry" section from | ||||
| //	      ctime field until "file size". | ||||
| //      - Stat data of $GIT_DIR/info/exclude. See "Index entry" section from | ||||
| //        ctime field until "file size". | ||||
| // | ||||
| //	    - Stat data of plumbing.excludesfile | ||||
| //      - Stat data of plumbing.excludesfile | ||||
| // | ||||
| //	    - 32-bit dir_flags (see struct dir_struct) | ||||
| //      - 32-bit dir_flags (see struct dir_struct) | ||||
| // | ||||
| //	    - 160-bit SHA-1 of $GIT_DIR/info/exclude. Null SHA-1 means the file | ||||
| //	      does not exist. | ||||
| //      - 160-bit SHA-1 of $GIT_DIR/info/exclude. Null SHA-1 means the file | ||||
| //        does not exist. | ||||
| // | ||||
| //	    - 160-bit SHA-1 of plumbing.excludesfile. Null SHA-1 means the file does | ||||
| //	      not exist. | ||||
| //      - 160-bit SHA-1 of plumbing.excludesfile. Null SHA-1 means the file does | ||||
| //        not exist. | ||||
| // | ||||
| //	    - NUL-terminated string of per-dir exclude file name. This usually | ||||
| //	      is ".gitignore". | ||||
| //      - NUL-terminated string of per-dir exclude file name. This usually | ||||
| //        is ".gitignore". | ||||
| // | ||||
| //	    - The number of following directory blocks, variable width | ||||
| //	      encoding. If this number is zero, the extension ends here with a | ||||
| //	      following NUL. | ||||
| //      - The number of following directory blocks, variable width | ||||
| //        encoding. If this number is zero, the extension ends here with a | ||||
| //        following NUL. | ||||
| // | ||||
| //	    - A number of directory blocks in depth-first-search order, each | ||||
| //	      consists of | ||||
| //      - A number of directory blocks in depth-first-search order, each | ||||
| //        consists of | ||||
| // | ||||
| //	      - The number of untracked entries, variable width encoding. | ||||
| //        - The number of untracked entries, variable width encoding. | ||||
| // | ||||
| //	      - The number of sub-directory blocks, variable width encoding. | ||||
| //        - The number of sub-directory blocks, variable width encoding. | ||||
| // | ||||
| //	      - The directory name terminated by NUL. | ||||
| //        - The directory name terminated by NUL. | ||||
| // | ||||
| //	      - A number of untracked file/dir names terminated by NUL. | ||||
| //        - A number of untracked file/dir names terminated by NUL. | ||||
| // | ||||
| //	  The remaining data of each directory block is grouped by type: | ||||
| //    The remaining data of each directory block is grouped by type: | ||||
| // | ||||
| //	    - An ewah bitmap, the n-th bit marks whether the n-th directory has | ||||
| //	      valid untracked cache entries. | ||||
| //      - An ewah bitmap, the n-th bit marks whether the n-th directory has | ||||
| //        valid untracked cache entries. | ||||
| // | ||||
| //	    - An ewah bitmap, the n-th bit records "check-only" bit of | ||||
| //	      read_directory_recursive() for the n-th directory. | ||||
| //      - An ewah bitmap, the n-th bit records "check-only" bit of | ||||
| //        read_directory_recursive() for the n-th directory. | ||||
| // | ||||
| //	    - An ewah bitmap, the n-th bit indicates whether SHA-1 and stat data | ||||
| //	      is valid for the n-th directory and exists in the next data. | ||||
| //      - An ewah bitmap, the n-th bit indicates whether SHA-1 and stat data | ||||
| //        is valid for the n-th directory and exists in the next data. | ||||
| // | ||||
| //	    - An array of stat data. The n-th data corresponds with the n-th | ||||
| //	      "one" bit in the previous ewah bitmap. | ||||
| //      - An array of stat data. The n-th data corresponds with the n-th | ||||
| //        "one" bit in the previous ewah bitmap. | ||||
| // | ||||
| //	    - An array of SHA-1. The n-th SHA-1 corresponds with the n-th "one" bit | ||||
| //	      in the previous ewah bitmap. | ||||
| //      - An array of SHA-1. The n-th SHA-1 corresponds with the n-th "one" bit | ||||
| //        in the previous ewah bitmap. | ||||
| // | ||||
| //	    - One NUL. | ||||
| //      - One NUL. | ||||
| // | ||||
| //	 == File System Monitor cache | ||||
| //   == File System Monitor cache | ||||
| // | ||||
| //	   The file system monitor cache tracks files for which the core.fsmonitor | ||||
| //	   hook has told us about changes.  The signature for this extension is | ||||
| //	   { 'F', 'S', 'M', 'N' }. | ||||
| //     The file system monitor cache tracks files for which the core.fsmonitor | ||||
| //     hook has told us about changes.  The signature for this extension is | ||||
| //     { 'F', 'S', 'M', 'N' }. | ||||
| // | ||||
| //	   The extension starts with | ||||
| //     The extension starts with | ||||
| // | ||||
| //	   - 32-bit version number: the current supported version is 1. | ||||
| //     - 32-bit version number: the current supported version is 1. | ||||
| // | ||||
| //	   - 64-bit time: the extension data reflects all changes through the given | ||||
| //	     time which is stored as the nanoseconds elapsed since midnight, | ||||
| //	     January 1, 1970. | ||||
| //     - 64-bit time: the extension data reflects all changes through the given | ||||
| //       time which is stored as the nanoseconds elapsed since midnight, | ||||
| //       January 1, 1970. | ||||
| // | ||||
| //	  - 32-bit bitmap size: the size of the CE_FSMONITOR_VALID bitmap. | ||||
| //    - 32-bit bitmap size: the size of the CE_FSMONITOR_VALID bitmap. | ||||
| // | ||||
| //	  - An ewah bitmap, the n-th bit indicates whether the n-th index entry | ||||
| //	    is not CE_FSMONITOR_VALID. | ||||
| //    - An ewah bitmap, the n-th bit indicates whether the n-th index entry | ||||
| //      is not CE_FSMONITOR_VALID. | ||||
| // | ||||
| //	== End of Index Entry | ||||
| //  == End of Index Entry | ||||
| // | ||||
| //	  The End of Index Entry (EOIE) is used to locate the end of the variable | ||||
| //	  length index entries and the beginning of the extensions. Code can take | ||||
| //	  advantage of this to quickly locate the index extensions without having | ||||
| //	  to parse through all of the index entries. | ||||
| //    The End of Index Entry (EOIE) is used to locate the end of the variable | ||||
| //    length index entries and the beginning of the extensions. Code can take | ||||
| //    advantage of this to quickly locate the index extensions without having | ||||
| //    to parse through all of the index entries. | ||||
| // | ||||
| //	  Because it must be able to be loaded before the variable length cache | ||||
| //	  entries and other index extensions, this extension must be written last. | ||||
| //	  The signature for this extension is { 'E', 'O', 'I', 'E' }. | ||||
| //    Because it must be able to be loaded before the variable length cache | ||||
| //    entries and other index extensions, this extension must be written last. | ||||
| //    The signature for this extension is { 'E', 'O', 'I', 'E' }. | ||||
| // | ||||
| //	  The extension consists of: | ||||
| //    The extension consists of: | ||||
| // | ||||
| //	  - 32-bit offset to the end of the index entries | ||||
| //    - 32-bit offset to the end of the index entries | ||||
| // | ||||
| //	  - 160-bit SHA-1 over the extension types and their sizes (but not | ||||
| //	    their contents).  E.g. if we have "TREE" extension that is N-bytes | ||||
| //	    long, "REUC" extension that is M-bytes long, followed by "EOIE", | ||||
| //	    then the hash would be: | ||||
| //    - 160-bit SHA-1 over the extension types and their sizes (but not | ||||
| //      their contents).  E.g. if we have "TREE" extension that is N-bytes | ||||
| //      long, "REUC" extension that is M-bytes long, followed by "EOIE", | ||||
| //      then the hash would be: | ||||
| // | ||||
| //	    SHA-1("TREE" + <binary representation of N> + | ||||
| //	      "REUC" + <binary representation of M>) | ||||
| //      SHA-1("TREE" + <binary representation of N> + | ||||
| //        "REUC" + <binary representation of M>) | ||||
| // | ||||
| //	== Index Entry Offset Table | ||||
| //  == Index Entry Offset Table | ||||
| // | ||||
| //	  The Index Entry Offset Table (IEOT) is used to help address the CPU | ||||
| //	  cost of loading the index by enabling multi-threading the process of | ||||
| //	  converting cache entries from the on-disk format to the in-memory format. | ||||
| //	  The signature for this extension is { 'I', 'E', 'O', 'T' }. | ||||
| //    The Index Entry Offset Table (IEOT) is used to help address the CPU | ||||
| //    cost of loading the index by enabling multi-threading the process of | ||||
| //    converting cache entries from the on-disk format to the in-memory format. | ||||
| //    The signature for this extension is { 'I', 'E', 'O', 'T' }. | ||||
| // | ||||
| //	  The extension consists of: | ||||
| //    The extension consists of: | ||||
| // | ||||
| //	  - 32-bit version (currently 1) | ||||
| //    - 32-bit version (currently 1) | ||||
| // | ||||
| //	  - A number of index offset entries each consisting of: | ||||
| //    - A number of index offset entries each consisting of: | ||||
| // | ||||
| //	  - 32-bit offset from the beginning of the file to the first cache entry | ||||
| //	    in this block of entries. | ||||
| //    - 32-bit offset from the beginning of the file to the first cache entry | ||||
| //      in this block of entries. | ||||
| // | ||||
| //	  - 32-bit count of cache entries in this blockpackage index | ||||
| //    - 32-bit count of cache entries in this blockpackage index | ||||
| package index | ||||
|  | ||||
							
								
								
									
										4
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/index/index.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/index/index.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -203,8 +203,8 @@ type ResolveUndoEntry struct { | ||||
| // can take advantage of this to quickly locate the index extensions without | ||||
| // having to parse through all of the index entries. | ||||
| // | ||||
| //	Because it must be able to be loaded before the variable length cache | ||||
| //	entries and other index extensions, this extension must be written last. | ||||
| //  Because it must be able to be loaded before the variable length cache | ||||
| //  entries and other index extensions, this extension must be written last. | ||||
| type EndOfIndexEntry struct { | ||||
| 	// Offset to the end of the index entries | ||||
| 	Offset uint32 | ||||
|  | ||||
							
								
								
									
										45
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/packfile/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/format/packfile/doc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,37 +1,38 @@ | ||||
| // Package packfile implements encoding and decoding of packfile format. | ||||
| // | ||||
| //	== pack-*.pack files have the following format: | ||||
| //  == pack-*.pack files have the following format: | ||||
| // | ||||
| //	  - A header appears at the beginning and consists of the following: | ||||
| //    - A header appears at the beginning and consists of the following: | ||||
| // | ||||
| //	    4-byte signature: | ||||
| //	        The signature is: {'P', 'A', 'C', 'K'} | ||||
| //      4-byte signature: | ||||
| //          The signature is: {'P', 'A', 'C', 'K'} | ||||
| // | ||||
| //	    4-byte version number (network byte order): | ||||
| //	        GIT currently accepts version number 2 or 3 but | ||||
| //	        generates version 2 only. | ||||
| //      4-byte version number (network byte order): | ||||
| //          GIT currently accepts version number 2 or 3 but | ||||
| //          generates version 2 only. | ||||
| // | ||||
| //	    4-byte number of objects contained in the pack (network byte order) | ||||
| //      4-byte number of objects contained in the pack (network byte order) | ||||
| // | ||||
| //	    Observation: we cannot have more than 4G versions ;-) and | ||||
| //	    more than 4G objects in a pack. | ||||
| //      Observation: we cannot have more than 4G versions ;-) and | ||||
| //      more than 4G objects in a pack. | ||||
| // | ||||
| //	  - The header is followed by number of object entries, each of | ||||
| //	    which looks like this: | ||||
| //    - The header is followed by number of object entries, each of | ||||
| //      which looks like this: | ||||
| // | ||||
| //	    (undeltified representation) | ||||
| //	    n-byte type and length (3-bit type, (n-1)*7+4-bit length) | ||||
| //	    compressed data | ||||
| //      (undeltified representation) | ||||
| //      n-byte type and length (3-bit type, (n-1)*7+4-bit length) | ||||
| //      compressed data | ||||
| // | ||||
| //	    (deltified representation) | ||||
| //	    n-byte type and length (3-bit type, (n-1)*7+4-bit length) | ||||
| //	    20-byte base object name | ||||
| //	    compressed delta data | ||||
| //      (deltified representation) | ||||
| //      n-byte type and length (3-bit type, (n-1)*7+4-bit length) | ||||
| //      20-byte base object name | ||||
| //      compressed delta data | ||||
| // | ||||
| //	    Observation: length of each object is encoded in a variable | ||||
| //	    length format and is not constrained to 32-bit or anything. | ||||
| //      Observation: length of each object is encoded in a variable | ||||
| //      length format and is not constrained to 32-bit or anything. | ||||
| // | ||||
| //   - The trailer records 20-byte SHA1 checksum of all of the above. | ||||
| // | ||||
| //	 - The trailer records 20-byte SHA1 checksum of all of the above. | ||||
| // | ||||
| // Source: | ||||
| // https://www.kernel.org/pub/software/scm/git/docs/v1.7.5/technical/pack-protocol.txt | ||||
|  | ||||
							
								
								
									
										24
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/object/object.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/object/object.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -24,18 +24,18 @@ var ErrUnsupportedObject = errors.New("unsupported object type") | ||||
| // Object is returned when an object can be of any type. It is frequently used | ||||
| // with a type cast to acquire the specific type of object: | ||||
| // | ||||
| //	func process(obj Object) { | ||||
| //		switch o := obj.(type) { | ||||
| //		case *Commit: | ||||
| //			// o is a Commit | ||||
| //		case *Tree: | ||||
| //			// o is a Tree | ||||
| //		case *Blob: | ||||
| //			// o is a Blob | ||||
| //		case *Tag: | ||||
| //			// o is a Tag | ||||
| //		} | ||||
| //	} | ||||
| //   func process(obj Object) { | ||||
| //   	switch o := obj.(type) { | ||||
| //   	case *Commit: | ||||
| //   		// o is a Commit | ||||
| //   	case *Tree: | ||||
| //   		// o is a Tree | ||||
| //   	case *Blob: | ||||
| //   		// o is a Blob | ||||
| //   	case *Tag: | ||||
| //   		// o is a Tag | ||||
| //   	} | ||||
| //   } | ||||
| // | ||||
| // This interface is intentionally different from plumbing.EncodedObject, which | ||||
| // is a lower level interface used by storage implementations to read and write | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/protocol/packp/updreq.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/plumbing/protocol/packp/updreq.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -48,7 +48,6 @@ func NewReferenceUpdateRequest() *ReferenceUpdateRequest { | ||||
| //   - ofs-delta | ||||
| //   - ref-delta | ||||
| //   - delete-refs | ||||
| // | ||||
| // It leaves up to the user to add the following capabilities later: | ||||
| //   - atomic | ||||
| //   - ofs-delta | ||||
|  | ||||
							
								
								
									
										7
									
								
								vendor/github.com/go-git/go-git/v5/utils/binary/read.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/github.com/go-git/go-git/v5/utils/binary/read.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -80,9 +80,10 @@ func ReadUntilFromBufioReader(r *bufio.Reader, delim byte) ([]byte, error) { | ||||
| // | ||||
| // This is how the offset is saved in C: | ||||
| // | ||||
| //	dheader[pos] = ofs & 127; | ||||
| //	while (ofs >>= 7) | ||||
| //	    dheader[--pos] = 128 | (--ofs & 127); | ||||
| //     dheader[pos] = ofs & 127; | ||||
| //     while (ofs >>= 7) | ||||
| //         dheader[--pos] = 128 | (--ofs & 127); | ||||
| // | ||||
| func ReadVariableWidthInt(r io.Reader) (int64, error) { | ||||
| 	var c byte | ||||
| 	if err := Read(r, &c); err != nil { | ||||
|  | ||||
							
								
								
									
										5
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/internal/frame/frame.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/internal/frame/frame.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -42,9 +42,8 @@ func New(n noder.Noder) (*Frame, error) { | ||||
| // separated by comas. | ||||
| // | ||||
| // Examples: | ||||
| // | ||||
| //	[] | ||||
| //	["a", "b"] | ||||
| //     [] | ||||
| //     ["a", "b"] | ||||
| func (f *Frame) String() string { | ||||
| 	var buf bytes.Buffer | ||||
| 	_ = buf.WriteByte('[') | ||||
|  | ||||
							
								
								
									
										17
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/iter.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/iter.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -17,14 +17,15 @@ import ( | ||||
| // This is the kind of traversal you will expect when listing ordinary | ||||
| // files and directories recursively, for example: | ||||
| // | ||||
| //	     Trie           Traversal order | ||||
| //	     ----           --------------- | ||||
| //	      . | ||||
| //	    / | \           c | ||||
| //	   /  |  \          d/ | ||||
| //	  d   c   z   ===>  d/a | ||||
| //	 / \                d/b | ||||
| //	b   a               z | ||||
| //          Trie           Traversal order | ||||
| //          ----           --------------- | ||||
| //           . | ||||
| //         / | \           c | ||||
| //        /  |  \          d/ | ||||
| //       d   c   z   ===>  d/a | ||||
| //      / \                d/b | ||||
| //     b   a               z | ||||
| // | ||||
| // | ||||
| // This iterator is somewhat especial as you can chose to skip whole | ||||
| // "directories" when iterating: | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/noder/noder.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/go-git/go-git/v5/utils/merkletrie/noder/noder.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -53,7 +53,7 @@ type Noder interface { | ||||
| 	// implement NumChildren in O(1) while Children is usually more | ||||
| 	// complex. | ||||
| 	NumChildren() (int, error) | ||||
| 	Skip() bool | ||||
| 	Skip()	bool | ||||
| } | ||||
|  | ||||
| // NoChildren represents the children of a noder without children. | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_bsd.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_bsd.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,4 +1,3 @@ | ||||
| //go:build darwin || freebsd || netbsd | ||||
| // +build darwin freebsd netbsd | ||||
|  | ||||
| package git | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_js.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_js.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,4 +1,3 @@ | ||||
| //go:build js | ||||
| // +build js | ||||
|  | ||||
| package git | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_linux.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_linux.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,4 +1,3 @@ | ||||
| //go:build linux | ||||
| // +build linux | ||||
|  | ||||
| package git | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_unix_other.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_unix_other.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,4 +1,3 @@ | ||||
| //go:build openbsd || dragonfly || solaris | ||||
| // +build openbsd dragonfly solaris | ||||
|  | ||||
| package git | ||||
|  | ||||
							
								
								
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_windows.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/go-git/go-git/v5/worktree_windows.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,4 +1,3 @@ | ||||
| //go:build windows | ||||
| // +build windows | ||||
|  | ||||
| package git | ||||
|  | ||||
		Reference in New Issue
	
	Block a user