104 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
| extensions.*::
 | |
| 	Unless otherwise stated, is an error to specify an extension if
 | |
| 	`core.repositoryFormatVersion` is not `1`. See
 | |
| 	linkgit:gitrepository-layout[5].
 | |
| +
 | |
| --
 | |
| compatObjectFormat::
 | |
| 	Specify a compatibility hash algorithm to use.  The acceptable values
 | |
| 	are `sha1` and `sha256`.  The value specified must be different from the
 | |
| 	value of `extensions.objectFormat`.  This allows client level
 | |
| 	interoperability between git repositories whose objectFormat matches
 | |
| 	this compatObjectFormat.  In particular when fully implemented the
 | |
| 	pushes and pulls from a repository in whose objectFormat matches
 | |
| 	compatObjectFormat.  As well as being able to use oids encoded in
 | |
| 	compatObjectFormat in addition to oids encoded with objectFormat to
 | |
| 	locally specify objects.
 | |
| 
 | |
| noop::
 | |
| 	This extension does not change git's behavior at all. It is useful only
 | |
| 	for testing format-1 compatibility.
 | |
| +
 | |
| For historical reasons, this extension is respected regardless of the
 | |
| `core.repositoryFormatVersion` setting.
 | |
| 
 | |
| noop-v1::
 | |
| 	This extension does not change git's behavior at all. It is useful only
 | |
| 	for testing format-1 compatibility.
 | |
| 
 | |
| objectFormat::
 | |
| 	Specify the hash algorithm to use.  The acceptable values are `sha1` and
 | |
| 	`sha256`.  If not specified, `sha1` is assumed.
 | |
| +
 | |
| Note that this setting should only be set by linkgit:git-init[1] or
 | |
| linkgit:git-clone[1].  Trying to change it after initialization will not
 | |
| work and will produce hard-to-diagnose issues.
 | |
| 
 | |
| partialClone::
 | |
| 	When enabled, indicates that the repo was created with a partial clone
 | |
| 	(or later performed a partial fetch) and that the remote may have
 | |
| 	omitted sending certain unwanted objects.  Such a remote is called a
 | |
| 	"promisor remote" and it promises that all such omitted objects can
 | |
| 	be fetched from it in the future.
 | |
| +
 | |
| The value of this key is the name of the promisor remote.
 | |
| +
 | |
| For historical reasons, this extension is respected regardless of the
 | |
| `core.repositoryFormatVersion` setting.
 | |
| 
 | |
| preciousObjects::
 | |
| 	If enabled, indicates that objects in the repository MUST NOT be deleted
 | |
| 	(e.g., by `git-prune` or `git repack -d`).
 | |
| +
 | |
| For historical reasons, this extension is respected regardless of the
 | |
| `core.repositoryFormatVersion` setting.
 | |
| 
 | |
| refStorage::
 | |
| 	Specify the ref storage format to use. The acceptable values are:
 | |
| +
 | |
| include::../ref-storage-format.adoc[]
 | |
| 
 | |
| +
 | |
| Note that this setting should only be set by linkgit:git-init[1] or
 | |
| linkgit:git-clone[1]. Trying to change it after initialization will not
 | |
| work and will produce hard-to-diagnose issues.
 | |
| 
 | |
| relativeWorktrees::
 | |
| 	If enabled, indicates at least one worktree has been linked with
 | |
| 	relative paths. Automatically set if a worktree has been created or
 | |
| 	repaired with either the `--relative-paths` option or with the
 | |
| 	`worktree.useRelativePaths` config set to `true`.
 | |
| 
 | |
| worktreeConfig::
 | |
| 	If enabled, then worktrees will load config settings from the
 | |
| 	`$GIT_DIR/config.worktree` file in addition to the
 | |
| 	`$GIT_COMMON_DIR/config` file. Note that `$GIT_COMMON_DIR` and
 | |
| 	`$GIT_DIR` are the same for the main working tree, while other
 | |
| 	working trees have `$GIT_DIR` equal to
 | |
| 	`$GIT_COMMON_DIR/worktrees/<id>/`. The settings in the
 | |
| 	`config.worktree` file will override settings from any other
 | |
| 	config files.
 | |
| +
 | |
| When enabling this extension, you must be careful to move
 | |
| certain values from the common config file to the main working tree's
 | |
| `config.worktree` file, if present:
 | |
| +
 | |
| * `core.worktree` must be moved from `$GIT_COMMON_DIR/config` to
 | |
|   `$GIT_COMMON_DIR/config.worktree`.
 | |
| * If `core.bare` is true, then it must be moved from `$GIT_COMMON_DIR/config`
 | |
|   to `$GIT_COMMON_DIR/config.worktree`.
 | |
| 
 | |
| +
 | |
| It may also be beneficial to adjust the locations of `core.sparseCheckout`
 | |
| and `core.sparseCheckoutCone` depending on your desire for customizable
 | |
| sparse-checkout settings for each worktree. By default, the `git
 | |
| sparse-checkout` builtin enables this extension, assigns
 | |
| these config values on a per-worktree basis, and uses the
 | |
| `$GIT_DIR/info/sparse-checkout` file to specify the sparsity for each
 | |
| worktree independently. See linkgit:git-sparse-checkout[1] for more
 | |
| details.
 | |
| +
 | |
| For historical reasons, this extension is respected regardless of the
 | |
| `core.repositoryFormatVersion` setting.
 | |
| --
 |