| core.attributesFile |  | ✅ | In addition to .gitattributes(per-directory) and.git/info/attributes, Git looks into this file for attributes . Path expansions are made the same way as forcore.excludesFile. | 
| core.autocrlf | false | ✅ | Setting this variable to trueis the same as setting the text attribute toautoon all files andcore.eoltocrlf. Set totrueif you want to have CRLF line endings in your working directory and the repository has LF line endings. This variable can be set toinput, in which case no output conversion is performed. | 
| core.bare | set automatically on init or clone | ✅ | If true this repository is assumed to be bare and has no working directory associated with it. If this is the case a number of commands that require a working directory will be disabled | 
| core.bigFileThreshold | 50 MiB | ✅ | Files larger than this size are stored deflated, without attempting delta compression. Storing large files without delta compression avoids excessive memory usage, at the slight expense of increased disk usage. Additionally files larger than this size are always treated as binary. | 
| core.checkstat |  | ✅ | When missing or is set to default, many fields in the stat structure are checked to detect if a file has been modified since Git looked at it. Checks as much of the dircache stat info as possible (in JGit limited by Java filesystem API). When set tominimumonly checks the size and whole second part of time stamp when comparing the stat info in the dircache with actual file stat info. | 
| core.compression | -1(zlib default) | ✅ | An integer -1..9, indicating a default compression level.-1is the zlib default.0means no compression, and1..9are various speed/size tradeoffs,9being slowest. | 
| core.deltaBaseCacheLimit | 10 MiB | ✅ | Maximum number of bytes to reserve for caching base objects that multiple deltafied objects reference. By storing the entire decompressed base object in a cache Git is able to avoid unpacking and decompressing frequently used base objects multiple times. | 
| core.dfs.blockLimit | 30 MiB | ⃞ | Maximum number bytes of heap memory to dedicate to caching pack file data in DFS block cache. | 
| core.dfs.blockSize | 64 kiB | ⃞ | Size in bytes of a single window read in from the pack file into the DFS block cache. | 
| core.dfs.concurrencyLevel | 32 | ⃞ | The estimated number of threads concurrently accessing the DFS block cache. | 
| core.dfs.deltaBaseCacheLimit | 10 MiB | ⃞ | Maximum number of bytes to hold in per-reader DFS delta base cache. | 
| core.dfs.streamFileThreshold | 50 MiB | ⃞ | The size threshold beyond which objects must be streamed. | 
| core.dfs.streamBuffer | Block size of the pack | ⃞ | Number of bytes to use for buffering when streaming a pack file during copying. If 0 the block size of the pack is used | 
| core.dfs.streamRatio | 0.30 | ⃞ | Ratio of DFS block cache to occupy with a copied pack. Values between 0and1.0. | 
| core.dirNoGitLinks | false | ⃞ | If set to trueavoid checking for submodules. See bug 436200. | 
| core.eol | native | ✅ | Sets the line ending type to use in the working directory for files that are marked as text (either by having the text attribute set, or by having text=autoand Git auto-detecting the contents as text). Alternatives arelf,crlfandnative, which uses the platform’s native line ending. | 
| core.excludesFile |  | ✅ | Specifies the pathname to the file that contains patterns to describe paths that are not meant to be tracked, in addition to .gitignore(per-directory) and.git/info/exclude. | 
| core.fileMode | Auto detects if file modes are supported | ✅ | Tells Git if the executable bit of files in the working tree is to be honored. | 
| core.hideDotFiles | dotGitOnly | ✅ | Windows only. If true, mark newly-created directories and files whose name starts with a dot as hidden. IfdotGitOnly, only the.git/directory is hidden, but no other files starting with a dot. | 
| core.hooksPath | $GIT_DIR/hooks | ✅ | Path to look for hooks. | 
| core.logAllRefUpdates | truein a repository with working tree,falsein bare repository | ✅ | Enable the reflog. | 
| core.packedGitLimit | 10 MiB | ✅ | Maximum number of bytes to cache in memory from pack files. | 
| core.packedGitMmap | false | ✅ | Whether to use Java NIO virtual memory mapping for JGit buffer cache. When set to trueenables use of Java NIO virtual memory mapping for cache windows,falsereads entire window into abyte[]with standard read calls.trueis experimental and may cause instabilities and crashes since Java doesn't support explicit unmapping of file regions mapped to virtual memory. | 
| core.packedGitOpenFiles | 128 | ⃞ | Maximum number of streams to open at a time. Open packs count against the process limits. | 
| core.packedGitUseStrongRefs | false | ⃞ | Whether the window cache should use strong references ( true) or SoftReferences (false). Whenfalsethe JVM will drop data cached in the JGit block cache when heap usage comes close to the maximum heap size. | 
| core.packedGitWindowSize | 8 kiB | ✅ | Number of bytes of a pack file to load into memory in a single read operation. This is the “page size” of the JGit buffer cache, used for all pack access operations. All disk IO occurs as single window reads. Setting this too large may cause the process to load more data than is required; setting this too small may increase the frequency of read() system calls. | 
| core.precomposeUnicode | trueon Mac OS | ✅ | MacOS only. When true, JGit reverts the unicode decomposition of filenames done by Mac OS. | 
| core.quotePath | true | ✅ | Commands that output paths (e.g. ls-files, diff), will quote “unusual” characters in the pathname by enclosing the pathname in double-quotes and escaping those characters with backslashes in the same way C escapes control characters (e.g. \tfor TAB,\nfor LF,\\for backslash) or bytes with values larger than0x80(e.g. octal\302\265for “micro” in UTF-8). | 
| core.repositoryFormatVersion | 1 | ⃞ | Internal version identifying the repository format and layout version. Don't set manually. | 
| core.sha1Implementation | java | ⃞ | Choose the SHA1 implementation used by JGit. Set it to javato use JGit's Java implementation which detects SHA1 collisions if system propertyorg.eclipse.jgit.util.sha1.detectCollisionis unset ortrue. Set it tojdkNativeto use the native implementation available in the JDK, can also be set using system propertyorg.eclipse.jgit.util.sha1.implementation. If both are set the system property takes precedence. Performance ofjdkNativeis around 10% higher thanjavawhendetectCollision=falseand 30% higher whendetectCollision=true. | 
| core.streamFileThreshold | 50 MiB | ⃞ | The size threshold beyond which objects must be streamed. | 
| core.supportsAtomicFileCreation | true | ⃞ | Whether the filesystem supports atomic file creation. | 
| core.symlinks | Auto detect if filesystem supports symlinks | ✅ | If false, symbolic links are checked out as small plain files that contain the link text. | 
| core.trustFolderStat | true | ⃞ | Whether to trust the pack folder‘s, packed-refs file’s and loose-objects folder's file attributes (Java equivalent of stat command on *nix). When looking for pack files, if falseJGit will always scan the.git/objects/packfolder and if set totrueit assumes that pack files are unchanged if the file attributes of the pack folder are unchanged. When getting the list of packed refs, iffalseJGit will always read the packed-refs file and if set totrueit uses the file attributes of the packed-refs file and will only read it if a file attribute has changed. When looking for loose objects, iffalseand if a loose object is not found, JGit will open and close a stream to.git/objectsfolder (which can refresh its directory listing, at least on some NFS clients) and retry looking for that loose object. Setting this option tofalsecan help to workaround caching issues on NFS, but reduces performance. | 
| core.trustPackedRefsStat | unset | ⃞ | Whether to trust the file attributes (Java equivalent of stat command on *nix) of the packed-refs file. If neverJGit will ignore the file attributes of the packed-refs file and always read it. IfalwaysJGit will trust the file attributes of the packed-refs file and will only read it if a file attribute has changed.after_openbehaves the same asalways, except that the packed-refs file is opened and closed before its file attributes are considered. An open/close of the packed-refs file is known to refresh its file attributes, at least on some NFS clients. Ifunset, JGit will use the behavior described intrustFolderStat. | 
| core.worktree | Root directory of the working tree if it is not the parent directory of the .gitdirectory | ✅ | The path to the root of the working tree. |