blob: d0b9c50d20489e421139b531b66d0b0e693c9781 [file] [log] [blame]
Junio C Hamano7ad22dc2007-01-29 02:55:481git-config(1)
2=============
3
4NAME
5----
6git-config - Get and set repository or global options
7
8
9SYNOPSIS
10--------
11[verse]
Junio C Hamanoccb82522018-05-08 07:52:0912'git config' [<file-option>] [--type=<type>] [--show-origin] [-z|--null] name [value [value_regex]]
13'git config' [<file-option>] [--type=<type>] --add name value
14'git config' [<file-option>] [--type=<type>] --replace-all name value [value_regex]
15'git config' [<file-option>] [--type=<type>] [--show-origin] [-z|--null] --get name [value_regex]
16'git config' [<file-option>] [--type=<type>] [--show-origin] [-z|--null] --get-all name [value_regex]
17'git config' [<file-option>] [--type=<type>] [--show-origin] [-z|--null] [--name-only] --get-regexp name_regex [value_regex]
18'git config' [<file-option>] [--type=<type>] [-z|--null] --get-urlmatch name URL
Junio C Hamanofce7c7e2008-07-02 03:06:3819'git config' [<file-option>] --unset name [value_regex]
20'git config' [<file-option>] --unset-all name [value_regex]
21'git config' [<file-option>] --rename-section old_name new_name
22'git config' [<file-option>] --remove-section name
Junio C Hamano76df4f72016-02-26 22:13:1023'git config' [<file-option>] [--show-origin] [-z|--null] [--name-only] -l | --list
Junio C Hamanofce7c7e2008-07-02 03:06:3824'git config' [<file-option>] --get-color name [default]
25'git config' [<file-option>] --get-colorbool name [stdout-is-tty]
Junio C Hamano0a235222009-03-06 08:21:0926'git config' [<file-option>] -e | --edit
Junio C Hamano7ad22dc2007-01-29 02:55:4827
28DESCRIPTION
29-----------
30You can query/set/replace/unset options with this command. The name is
31actually the section and the key separated by a dot, and the value will be
32escaped.
33
Junio C Hamano92d80372016-07-13 22:00:0534Multiple lines can be added to an option by using the `--add` option.
Junio C Hamano7ad22dc2007-01-29 02:55:4835If you want to update or unset an option which can occur on multiple
36lines, a POSIX regexp `value_regex` needs to be given. Only the
37existing values that match the regexp are updated or unset. If
38you want to handle the lines that do *not* match the regex, just
Junio C Hamano6fddfe52007-05-31 07:38:1939prepend a single exclamation mark in front (see also <<EXAMPLES>>).
Junio C Hamano7ad22dc2007-01-29 02:55:4840
Junio C Hamanoccb82522018-05-08 07:52:0941The `--type=<type>` option instructs 'git config' to ensure that incoming and
42outgoing values are canonicalize-able under the given <type>. If no
43`--type=<type>` is given, no canonicalization will be performed. Callers may
44unset an existing `--type` specifier with `--no-type`.
Junio C Hamano7ad22dc2007-01-29 02:55:4845
Junio C Hamanobcdb12e2012-05-10 18:45:1546When reading, the values are read from the system, global and
47repository local configuration files by default, and options
Junio C Hamano06ce83b2018-11-13 14:06:1248`--system`, `--global`, `--local`, `--worktree` and
49`--file <filename>` can be used to tell the command to read from only
50that location (see <<FILES>>).
Junio C Hamanobcdb12e2012-05-10 18:45:1551
52When writing, the new value is written to the repository local
Junio C Hamano92d80372016-07-13 22:00:0553configuration file by default, and options `--system`, `--global`,
Junio C Hamano06ce83b2018-11-13 14:06:1254`--worktree`, `--file <filename>` can be used to tell the command to
55write to that location (you can say `--local` but that is the
56default).
Junio C Hamano0ddc94d2007-08-01 08:42:3957
Junio C Hamanof3353932012-09-04 23:16:5158This command will fail with non-zero status upon error. Some exit
59codes are:
Junio C Hamano7ad22dc2007-01-29 02:55:4860
Junio C Hamanoccdabca2016-05-06 22:27:0961- The section or key is invalid (ret=1),
Junio C Hamano4ba4a782016-04-03 19:11:3262- no section or name was provided (ret=2),
Junio C Hamanoccdabca2016-05-06 22:27:0963- the config file is invalid (ret=3),
64- the config file cannot be written (ret=4),
Junio C Hamano4ba4a782016-04-03 19:11:3265- you try to unset an option which does not exist (ret=5),
66- you try to unset/set an option for which multiple lines match (ret=5), or
67- you try to use an invalid regexp (ret=6).
Junio C Hamano7ad22dc2007-01-29 02:55:4868
Junio C Hamano2a294cd2011-05-23 23:06:3169On success, the command returns the exit code 0.
Junio C Hamano7ad22dc2007-01-29 02:55:4870
71OPTIONS
72-------
73
74--replace-all::
75Default behavior is to replace at most one line. This replaces
76all lines matching the key (and optionally the value_regex).
77
78--add::
79Adds a new line to the option without altering any existing
Junio C Hamano89bdb3b2009-05-10 06:48:1480values. This is the same as providing '^$' as the value_regex
81in `--replace-all`.
Junio C Hamano7ad22dc2007-01-29 02:55:4882
83--get::
84Get the value for a given key (optionally filtered by a regex
85matching the value). Returns error code 1 if the key was not
Junio C Hamano68e17742013-07-04 00:44:2686found and the last value if multiple key values were found.
Junio C Hamano7ad22dc2007-01-29 02:55:4887
88--get-all::
Junio C Hamano4ba4a782016-04-03 19:11:3289Like get, but returns all values for a multi-valued key.
Junio C Hamano7ad22dc2007-01-29 02:55:4890
91--get-regexp::
Junio C Hamano81d540a2012-03-02 19:52:4792Like --get-all, but interprets the name as a regular expression and
93writes out the key names. Regular expression matching is currently
94case-sensitive and done against a canonicalized version of the key
95in which section and variable names are lowercased, but subsection
96names are not.
Junio C Hamano7ad22dc2007-01-29 02:55:4897
Junio C Hamano8eac2682013-09-09 22:35:2098--get-urlmatch name URL::
99When given a two-part name section.key, the value for
100section.<url>.key whose <url> part matches the best to the
101given URL is returned (if no such key exists, the value for
102section.key is used as a fallback). When given just the
103section as name, do so for all the keys in the section and
Junio C Hamano4ba4a782016-04-03 19:11:32104list them. Returns error code 1 if no value is found.
Junio C Hamano8eac2682013-09-09 22:35:20105
Junio C Hamano7ad22dc2007-01-29 02:55:48106--global::
Junio C Hamano4b500fa2013-07-31 23:11:16107For writing options: write to global `~/.gitconfig` file
108rather than the repository `.git/config`, write to
109`$XDG_CONFIG_HOME/git/config` file if this file exists and the
110`~/.gitconfig` file doesn't.
Junio C Hamano6fddfe52007-05-31 07:38:19111+
Junio C Hamano4b500fa2013-07-31 23:11:16112For reading options: read only from global `~/.gitconfig` and from
113`$XDG_CONFIG_HOME/git/config` rather than from all available files.
Junio C Hamano6fddfe52007-05-31 07:38:19114+
115See also <<FILES>>.
Junio C Hamano7ad22dc2007-01-29 02:55:48116
Junio C Hamano81c711d2007-04-20 07:20:14117--system::
Junio C Hamano4b500fa2013-07-31 23:11:16118For writing options: write to system-wide
119`$(prefix)/etc/gitconfig` rather than the repository
120`.git/config`.
Junio C Hamano6fddfe52007-05-31 07:38:19121+
Junio C Hamano4b500fa2013-07-31 23:11:16122For reading options: read only from system-wide `$(prefix)/etc/gitconfig`
Junio C Hamano6fddfe52007-05-31 07:38:19123rather than from all available files.
124+
125See also <<FILES>>.
Junio C Hamano81c711d2007-04-20 07:20:14126
Junio C Hamano8ab94942013-06-24 21:55:30127--local::
Junio C Hamano4b500fa2013-07-31 23:11:16128For writing options: write to the repository `.git/config` file.
Junio C Hamano8ab94942013-06-24 21:55:30129This is the default behavior.
130+
Junio C Hamano4b500fa2013-07-31 23:11:16131For reading options: read only from the repository `.git/config` rather than
Junio C Hamano8ab94942013-06-24 21:55:30132from all available files.
133+
134See also <<FILES>>.
135
Junio C Hamano06ce83b2018-11-13 14:06:12136--worktree::
137Similar to `--local` except that `.git/config.worktree` is
138read from or written to if `extensions.worktreeConfig` is
139present. If not it's the same as `--local`.
140
Junio C Hamanoeb415992008-06-08 22:49:47141-f config-file::
142--file config-file::
Junio C Hamano0ddc94d2007-08-01 08:42:39143Use the given config file instead of the one specified by GIT_CONFIG.
144
Junio C Hamano58f587a2013-07-22 19:20:59145--blob blob::
Junio C Hamano92d80372016-07-13 22:00:05146Similar to `--file` but use the given blob instead of a file. E.g.
Junio C Hamano58f587a2013-07-22 19:20:59147you can use 'master:.gitmodules' to read values from the file
148'.gitmodules' in the master branch. See "SPECIFYING REVISIONS"
149section in linkgit:gitrevisions[7] for a more complete list of
150ways to spell blob names.
151
Junio C Hamanod15328a2007-03-09 09:06:40152--remove-section::
153Remove the given section from the configuration file.
154
155--rename-section::
156Rename the given section to a new name.
157
Junio C Hamano7ad22dc2007-01-29 02:55:48158--unset::
159Remove the line matching the key from config file.
160
161--unset-all::
Junio C Hamano10557772007-03-15 07:12:30162Remove all lines matching the key from config file.
Junio C Hamano7ad22dc2007-01-29 02:55:48163
Junio C Hamanoeb415992008-06-08 22:49:47164-l::
165--list::
Junio C Hamano3891e252015-08-31 23:06:13166List all variables set in config file, along with their values.
Junio C Hamano7ad22dc2007-01-29 02:55:48167
Junio C Hamanoccb82522018-05-08 07:52:09168--type <type>::
169 'git config' will ensure that any input or output is valid under the given
170 type constraint(s), and will canonicalize outgoing values in `<type>`'s
171 canonical form.
172+
173Valid `<type>`'s include:
174+
175- 'bool': canonicalize values as either "true" or "false".
176- 'int': canonicalize values as simple decimal numbers. An optional suffix of
177 'k', 'm', or 'g' will cause the value to be multiplied by 1024, 1048576, or
178 1073741824 upon input.
179- 'bool-or-int': canonicalize according to either 'bool' or 'int', as described
180 above.
181- 'path': canonicalize by adding a leading `~` to the value of `$HOME` and
182 `~user` to the home directory for the specified user. This specifier has no
183 effect when setting the value (but you can use `git config section.variable
184 ~/` from the command line to let your shell do the expansion.)
185- 'expiry-date': canonicalize by converting from a fixed or relative date-string
186 to a timestamp. This specifier has no effect when setting the value.
187- 'color': When getting a value, canonicalize by converting to an ANSI color
188 escape sequence. When setting a value, a sanity-check is performed to ensure
189 that the given value is canonicalize-able as an ANSI color, but it is written
190 as-is.
191+
192
Junio C Hamano7ad22dc2007-01-29 02:55:48193--bool::
Junio C Hamano7ad22dc2007-01-29 02:55:48194--int::
Junio C Hamano792c5a92009-03-08 08:45:13195--bool-or-int::
Junio C Hamanob141a922010-01-10 19:55:14196--path::
Junio C Hamano912712b2017-12-06 18:04:01197--expiry-date::
Junio C Hamano32a75272018-10-16 07:37:35198 Historical options for selecting a type specifier. Prefer instead `--type`
199 (see above).
Junio C Hamanoccb82522018-05-08 07:52:09200
201--no-type::
202 Un-sets the previously set type specifier (if one was previously set). This
203 option requests that 'git config' not canonicalize the retrieved variable.
204 `--no-type` has no effect without `--type=<type>` or `--<type>`.
Junio C Hamano912712b2017-12-06 18:04:01205
Junio C Hamanoeb415992008-06-08 22:49:47206-z::
207--null::
Junio C Hamanoddc5ad42007-06-27 07:14:52208For all options that output values and/or keys, always
Junio C Hamano1f511962008-01-30 08:28:52209end values with the null character (instead of a
Junio C Hamanoddc5ad42007-06-27 07:14:52210newline). Use newline instead as a delimiter between
211key and value. This allows for secure parsing of the
212output without getting confused e.g. by values that
213contain line breaks.
214
Junio C Hamano3891e252015-08-31 23:06:13215--name-only::
216Output only the names of config variables for `--list` or
217`--get-regexp`.
218
Junio C Hamano76df4f72016-02-26 22:13:10219--show-origin::
220Augment the output of all queried config options with the
221origin type (file, standard input, blob, command line) and
222the actual origin (config file path, ref, or blob id if
223applicable).
224
Junio C Hamano00b8b632007-12-07 09:50:49225--get-colorbool name [stdout-is-tty]::
226
227Find the color setting for `name` (e.g. `color.diff`) and output
228"true" or "false". `stdout-is-tty` should be either "true" or
229"false", and is taken into account when configuration says
230"auto". If `stdout-is-tty` is missing, then checks the standard
231output of the command itself, and exits with status 0 if color
232is to be used, or exits with status 1 otherwise.
Junio C Hamanoe3ddb5b2008-04-21 00:48:07233When the color setting for `name` is undefined, the command uses
234`color.ui` as fallback.
Junio C Hamano00b8b632007-12-07 09:50:49235
Junio C Hamano89bdb3b2009-05-10 06:48:14236--get-color name [default]::
Junio C Hamano0c999702007-12-03 09:57:55237
238Find the color configured for `name` (e.g. `color.diff.new`) and
239output it as the ANSI color escape sequence to the standard
240output. The optional `default` parameter is used instead, if
241there is no color configured for `name`.
Junio C Hamanoccb82522018-05-08 07:52:09242+
Junio C Hamano328b8c92019-03-20 07:15:59243`--type=color [--default=<default>]` is preferred over `--get-color`
244(but note that `--get-color` will omit the trailing newline printed by
245`--type=color`).
Junio C Hamano7ad22dc2007-01-29 02:55:48246
Junio C Hamano0a235222009-03-06 08:21:09247-e::
248--edit::
249Opens an editor to modify the specified config file; either
Junio C Hamano92d80372016-07-13 22:00:05250`--system`, `--global`, or repository (default).
Junio C Hamano0a235222009-03-06 08:21:09251
Junio C Hamano3d1b5a12013-05-17 23:34:02252--[no-]includes::
Junio C Hamanoe0238c22012-02-23 22:45:50253Respect `include.*` directives in config files when looking up
Junio C Hamanob29ef022016-02-22 22:06:01254values. Defaults to `off` when a specific file is given (e.g.,
255using `--file`, `--global`, etc) and `on` when searching all
256config files.
Junio C Hamanoe0238c22012-02-23 22:45:50257
Junio C Hamanoccb82522018-05-08 07:52:09258--default <value>::
259 When using `--get`, and the requested variable is not found, behave as if
260 <value> were the value assigned to the that variable.
261
Junio C Hamano81000162018-03-21 19:54:50262CONFIGURATION
263-------------
264`pager.config` is only respected when listing configuration, i.e., when
265using `--list` or any of the `--get-*` which may return multiple results.
266The default is to use a pager.
267
Junio C Hamano6fddfe52007-05-31 07:38:19268[[FILES]]
269FILES
270-----
271
Junio C Hamano92d80372016-07-13 22:00:05272If not set explicitly with `--file`, there are four files where
Junio C Hamano1aa40d22010-01-21 17:46:43273'git config' will search for configuration options:
Junio C Hamano6fddfe52007-05-31 07:38:19274
Junio C Hamano8401f142013-07-12 22:47:46275$(prefix)/etc/gitconfig::
276System-wide configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19277
Junio C Hamano8edb4c72012-07-09 20:33:55278$XDG_CONFIG_HOME/git/config::
279Second user-specific configuration file. If $XDG_CONFIG_HOME is not set
Junio C Hamano4b500fa2013-07-31 23:11:16280or empty, `$HOME/.config/git/config` will be used. Any single-valued
Junio C Hamano8edb4c72012-07-09 20:33:55281variable set in this file will be overwritten by whatever is in
Junio C Hamano4b500fa2013-07-31 23:11:16282`~/.gitconfig`. It is a good idea not to create this file if
Junio C Hamano8edb4c72012-07-09 20:33:55283you sometimes use older versions of Git, as support for this
284file was added fairly recently.
285
Junio C Hamano8401f142013-07-12 22:47:46286~/.gitconfig::
287User-specific configuration file. Also called "global"
288configuration file.
289
290$GIT_DIR/config::
291Repository specific configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19292
Junio C Hamano06ce83b2018-11-13 14:06:12293$GIT_DIR/config.worktree::
294This is optional and is only searched when
295`extensions.worktreeConfig` is present in $GIT_DIR/config.
296
Junio C Hamano6fddfe52007-05-31 07:38:19297If no further options are given, all reading options will read all of these
298files that are available. If the global or the system-wide configuration
299file are not available they will be ignored. If the repository configuration
Junio C Hamano1aa40d22010-01-21 17:46:43300file is not available or readable, 'git config' will exit with a non-zero
Junio C Hamano6fddfe52007-05-31 07:38:19301error code. However, in neither case will an error message be issued.
302
Junio C Hamano8401f142013-07-12 22:47:46303The files are read in the order given above, with last value found taking
304precedence over values read earlier. When multiple values are taken then all
305values of a key from all files will be used.
306
Junio C Hamanoe7808d72016-08-26 21:48:01307You may override individual configuration parameters when running any git
308command by using the `-c` option. See linkgit:git[1] for details.
309
Junio C Hamano6fddfe52007-05-31 07:38:19310All writing options will per default write to the repository specific
Junio C Hamano92d80372016-07-13 22:00:05311configuration file. Note that this also affects options like `--replace-all`
312and `--unset`. *'git config' will only ever change one file at a time*.
Junio C Hamano6fddfe52007-05-31 07:38:19313
Junio C Hamanoe1aeb5e2014-06-06 19:16:29314You can override these rules either by command-line options or by environment
Junio C Hamano06ce83b2018-11-13 14:06:12315variables. The `--global`, `--system` and `--worktree` options will limit
316the file used to the global, system-wide or per-worktree file respectively.
317The `GIT_CONFIG` environment variable has a similar effect, but you
318can specify any filename you want.
Junio C Hamano6fddfe52007-05-31 07:38:19319
Junio C Hamano6fddfe52007-05-31 07:38:19320
Junio C Hamano7ad22dc2007-01-29 02:55:48321ENVIRONMENT
322-----------
323
324GIT_CONFIG::
325Take the configuration from the given file instead of .git/config.
Junio C Hamano6fddfe52007-05-31 07:38:19326Using the "--global" option forces this to ~/.gitconfig. Using the
327"--system" option forces this to $(prefix)/etc/gitconfig.
Junio C Hamano7ad22dc2007-01-29 02:55:48328
Junio C Hamanoeec745b2013-01-07 08:08:20329GIT_CONFIG_NOSYSTEM::
330Whether to skip reading settings from the system-wide
331$(prefix)/etc/gitconfig file. See linkgit:git[1] for details.
332
Junio C Hamano6fddfe52007-05-31 07:38:19333See also <<FILES>>.
Junio C Hamano7ad22dc2007-01-29 02:55:48334
335
Junio C Hamano6fddfe52007-05-31 07:38:19336[[EXAMPLES]]
337EXAMPLES
338--------
Junio C Hamano7ad22dc2007-01-29 02:55:48339
340Given a .git/config like this:
341
342#
343# This is the config file, and
344# a '#' or ';' character indicates
345# a comment
346#
347
348; core variables
349[core]
350; Don't trust file modes
351filemode = false
352
353; Our diff algorithm
354[diff]
Junio C Hamano85c71572008-07-28 00:03:31355external = /usr/local/bin/diff-wrapper
Junio C Hamano7ad22dc2007-01-29 02:55:48356renames = true
357
358; Proxy settings
359[core]
Junio C Hamano53850262012-08-29 23:03:49360gitproxy=proxy-command for kernel.org
Junio C Hamano7ad22dc2007-01-29 02:55:48361gitproxy=default-proxy ; for all the rest
362
Junio C Hamano8eac2682013-09-09 22:35:20363; HTTP
364[http]
365sslVerify
366[http "https://weak.example.com"]
367sslVerify = false
368cookieFile = /tmp/cookie.txt
369
Junio C Hamano7ad22dc2007-01-29 02:55:48370you can set the filemode to true with
371
372------------
373% git config core.filemode true
374------------
375
376The hypothetical proxy command entries actually have a postfix to discern
377what URL they apply to. Here is how to change the entry for kernel.org
378to "ssh".
379
380------------
381% git config core.gitproxy '"ssh" for kernel.org' 'for kernel.org$'
382------------
383
384This makes sure that only the key/value pair for kernel.org is replaced.
385
386To delete the entry for renames, do
387
388------------
389% git config --unset diff.renames
390------------
391
392If you want to delete an entry for a multivar (like core.gitproxy above),
393you have to provide a regex matching the value of exactly one line.
394
395To query the value for a given key, do
396
397------------
398% git config --get core.filemode
399------------
400
401or
402
403------------
404% git config core.filemode
405------------
406
407or, to query a multivar:
408
409------------
410% git config --get core.gitproxy "for kernel.org$"
411------------
412
413If you want to know all the values for a multivar, do:
414
415------------
416% git config --get-all core.gitproxy
417------------
418
Junio C Hamanoffb4b682008-12-13 07:35:22419If you like to live dangerously, you can replace *all* core.gitproxy by a
Junio C Hamano7ad22dc2007-01-29 02:55:48420new one with
421
422------------
423% git config --replace-all core.gitproxy ssh
424------------
425
426However, if you really only want to replace the line for the default proxy,
427i.e. the one without a "for ..." postfix, do something like this:
428
429------------
430% git config core.gitproxy ssh '! for '
431------------
432
433To actually match only values with an exclamation mark, you have to
434
435------------
436% git config section.key value '[!]'
437------------
438
439To add a new proxy, without altering any of the existing ones, use
440
441------------
Junio C Hamano53850262012-08-29 23:03:49442% git config --add core.gitproxy '"proxy-command" for example.com'
Junio C Hamano7ad22dc2007-01-29 02:55:48443------------
444
Junio C Hamano0c999702007-12-03 09:57:55445An example to use customized color from the configuration in your
446script:
447
448------------
449#!/bin/sh
450WS=$(git config --get-color color.diff.whitespace "blue reverse")
451RESET=$(git config --get-color "" "reset")
452echo "${WS}your whitespace color or blue reverse${RESET}"
453------------
Junio C Hamano7ad22dc2007-01-29 02:55:48454
Junio C Hamano8eac2682013-09-09 22:35:20455For URLs in `https://weak.example.com`, `http.sslVerify` is set to
456false, while it is set to `true` for all others:
457
458------------
Junio C Hamano32a75272018-10-16 07:37:35459% git config --type=bool --get-urlmatch http.sslverify https://good.example.com
Junio C Hamano8eac2682013-09-09 22:35:20460true
Junio C Hamano32a75272018-10-16 07:37:35461% git config --type=bool --get-urlmatch http.sslverify https://weak.example.com
Junio C Hamano8eac2682013-09-09 22:35:20462false
463% git config --get-urlmatch http https://weak.example.com
Junio C Hamano322c6242015-03-23 21:32:46464http.cookieFile /tmp/cookie.txt
Junio C Hamano8eac2682013-09-09 22:35:20465http.sslverify false
466------------
467
Junio C Hamano7ad22dc2007-01-29 02:55:48468include::config.txt[]
469
Junio C Hamano11ae3202018-08-20 20:15:42470BUGS
471----
472When using the deprecated `[section.subsection]` syntax, changing a value
473will result in adding a multi-line key instead of a change, if the subsection
474is given with at least one uppercase character. For example when the config
475looks like
476
477--------
478 [section.subsection]
479 key = value1
480--------
481
482and running `git config section.Subsection.key value2` will result in
483
484--------
485 [section.subsection]
486 key = value1
487 key = value2
488--------
489
490
Junio C Hamano7ad22dc2007-01-29 02:55:48491GIT
492---
Junio C Hamanof7c042d2008-06-06 22:50:53493Part of the linkgit:git[1] suite