Make gc a builtin.
Signed-off-by: James Bowes <jbowes@dangerouslyinc.com> Signed-off-by: Junio C Hamano <junkio@cox.net>maint
							parent
							
								
									1589e0517f
								
							
						
					
					
						commit
						6757ada403
					
				
							
								
								
									
										3
									
								
								Makefile
								
								
								
								
							
							
						
						
									
										3
									
								
								Makefile
								
								
								
								
							|  | @ -177,7 +177,7 @@ BASIC_LDFLAGS = | ||||||
| SCRIPT_SH = \ | SCRIPT_SH = \ | ||||||
| 	git-bisect.sh git-checkout.sh \ | 	git-bisect.sh git-checkout.sh \ | ||||||
| 	git-clean.sh git-clone.sh git-commit.sh \ | 	git-clean.sh git-clone.sh git-commit.sh \ | ||||||
| 	git-fetch.sh git-gc.sh \ | 	git-fetch.sh \ | ||||||
| 	git-ls-remote.sh \ | 	git-ls-remote.sh \ | ||||||
| 	git-merge-one-file.sh git-mergetool.sh git-parse-remote.sh \ | 	git-merge-one-file.sh git-mergetool.sh git-parse-remote.sh \ | ||||||
| 	git-pull.sh git-rebase.sh \ | 	git-pull.sh git-rebase.sh \ | ||||||
|  | @ -297,6 +297,7 @@ BUILTIN_OBJS = \ | ||||||
| 	builtin-fmt-merge-msg.o \ | 	builtin-fmt-merge-msg.o \ | ||||||
| 	builtin-for-each-ref.o \ | 	builtin-for-each-ref.o \ | ||||||
| 	builtin-fsck.o \ | 	builtin-fsck.o \ | ||||||
|  | 	builtin-gc.o \ | ||||||
| 	builtin-grep.o \ | 	builtin-grep.o \ | ||||||
| 	builtin-init-db.o \ | 	builtin-init-db.o \ | ||||||
| 	builtin-log.o \ | 	builtin-log.o \ | ||||||
|  |  | ||||||
|  | @ -0,0 +1,78 @@ | ||||||
|  | /* | ||||||
|  |  * git gc builtin command | ||||||
|  |  * | ||||||
|  |  * Cleanup unreachable files and optimize the repository. | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 2007 James Bowes | ||||||
|  |  * | ||||||
|  |  * Based on git-gc.sh, which is | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 2006 Shawn O. Pearce | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include "cache.h" | ||||||
|  | #include "run-command.h" | ||||||
|  |  | ||||||
|  | #define FAILED_RUN "failed to run %s" | ||||||
|  |  | ||||||
|  | static const char builtin_gc_usage[] = "git-gc [--prune]"; | ||||||
|  |  | ||||||
|  | static int pack_refs = -1; | ||||||
|  |  | ||||||
|  | static const char *argv_pack_refs[] = {"pack-refs", "--prune", NULL}; | ||||||
|  | static const char *argv_reflog[] = {"reflog", "expire", "--all", NULL}; | ||||||
|  | static const char *argv_repack[] = {"repack", "-a", "-d", "-l", NULL}; | ||||||
|  | static const char *argv_prune[] = {"prune", NULL}; | ||||||
|  | static const char *argv_rerere[] = {"rerere", "gc", NULL}; | ||||||
|  |  | ||||||
|  | static int gc_config(const char *var, const char *value) | ||||||
|  | { | ||||||
|  | 	if (!strcmp(var, "gc.packrefs")) { | ||||||
|  | 		if (!strcmp(value, "notbare")) | ||||||
|  | 			pack_refs = -1; | ||||||
|  | 		else | ||||||
|  | 			pack_refs = git_config_bool(var, value); | ||||||
|  | 		return 0; | ||||||
|  | 	} | ||||||
|  | 	return git_default_config(var, value); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int cmd_gc(int argc, const char **argv, const char *prefix) | ||||||
|  | { | ||||||
|  | 	int i; | ||||||
|  | 	int prune = 0; | ||||||
|  |  | ||||||
|  | 	git_config(gc_config); | ||||||
|  |  | ||||||
|  | 	if (pack_refs < 0) | ||||||
|  | 		pack_refs = !is_bare_repository(); | ||||||
|  |  | ||||||
|  | 	for (i = 1; i < argc; i++) { | ||||||
|  | 		const char *arg = argv[i]; | ||||||
|  | 		if (!strcmp(arg, "--prune")) { | ||||||
|  | 			prune = 1; | ||||||
|  | 			continue; | ||||||
|  | 		} | ||||||
|  | 		/* perhaps other parameters later... */ | ||||||
|  | 		break; | ||||||
|  | 	} | ||||||
|  | 	if (i != argc) | ||||||
|  | 		usage(builtin_gc_usage); | ||||||
|  |  | ||||||
|  | 	if (pack_refs && run_command_v_opt(argv_pack_refs, RUN_GIT_CMD)) | ||||||
|  | 		return error(FAILED_RUN, argv_pack_refs[0]); | ||||||
|  |  | ||||||
|  | 	if (run_command_v_opt(argv_reflog, RUN_GIT_CMD)) | ||||||
|  | 		return error(FAILED_RUN, argv_reflog[0]); | ||||||
|  |  | ||||||
|  | 	if (run_command_v_opt(argv_repack, RUN_GIT_CMD)) | ||||||
|  | 		return error(FAILED_RUN, argv_repack[0]); | ||||||
|  |  | ||||||
|  | 	if (prune && run_command_v_opt(argv_prune, RUN_GIT_CMD)) | ||||||
|  | 		return error(FAILED_RUN, argv_prune[0]); | ||||||
|  |  | ||||||
|  | 	if (run_command_v_opt(argv_rerere, RUN_GIT_CMD)) | ||||||
|  | 		return error(FAILED_RUN, argv_rerere[0]); | ||||||
|  |  | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | @ -37,6 +37,7 @@ extern int cmd_fmt_merge_msg(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_for_each_ref(int argc, const char **argv, const char *prefix); | extern int cmd_for_each_ref(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_format_patch(int argc, const char **argv, const char *prefix); | extern int cmd_format_patch(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_fsck(int argc, const char **argv, const char *prefix); | extern int cmd_fsck(int argc, const char **argv, const char *prefix); | ||||||
|  | extern int cmd_gc(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_get_tar_commit_id(int argc, const char **argv, const char *prefix); | extern int cmd_get_tar_commit_id(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_grep(int argc, const char **argv, const char *prefix); | extern int cmd_grep(int argc, const char **argv, const char *prefix); | ||||||
| extern int cmd_help(int argc, const char **argv, const char *prefix); | extern int cmd_help(int argc, const char **argv, const char *prefix); | ||||||
|  |  | ||||||
							
								
								
									
										1
									
								
								git.c
								
								
								
								
							
							
						
						
									
										1
									
								
								git.c
								
								
								
								
							|  | @ -249,6 +249,7 @@ static void handle_internal_command(int argc, const char **argv, char **envp) | ||||||
| 		{ "format-patch", cmd_format_patch, RUN_SETUP }, | 		{ "format-patch", cmd_format_patch, RUN_SETUP }, | ||||||
| 		{ "fsck", cmd_fsck, RUN_SETUP }, | 		{ "fsck", cmd_fsck, RUN_SETUP }, | ||||||
| 		{ "fsck-objects", cmd_fsck, RUN_SETUP }, | 		{ "fsck-objects", cmd_fsck, RUN_SETUP }, | ||||||
|  | 		{ "gc", cmd_gc, RUN_SETUP }, | ||||||
| 		{ "get-tar-commit-id", cmd_get_tar_commit_id }, | 		{ "get-tar-commit-id", cmd_get_tar_commit_id }, | ||||||
| 		{ "grep", cmd_grep, RUN_SETUP | USE_PAGER }, | 		{ "grep", cmd_grep, RUN_SETUP | USE_PAGER }, | ||||||
| 		{ "help", cmd_help }, | 		{ "help", cmd_help }, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 James Bowes
						James Bowes