Significant updates since patch v6 series: * Refactor on patch 4/10: split `list_and_choose` into 3 functions, to make it easy to read. * Mark no public functions as static for patch 1-10. * If set 'pager.clean' to true (i.e. isatty(1) is false), die instead of do cleaning. * New action: flags. The user can update flags for git-clean, such as -x/-d/-X/-ff. * Alway show interactive menu, even there are no files to clean. Because the use can update flags for git-clean. Usage: When the command enters the interactive mode, it shows the files and directories to be cleaned, and goes into its interactive command loop. The command loop shows the list of subcommands available, and gives a prompt "What now> ". In general, when the prompt ends with a single '>', you can pick only one of the choices given and type return, like this: *** Commands *** 1: clean 2: edit by patterns 3: edit by numbers 4: rm -i 5: flags: none 6: quit 7: help What now> 2 You also could say `c` or `clean` above as long as the choice is unique. The main command loop has 7 subcommands. clean:: Start cleaning files and directories, and then quit. edit by patterns:: This shows the files and directories to be deleted and issues an "Input ignore patterns>>" prompt. You can input a space-seperated patterns to exclude files and directories from deletion. E.g. "*.c *.h" will excludes files end with ".c" and ".h" from deletion. When you are satisfied with the filtered result, press ENTER (empty) back to the main menu. edit by numbers:: This shows the files and directories to be deleted and issues an "Select items to delete>>" prompt. When the prompt ends with double '>>' like this, you can make more than one selection, concatenated with whitespace or comma. Also you can say ranges. E.g. "2-5 7,9" to choose 2,3,4,5,7,9 from the list. If the second number in a range is omitted, all remaining patches are taken. E.g. "7-" to choose 7,8,9 from the list. You can say '*' to choose everything. Also when you are satisfied with the filtered result, press ENTER (empty) back to the main menu. rm -i:: This will show a "rm -i" style cleaning, that you must confirm one by one in order to delete items. This action is not as efficient as the above two actions. flags:: This lets you change the flags for git-clean, such as -x/-X/-d/-ff, and refresh the cleaning candidates list automatically. quit:: This lets you quit without do cleaning. help:: Show brief usage of interactive git-clean. Jiang Xin (10): Add support for -i/--interactive to git-clean Show items of interactive git-clean in columns Add colors to interactive git-clean git-clean: use a git-add-interactive compatible UI git-clean: interactive cleaning by select numbers git-clean: rm -i style interactive cleaning git-clean: update document for interactive git-clean git-clean refactor: save some options in clean_flags git-clean refactor: wrap in scan_clean_candidates git-clean: change clean flags in interactive mode Documentation/config.txt | 4 + Documentation/git-clean.txt | 76 +++- builtin/clean.c | 972 ++++++++++++++++++++++++++++++++++++++++---- 3 files changed, 981 insertions(+), 71 deletions(-) -- 1.8.3.rc1.341.g1c24ab7 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html