| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 1 | git-clean(1) |
| 2 | ============ |
| 3 | |
| 4 | NAME |
| 5 | ---- |
| 6 | git-clean - Remove untracked files from the working tree |
| 7 | |
| 8 | SYNOPSIS |
| 9 | -------- |
| 10 | [verse] |
| Junio C Hamano | 58f587a | 2013-07-22 19:20:59 | [diff] [blame] | 11 | 'git clean' [-d] [-f] [-i] [-n] [-q] [-e <pattern>] [-x | -X] [--] <path>... |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 12 | |
| 13 | DESCRIPTION |
| 14 | ----------- |
| Junio C Hamano | e91ea77 | 2009-04-26 01:41:41 | [diff] [blame] | 15 | |
| Junio C Hamano | bde411d | 2009-05-07 05:07:31 | [diff] [blame] | 16 | Cleans the working tree by recursively removing files that are not |
| 17 | under version control, starting from the current directory. |
| Junio C Hamano | e91ea77 | 2009-04-26 01:41:41 | [diff] [blame] | 18 | |
| Junio C Hamano | 92d8037 | 2016-07-13 22:00:05 | [diff] [blame] | 19 | Normally, only files unknown to Git are removed, but if the `-x` |
| Junio C Hamano | e91ea77 | 2009-04-26 01:41:41 | [diff] [blame] | 20 | option is specified, ignored files are also removed. This can, for |
| 21 | example, be useful to remove all build products. |
| 22 | |
| Junio C Hamano | 9e39507 | 2008-07-31 22:11:21 | [diff] [blame] | 23 | If any optional `<path>...` arguments are given, only those paths |
| 24 | are affected. |
| Junio C Hamano | 26a5737 | 2006-05-10 00:13:40 | [diff] [blame] | 25 | |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 26 | OPTIONS |
| 27 | ------- |
| 28 | -d:: |
| 29 | Remove untracked directories in addition to untracked files. |
| Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 30 | If an untracked directory is managed by a different Git |
| Junio C Hamano | ac34f56 | 2009-08-16 19:04:05 | [diff] [blame] | 31 | repository, it is not removed by default. Use -f option twice |
| 32 | if you really want to remove such a directory. |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 33 | |
| Junio C Hamano | 47b9acd | 2007-04-24 07:34:34 | [diff] [blame] | 34 | -f:: |
| Junio C Hamano | 68cfa3a | 2009-08-30 00:22:55 | [diff] [blame] | 35 | --force:: |
| Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 36 | If the Git configuration variable clean.requireForce is not set |
| Junio C Hamano | 6bf68cf | 2015-03-06 23:46:29 | [diff] [blame] | 37 | to false, 'git clean' will refuse to delete files or directories |
| 38 | unless given -f, -n or -i. Git will refuse to delete directories |
| 39 | with .git sub directory or file unless a second -f |
| Junio C Hamano | f85ef63 | 2016-02-17 22:31:06 | [diff] [blame] | 40 | is given. |
| Junio C Hamano | 58f587a | 2013-07-22 19:20:59 | [diff] [blame] | 41 | |
| 42 | -i:: |
| 43 | --interactive:: |
| 44 | Show what would be done and clean files interactively. See |
| 45 | ``Interactive mode'' for details. |
| Junio C Hamano | 47b9acd | 2007-04-24 07:34:34 | [diff] [blame] | 46 | |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 47 | -n:: |
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 48 | --dry-run:: |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 49 | Don't actually remove anything, just show what would be done. |
| 50 | |
| 51 | -q:: |
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 52 | --quiet:: |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 53 | Be quiet, only report errors, but not the files that are |
| 54 | successfully removed. |
| 55 | |
| Junio C Hamano | 619596a | 2010-08-18 22:15:35 | [diff] [blame] | 56 | -e <pattern>:: |
| 57 | --exclude=<pattern>:: |
| Junio C Hamano | 7bd050f | 2011-09-22 06:32:22 | [diff] [blame] | 58 | In addition to those found in .gitignore (per directory) and |
| 59 | $GIT_DIR/info/exclude, also consider these patterns to be in the |
| 60 | set of the ignore rules in effect. |
| Junio C Hamano | 619596a | 2010-08-18 22:15:35 | [diff] [blame] | 61 | |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 62 | -x:: |
| Junio C Hamano | 7bd050f | 2011-09-22 06:32:22 | [diff] [blame] | 63 | Don't use the standard ignore rules read from .gitignore (per |
| 64 | directory) and $GIT_DIR/info/exclude, but do still use the ignore |
| 65 | rules given with `-e` options. This allows removing all untracked |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 66 | files, including build products. This can be used (possibly in |
| Junio C Hamano | 1aa40d2 | 2010-01-21 17:46:43 | [diff] [blame] | 67 | conjunction with 'git reset') to create a pristine |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 68 | working directory to test a clean build. |
| 69 | |
| 70 | -X:: |
| Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 71 | Remove only files ignored by Git. This may be useful to rebuild |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 72 | everything from scratch, but keep manually created files. |
| 73 | |
| Junio C Hamano | 58f587a | 2013-07-22 19:20:59 | [diff] [blame] | 74 | Interactive mode |
| 75 | ---------------- |
| 76 | When the command enters the interactive mode, it shows the |
| 77 | files and directories to be cleaned, and goes into its |
| 78 | interactive command loop. |
| 79 | |
| 80 | The command loop shows the list of subcommands available, and |
| 81 | gives a prompt "What now> ". In general, when the prompt ends |
| 82 | with a single '>', you can pick only one of the choices given |
| 83 | and type return, like this: |
| 84 | |
| 85 | ------------ |
| 86 | *** Commands *** |
| 87 | 1: clean 2: filter by pattern 3: select by numbers |
| 88 | 4: ask each 5: quit 6: help |
| 89 | What now> 1 |
| 90 | ------------ |
| 91 | |
| 92 | You also could say `c` or `clean` above as long as the choice is unique. |
| 93 | |
| 94 | The main command loop has 6 subcommands. |
| 95 | |
| 96 | clean:: |
| 97 | |
| 98 | Start cleaning files and directories, and then quit. |
| 99 | |
| 100 | filter by pattern:: |
| 101 | |
| 102 | This shows the files and directories to be deleted and issues an |
| Junio C Hamano | fb5ffde | 2014-11-04 22:38:56 | [diff] [blame] | 103 | "Input ignore patterns>>" prompt. You can input space-separated |
| Junio C Hamano | 58f587a | 2013-07-22 19:20:59 | [diff] [blame] | 104 | patterns to exclude files and directories from deletion. |
| 105 | E.g. "*.c *.h" will excludes files end with ".c" and ".h" from |
| 106 | deletion. When you are satisfied with the filtered result, press |
| 107 | ENTER (empty) back to the main menu. |
| 108 | |
| 109 | select by numbers:: |
| 110 | |
| 111 | This shows the files and directories to be deleted and issues an |
| 112 | "Select items to delete>>" prompt. When the prompt ends with double |
| 113 | '>>' like this, you can make more than one selection, concatenated |
| 114 | with whitespace or comma. Also you can say ranges. E.g. "2-5 7,9" |
| 115 | to choose 2,3,4,5,7,9 from the list. If the second number in a |
| Junio C Hamano | ce806e3 | 2013-08-01 20:28:10 | [diff] [blame] | 116 | range is omitted, all remaining items are selected. E.g. "7-" to |
| Junio C Hamano | 58f587a | 2013-07-22 19:20:59 | [diff] [blame] | 117 | choose 7,8,9 from the list. You can say '*' to choose everything. |
| 118 | Also when you are satisfied with the filtered result, press ENTER |
| 119 | (empty) back to the main menu. |
| 120 | |
| 121 | ask each:: |
| 122 | |
| 123 | This will start to clean, and you must confirm one by one in order |
| 124 | to delete items. Please note that this action is not as efficient |
| 125 | as the above two actions. |
| 126 | |
| 127 | quit:: |
| 128 | |
| 129 | This lets you quit without do cleaning. |
| 130 | |
| 131 | help:: |
| 132 | |
| 133 | Show brief usage of interactive git-clean. |
| 134 | |
| Junio C Hamano | 4f07aec | 2012-09-25 19:08:44 | [diff] [blame] | 135 | SEE ALSO |
| 136 | -------- |
| 137 | linkgit:gitignore[5] |
| 138 | |
| Junio C Hamano | 60d0063 | 2006-04-05 10:34:43 | [diff] [blame] | 139 | GIT |
| 140 | --- |
| Junio C Hamano | f7c042d | 2008-06-06 22:50:53 | [diff] [blame] | 141 | Part of the linkgit:git[1] suite |