 50f26bd035
			
		
	
	50f26bd035
	
	
	
		
			
			The commit-graph feature is now on by default, and is being written during 'git gc' by default. Typically, Git only writes a commit-graph when a 'git gc --auto' command passes the gc.auto setting to actualy do work. This means that a commit-graph will typically fall behind the commits that are being used every day. To stay updated with the latest commits, add a step to 'git fetch' to write a commit-graph after fetching new objects. The fetch.writeCommitGraph config setting enables writing a split commit-graph, so on average the cost of writing this file is very small. Occasionally, the commit-graph chain will collapse to a single level, and this could be slow for very large repos. For additional use, adjust the default to be true when feature.experimental is enabled. Signed-off-by: Derrick Stolee <dstolee@microsoft.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "cache.h"
 | |
| #include "config.h"
 | |
| #include "repository.h"
 | |
| 
 | |
| #define UPDATE_DEFAULT_BOOL(s,v) do { if (s == -1) { s = v; } } while(0)
 | |
| 
 | |
| void prepare_repo_settings(struct repository *r)
 | |
| {
 | |
| 	int value;
 | |
| 	char *strval;
 | |
| 
 | |
| 	if (r->settings.initialized)
 | |
| 		return;
 | |
| 
 | |
| 	/* Defaults */
 | |
| 	memset(&r->settings, -1, sizeof(r->settings));
 | |
| 
 | |
| 	if (!repo_config_get_bool(r, "core.commitgraph", &value))
 | |
| 		r->settings.core_commit_graph = value;
 | |
| 	if (!repo_config_get_bool(r, "gc.writecommitgraph", &value))
 | |
| 		r->settings.gc_write_commit_graph = value;
 | |
| 	UPDATE_DEFAULT_BOOL(r->settings.core_commit_graph, 1);
 | |
| 	UPDATE_DEFAULT_BOOL(r->settings.gc_write_commit_graph, 1);
 | |
| 
 | |
| 	if (!repo_config_get_bool(r, "index.version", &value))
 | |
| 		r->settings.index_version = value;
 | |
| 	if (!repo_config_get_maybe_bool(r, "core.untrackedcache", &value)) {
 | |
| 		if (value == 0)
 | |
| 			r->settings.core_untracked_cache = UNTRACKED_CACHE_REMOVE;
 | |
| 		else
 | |
| 			r->settings.core_untracked_cache = UNTRACKED_CACHE_WRITE;
 | |
| 	} else if (!repo_config_get_string(r, "core.untrackedcache", &strval)) {
 | |
| 		if (!strcasecmp(strval, "keep"))
 | |
| 			r->settings.core_untracked_cache = UNTRACKED_CACHE_KEEP;
 | |
| 
 | |
| 		free(strval);
 | |
| 	}
 | |
| 
 | |
| 	if (!repo_config_get_string(r, "fetch.negotiationalgorithm", &strval)) {
 | |
| 		if (!strcasecmp(strval, "skipping"))
 | |
| 			r->settings.fetch_negotiation_algorithm = FETCH_NEGOTIATION_SKIPPING;
 | |
| 		else
 | |
| 			r->settings.fetch_negotiation_algorithm = FETCH_NEGOTIATION_DEFAULT;
 | |
| 	}
 | |
| 
 | |
| 	if (!repo_config_get_bool(r, "pack.usesparse", &value))
 | |
| 		r->settings.pack_use_sparse = value;
 | |
| 	if (!repo_config_get_bool(r, "feature.manyfiles", &value) && value) {
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.index_version, 4);
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.core_untracked_cache, UNTRACKED_CACHE_WRITE);
 | |
| 	}
 | |
| 	if (!repo_config_get_bool(r, "fetch.writecommitgraph", &value))
 | |
| 		r->settings.fetch_write_commit_graph = value;
 | |
| 	if (!repo_config_get_bool(r, "feature.experimental", &value) && value) {
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.pack_use_sparse, 1);
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.fetch_negotiation_algorithm, FETCH_NEGOTIATION_SKIPPING);
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.fetch_write_commit_graph, 1);
 | |
| 	}
 | |
| 	UPDATE_DEFAULT_BOOL(r->settings.fetch_write_commit_graph, 0);
 | |
| 
 | |
| 	/* Hack for test programs like test-dump-untracked-cache */
 | |
| 	if (ignore_untracked_cache_config)
 | |
| 		r->settings.core_untracked_cache = UNTRACKED_CACHE_KEEP;
 | |
| 	else
 | |
| 		UPDATE_DEFAULT_BOOL(r->settings.core_untracked_cache, UNTRACKED_CACHE_KEEP);
 | |
| 
 | |
| 	UPDATE_DEFAULT_BOOL(r->settings.fetch_negotiation_algorithm, FETCH_NEGOTIATION_DEFAULT);
 | |
| }
 |