blob: 1bfe9f56a7b9b983a2d927406dc17ff384e715a2 [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+
243`--type=color [--default=<default>]` is preferred over `--get-color`.
Junio C Hamano7ad22dc2007-01-29 02:55:48244
Junio C Hamano0a235222009-03-06 08:21:09245-e::
246--edit::
247Opens an editor to modify the specified config file; either
Junio C Hamano92d80372016-07-13 22:00:05248`--system`, `--global`, or repository (default).
Junio C Hamano0a235222009-03-06 08:21:09249
Junio C Hamano3d1b5a12013-05-17 23:34:02250--[no-]includes::
Junio C Hamanoe0238c22012-02-23 22:45:50251Respect `include.*` directives in config files when looking up
Junio C Hamanob29ef022016-02-22 22:06:01252values. Defaults to `off` when a specific file is given (e.g.,
253using `--file`, `--global`, etc) and `on` when searching all
254config files.
Junio C Hamanoe0238c22012-02-23 22:45:50255
Junio C Hamanoccb82522018-05-08 07:52:09256--default <value>::
257 When using `--get`, and the requested variable is not found, behave as if
258 <value> were the value assigned to the that variable.
259
Junio C Hamano81000162018-03-21 19:54:50260CONFIGURATION
261-------------
262`pager.config` is only respected when listing configuration, i.e., when
263using `--list` or any of the `--get-*` which may return multiple results.
264The default is to use a pager.
265
Junio C Hamano6fddfe52007-05-31 07:38:19266[[FILES]]
267FILES
268-----
269
Junio C Hamano92d80372016-07-13 22:00:05270If not set explicitly with `--file`, there are four files where
Junio C Hamano1aa40d22010-01-21 17:46:43271'git config' will search for configuration options:
Junio C Hamano6fddfe52007-05-31 07:38:19272
Junio C Hamano8401f142013-07-12 22:47:46273$(prefix)/etc/gitconfig::
274System-wide configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19275
Junio C Hamano8edb4c72012-07-09 20:33:55276$XDG_CONFIG_HOME/git/config::
277Second user-specific configuration file. If $XDG_CONFIG_HOME is not set
Junio C Hamano4b500fa2013-07-31 23:11:16278or empty, `$HOME/.config/git/config` will be used. Any single-valued
Junio C Hamano8edb4c72012-07-09 20:33:55279variable set in this file will be overwritten by whatever is in
Junio C Hamano4b500fa2013-07-31 23:11:16280`~/.gitconfig`. It is a good idea not to create this file if
Junio C Hamano8edb4c72012-07-09 20:33:55281you sometimes use older versions of Git, as support for this
282file was added fairly recently.
283
Junio C Hamano8401f142013-07-12 22:47:46284~/.gitconfig::
285User-specific configuration file. Also called "global"
286configuration file.
287
288$GIT_DIR/config::
289Repository specific configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19290
Junio C Hamano06ce83b2018-11-13 14:06:12291$GIT_DIR/config.worktree::
292This is optional and is only searched when
293`extensions.worktreeConfig` is present in $GIT_DIR/config.
294
Junio C Hamano6fddfe52007-05-31 07:38:19295If no further options are given, all reading options will read all of these
296files that are available. If the global or the system-wide configuration
297file are not available they will be ignored. If the repository configuration
Junio C Hamano1aa40d22010-01-21 17:46:43298file is not available or readable, 'git config' will exit with a non-zero
Junio C Hamano6fddfe52007-05-31 07:38:19299error code. However, in neither case will an error message be issued.
300
Junio C Hamano8401f142013-07-12 22:47:46301The files are read in the order given above, with last value found taking
302precedence over values read earlier. When multiple values are taken then all
303values of a key from all files will be used.
304
Junio C Hamanoe7808d72016-08-26 21:48:01305You may override individual configuration parameters when running any git
306command by using the `-c` option. See linkgit:git[1] for details.
307
Junio C Hamano6fddfe52007-05-31 07:38:19308All writing options will per default write to the repository specific
Junio C Hamano92d80372016-07-13 22:00:05309configuration file. Note that this also affects options like `--replace-all`
310and `--unset`. *'git config' will only ever change one file at a time*.
Junio C Hamano6fddfe52007-05-31 07:38:19311
Junio C Hamanoe1aeb5e2014-06-06 19:16:29312You can override these rules either by command-line options or by environment
Junio C Hamano06ce83b2018-11-13 14:06:12313variables. The `--global`, `--system` and `--worktree` options will limit
314the file used to the global, system-wide or per-worktree file respectively.
315The `GIT_CONFIG` environment variable has a similar effect, but you
316can specify any filename you want.
Junio C Hamano6fddfe52007-05-31 07:38:19317
Junio C Hamano6fddfe52007-05-31 07:38:19318
Junio C Hamano7ad22dc2007-01-29 02:55:48319ENVIRONMENT
320-----------
321
322GIT_CONFIG::
323Take the configuration from the given file instead of .git/config.
Junio C Hamano6fddfe52007-05-31 07:38:19324Using the "--global" option forces this to ~/.gitconfig. Using the
325"--system" option forces this to $(prefix)/etc/gitconfig.
Junio C Hamano7ad22dc2007-01-29 02:55:48326
Junio C Hamanoeec745b2013-01-07 08:08:20327GIT_CONFIG_NOSYSTEM::
328Whether to skip reading settings from the system-wide
329$(prefix)/etc/gitconfig file. See linkgit:git[1] for details.
330
Junio C Hamano6fddfe52007-05-31 07:38:19331See also <<FILES>>.
Junio C Hamano7ad22dc2007-01-29 02:55:48332
333
Junio C Hamano6fddfe52007-05-31 07:38:19334[[EXAMPLES]]
335EXAMPLES
336--------
Junio C Hamano7ad22dc2007-01-29 02:55:48337
338Given a .git/config like this:
339
340#
341# This is the config file, and
342# a '#' or ';' character indicates
343# a comment
344#
345
346; core variables
347[core]
348; Don't trust file modes
349filemode = false
350
351; Our diff algorithm
352[diff]
Junio C Hamano85c71572008-07-28 00:03:31353external = /usr/local/bin/diff-wrapper
Junio C Hamano7ad22dc2007-01-29 02:55:48354renames = true
355
356; Proxy settings
357[core]
Junio C Hamano53850262012-08-29 23:03:49358gitproxy=proxy-command for kernel.org
Junio C Hamano7ad22dc2007-01-29 02:55:48359gitproxy=default-proxy ; for all the rest
360
Junio C Hamano8eac2682013-09-09 22:35:20361; HTTP
362[http]
363sslVerify
364[http "https://weak.example.com"]
365sslVerify = false
366cookieFile = /tmp/cookie.txt
367
Junio C Hamano7ad22dc2007-01-29 02:55:48368you can set the filemode to true with
369
370------------
371% git config core.filemode true
372------------
373
374The hypothetical proxy command entries actually have a postfix to discern
375what URL they apply to. Here is how to change the entry for kernel.org
376to "ssh".
377
378------------
379% git config core.gitproxy '"ssh" for kernel.org' 'for kernel.org$'
380------------
381
382This makes sure that only the key/value pair for kernel.org is replaced.
383
384To delete the entry for renames, do
385
386------------
387% git config --unset diff.renames
388------------
389
390If you want to delete an entry for a multivar (like core.gitproxy above),
391you have to provide a regex matching the value of exactly one line.
392
393To query the value for a given key, do
394
395------------
396% git config --get core.filemode
397------------
398
399or
400
401------------
402% git config core.filemode
403------------
404
405or, to query a multivar:
406
407------------
408% git config --get core.gitproxy "for kernel.org$"
409------------
410
411If you want to know all the values for a multivar, do:
412
413------------
414% git config --get-all core.gitproxy
415------------
416
Junio C Hamanoffb4b682008-12-13 07:35:22417If you like to live dangerously, you can replace *all* core.gitproxy by a
Junio C Hamano7ad22dc2007-01-29 02:55:48418new one with
419
420------------
421% git config --replace-all core.gitproxy ssh
422------------
423
424However, if you really only want to replace the line for the default proxy,
425i.e. the one without a "for ..." postfix, do something like this:
426
427------------
428% git config core.gitproxy ssh '! for '
429------------
430
431To actually match only values with an exclamation mark, you have to
432
433------------
434% git config section.key value '[!]'
435------------
436
437To add a new proxy, without altering any of the existing ones, use
438
439------------
Junio C Hamano53850262012-08-29 23:03:49440% git config --add core.gitproxy '"proxy-command" for example.com'
Junio C Hamano7ad22dc2007-01-29 02:55:48441------------
442
Junio C Hamano0c999702007-12-03 09:57:55443An example to use customized color from the configuration in your
444script:
445
446------------
447#!/bin/sh
448WS=$(git config --get-color color.diff.whitespace "blue reverse")
449RESET=$(git config --get-color "" "reset")
450echo "${WS}your whitespace color or blue reverse${RESET}"
451------------
Junio C Hamano7ad22dc2007-01-29 02:55:48452
Junio C Hamano8eac2682013-09-09 22:35:20453For URLs in `https://weak.example.com`, `http.sslVerify` is set to
454false, while it is set to `true` for all others:
455
456------------
Junio C Hamano32a75272018-10-16 07:37:35457% git config --type=bool --get-urlmatch http.sslverify https://good.example.com
Junio C Hamano8eac2682013-09-09 22:35:20458true
Junio C Hamano32a75272018-10-16 07:37:35459% git config --type=bool --get-urlmatch http.sslverify https://weak.example.com
Junio C Hamano8eac2682013-09-09 22:35:20460false
461% git config --get-urlmatch http https://weak.example.com
Junio C Hamano322c6242015-03-23 21:32:46462http.cookieFile /tmp/cookie.txt
Junio C Hamano8eac2682013-09-09 22:35:20463http.sslverify false
464------------
465
Junio C Hamano7ad22dc2007-01-29 02:55:48466include::config.txt[]
467
Junio C Hamano11ae3202018-08-20 20:15:42468BUGS
469----
470When using the deprecated `[section.subsection]` syntax, changing a value
471will result in adding a multi-line key instead of a change, if the subsection
472is given with at least one uppercase character. For example when the config
473looks like
474
475--------
476 [section.subsection]
477 key = value1
478--------
479
480and running `git config section.Subsection.key value2` will result in
481
482--------
483 [section.subsection]
484 key = value1
485 key = value2
486--------
487
488
Junio C Hamano7ad22dc2007-01-29 02:55:48489GIT
490---
Junio C Hamanof7c042d2008-06-06 22:50:53491Part of the linkgit:git[1] suite