blob: 7573160f21539592ddeccb3e36cdde04ed0347e6 [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 Hamano5b8e1232020-02-17 22:05:0612'git config' [<file-option>] [--type=<type>] [--show-origin] [--show-scope] [-z|--null] name [value [value_regex]]
Junio C Hamanoccb82522018-05-08 07:52:0913'git config' [<file-option>] [--type=<type>] --add name value
14'git config' [<file-option>] [--type=<type>] --replace-all name value [value_regex]
Junio C Hamano5b8e1232020-02-17 22:05:0615'git config' [<file-option>] [--type=<type>] [--show-origin] [--show-scope] [-z|--null] --get name [value_regex]
16'git config' [<file-option>] [--type=<type>] [--show-origin] [--show-scope] [-z|--null] --get-all name [value_regex]
17'git config' [<file-option>] [--type=<type>] [--show-origin] [--show-scope] [-z|--null] [--name-only] --get-regexp name_regex [value_regex]
Junio C Hamanoccb82522018-05-08 07:52:0918'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 Hamano5b8e1232020-02-17 22:05:0623'git config' [<file-option>] [--show-origin] [--show-scope] [-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 Hamano6b7d2152019-04-16 12:51:15129This is the default behavior.
Junio C Hamano8ab94942013-06-24 21:55:30130+
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 Hamano5b8e1232020-02-17 22:05:06225--show-scope::
226Similar to `--show-origin` in that it augments the output of
227all queried config options with the scope of that value
228(local, global, system, command).
229
Junio C Hamano00b8b632007-12-07 09:50:49230--get-colorbool name [stdout-is-tty]::
231
232Find the color setting for `name` (e.g. `color.diff`) and output
233"true" or "false". `stdout-is-tty` should be either "true" or
234"false", and is taken into account when configuration says
235"auto". If `stdout-is-tty` is missing, then checks the standard
236output of the command itself, and exits with status 0 if color
237is to be used, or exits with status 1 otherwise.
Junio C Hamanoe3ddb5b2008-04-21 00:48:07238When the color setting for `name` is undefined, the command uses
239`color.ui` as fallback.
Junio C Hamano00b8b632007-12-07 09:50:49240
Junio C Hamano89bdb3b2009-05-10 06:48:14241--get-color name [default]::
Junio C Hamano0c999702007-12-03 09:57:55242
243Find the color configured for `name` (e.g. `color.diff.new`) and
244output it as the ANSI color escape sequence to the standard
245output. The optional `default` parameter is used instead, if
246there is no color configured for `name`.
Junio C Hamanoccb82522018-05-08 07:52:09247+
Junio C Hamano328b8c92019-03-20 07:15:59248`--type=color [--default=<default>]` is preferred over `--get-color`
249(but note that `--get-color` will omit the trailing newline printed by
250`--type=color`).
Junio C Hamano7ad22dc2007-01-29 02:55:48251
Junio C Hamano0a235222009-03-06 08:21:09252-e::
253--edit::
254Opens an editor to modify the specified config file; either
Junio C Hamano92d80372016-07-13 22:00:05255`--system`, `--global`, or repository (default).
Junio C Hamano0a235222009-03-06 08:21:09256
Junio C Hamano3d1b5a12013-05-17 23:34:02257--[no-]includes::
Junio C Hamanoe0238c22012-02-23 22:45:50258Respect `include.*` directives in config files when looking up
Junio C Hamanob29ef022016-02-22 22:06:01259values. Defaults to `off` when a specific file is given (e.g.,
260using `--file`, `--global`, etc) and `on` when searching all
261config files.
Junio C Hamanoe0238c22012-02-23 22:45:50262
Junio C Hamanoccb82522018-05-08 07:52:09263--default <value>::
264 When using `--get`, and the requested variable is not found, behave as if
265 <value> were the value assigned to the that variable.
266
Junio C Hamano81000162018-03-21 19:54:50267CONFIGURATION
268-------------
269`pager.config` is only respected when listing configuration, i.e., when
270using `--list` or any of the `--get-*` which may return multiple results.
271The default is to use a pager.
272
Junio C Hamano6fddfe52007-05-31 07:38:19273[[FILES]]
274FILES
275-----
276
Junio C Hamano92d80372016-07-13 22:00:05277If not set explicitly with `--file`, there are four files where
Junio C Hamano1aa40d22010-01-21 17:46:43278'git config' will search for configuration options:
Junio C Hamano6fddfe52007-05-31 07:38:19279
Junio C Hamano8401f142013-07-12 22:47:46280$(prefix)/etc/gitconfig::
281System-wide configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19282
Junio C Hamano8edb4c72012-07-09 20:33:55283$XDG_CONFIG_HOME/git/config::
284Second user-specific configuration file. If $XDG_CONFIG_HOME is not set
Junio C Hamano4b500fa2013-07-31 23:11:16285or empty, `$HOME/.config/git/config` will be used. Any single-valued
Junio C Hamano8edb4c72012-07-09 20:33:55286variable set in this file will be overwritten by whatever is in
Junio C Hamano4b500fa2013-07-31 23:11:16287`~/.gitconfig`. It is a good idea not to create this file if
Junio C Hamano8edb4c72012-07-09 20:33:55288you sometimes use older versions of Git, as support for this
289file was added fairly recently.
290
Junio C Hamano8401f142013-07-12 22:47:46291~/.gitconfig::
292User-specific configuration file. Also called "global"
293configuration file.
294
295$GIT_DIR/config::
296Repository specific configuration file.
Junio C Hamano6fddfe52007-05-31 07:38:19297
Junio C Hamano06ce83b2018-11-13 14:06:12298$GIT_DIR/config.worktree::
299This is optional and is only searched when
300`extensions.worktreeConfig` is present in $GIT_DIR/config.
301
Junio C Hamano6fddfe52007-05-31 07:38:19302If no further options are given, all reading options will read all of these
303files that are available. If the global or the system-wide configuration
304file are not available they will be ignored. If the repository configuration
Junio C Hamano1aa40d22010-01-21 17:46:43305file is not available or readable, 'git config' will exit with a non-zero
Junio C Hamano6fddfe52007-05-31 07:38:19306error code. However, in neither case will an error message be issued.
307
Junio C Hamano8401f142013-07-12 22:47:46308The files are read in the order given above, with last value found taking
309precedence over values read earlier. When multiple values are taken then all
310values of a key from all files will be used.
311
Junio C Hamanoe7808d72016-08-26 21:48:01312You may override individual configuration parameters when running any git
313command by using the `-c` option. See linkgit:git[1] for details.
314
Junio C Hamano6fddfe52007-05-31 07:38:19315All writing options will per default write to the repository specific
Junio C Hamano92d80372016-07-13 22:00:05316configuration file. Note that this also affects options like `--replace-all`
317and `--unset`. *'git config' will only ever change one file at a time*.
Junio C Hamano6fddfe52007-05-31 07:38:19318
Junio C Hamanoe1aeb5e2014-06-06 19:16:29319You can override these rules either by command-line options or by environment
Junio C Hamano06ce83b2018-11-13 14:06:12320variables. The `--global`, `--system` and `--worktree` options will limit
321the file used to the global, system-wide or per-worktree file respectively.
322The `GIT_CONFIG` environment variable has a similar effect, but you
323can specify any filename you want.
Junio C Hamano6fddfe52007-05-31 07:38:19324
Junio C Hamano6fddfe52007-05-31 07:38:19325
Junio C Hamano7ad22dc2007-01-29 02:55:48326ENVIRONMENT
327-----------
328
329GIT_CONFIG::
330Take the configuration from the given file instead of .git/config.
Junio C Hamano6fddfe52007-05-31 07:38:19331Using the "--global" option forces this to ~/.gitconfig. Using the
332"--system" option forces this to $(prefix)/etc/gitconfig.
Junio C Hamano7ad22dc2007-01-29 02:55:48333
Junio C Hamanoeec745b2013-01-07 08:08:20334GIT_CONFIG_NOSYSTEM::
335Whether to skip reading settings from the system-wide
336$(prefix)/etc/gitconfig file. See linkgit:git[1] for details.
337
Junio C Hamano6fddfe52007-05-31 07:38:19338See also <<FILES>>.
Junio C Hamano7ad22dc2007-01-29 02:55:48339
340
Junio C Hamano6fddfe52007-05-31 07:38:19341[[EXAMPLES]]
342EXAMPLES
343--------
Junio C Hamano7ad22dc2007-01-29 02:55:48344
345Given a .git/config like this:
346
Junio C Hamano48cd3f12019-10-09 05:55:30347------------
348#
349# This is the config file, and
350# a '#' or ';' character indicates
351# a comment
352#
Junio C Hamano7ad22dc2007-01-29 02:55:48353
Junio C Hamano48cd3f12019-10-09 05:55:30354; core variables
355[core]
356; Don't trust file modes
357filemode = false
Junio C Hamano7ad22dc2007-01-29 02:55:48358
Junio C Hamano48cd3f12019-10-09 05:55:30359; Our diff algorithm
360[diff]
361external = /usr/local/bin/diff-wrapper
362renames = true
Junio C Hamano7ad22dc2007-01-29 02:55:48363
Junio C Hamano48cd3f12019-10-09 05:55:30364; Proxy settings
365[core]
366gitproxy=proxy-command for kernel.org
367gitproxy=default-proxy ; for all the rest
Junio C Hamano7ad22dc2007-01-29 02:55:48368
Junio C Hamano48cd3f12019-10-09 05:55:30369; HTTP
370[http]
371sslVerify
372[http "https://weak.example.com"]
373sslVerify = false
374cookieFile = /tmp/cookie.txt
375------------
Junio C Hamano8eac2682013-09-09 22:35:20376
Junio C Hamano7ad22dc2007-01-29 02:55:48377you can set the filemode to true with
378
379------------
380% git config core.filemode true
381------------
382
383The hypothetical proxy command entries actually have a postfix to discern
384what URL they apply to. Here is how to change the entry for kernel.org
385to "ssh".
386
387------------
388% git config core.gitproxy '"ssh" for kernel.org' 'for kernel.org$'
389------------
390
391This makes sure that only the key/value pair for kernel.org is replaced.
392
393To delete the entry for renames, do
394
395------------
396% git config --unset diff.renames
397------------
398
399If you want to delete an entry for a multivar (like core.gitproxy above),
400you have to provide a regex matching the value of exactly one line.
401
402To query the value for a given key, do
403
404------------
405% git config --get core.filemode
406------------
407
408or
409
410------------
411% git config core.filemode
412------------
413
414or, to query a multivar:
415
416------------
417% git config --get core.gitproxy "for kernel.org$"
418------------
419
420If you want to know all the values for a multivar, do:
421
422------------
423% git config --get-all core.gitproxy
424------------
425
Junio C Hamanoffb4b682008-12-13 07:35:22426If you like to live dangerously, you can replace *all* core.gitproxy by a
Junio C Hamano7ad22dc2007-01-29 02:55:48427new one with
428
429------------
430% git config --replace-all core.gitproxy ssh
431------------
432
433However, if you really only want to replace the line for the default proxy,
434i.e. the one without a "for ..." postfix, do something like this:
435
436------------
437% git config core.gitproxy ssh '! for '
438------------
439
440To actually match only values with an exclamation mark, you have to
441
442------------
443% git config section.key value '[!]'
444------------
445
446To add a new proxy, without altering any of the existing ones, use
447
448------------
Junio C Hamano53850262012-08-29 23:03:49449% git config --add core.gitproxy '"proxy-command" for example.com'
Junio C Hamano7ad22dc2007-01-29 02:55:48450------------
451
Junio C Hamano0c999702007-12-03 09:57:55452An example to use customized color from the configuration in your
453script:
454
455------------
456#!/bin/sh
457WS=$(git config --get-color color.diff.whitespace "blue reverse")
458RESET=$(git config --get-color "" "reset")
459echo "${WS}your whitespace color or blue reverse${RESET}"
460------------
Junio C Hamano7ad22dc2007-01-29 02:55:48461
Junio C Hamano8eac2682013-09-09 22:35:20462For URLs in `https://weak.example.com`, `http.sslVerify` is set to
463false, while it is set to `true` for all others:
464
465------------
Junio C Hamano32a75272018-10-16 07:37:35466% git config --type=bool --get-urlmatch http.sslverify https://good.example.com
Junio C Hamano8eac2682013-09-09 22:35:20467true
Junio C Hamano32a75272018-10-16 07:37:35468% git config --type=bool --get-urlmatch http.sslverify https://weak.example.com
Junio C Hamano8eac2682013-09-09 22:35:20469false
470% git config --get-urlmatch http https://weak.example.com
Junio C Hamano322c6242015-03-23 21:32:46471http.cookieFile /tmp/cookie.txt
Junio C Hamano8eac2682013-09-09 22:35:20472http.sslverify false
473------------
474
Junio C Hamano7ad22dc2007-01-29 02:55:48475include::config.txt[]
476
Junio C Hamano11ae3202018-08-20 20:15:42477BUGS
478----
479When using the deprecated `[section.subsection]` syntax, changing a value
480will result in adding a multi-line key instead of a change, if the subsection
481is given with at least one uppercase character. For example when the config
482looks like
483
484--------
485 [section.subsection]
486 key = value1
487--------
488
489and running `git config section.Subsection.key value2` will result in
490
491--------
492 [section.subsection]
493 key = value1
494 key = value2
495--------
496
497
Junio C Hamano7ad22dc2007-01-29 02:55:48498GIT
499---
Junio C Hamanof7c042d2008-06-06 22:50:53500Part of the linkgit:git[1] suite