 9b6606f43d
			
		
	
	9b6606f43d
	
	
	
		
			
			Introduce an extension to the commit-graph to make it efficient to check for the paths that were modified at each commit using Bloom filters. * gs/commit-graph-path-filter: bloom: ignore renames when computing changed paths commit-graph: add GIT_TEST_COMMIT_GRAPH_CHANGED_PATHS test flag t4216: add end to end tests for git log with Bloom filters revision.c: add trace2 stats around Bloom filter usage revision.c: use Bloom filters to speed up path based revision walks commit-graph: add --changed-paths option to write subcommand commit-graph: reuse existing Bloom filters during write commit-graph: write Bloom filters to commit graph file commit-graph: examine commits by generation number commit-graph: examine changed-path objects in pack order commit-graph: compute Bloom filters for changed paths diff: halt tree-diff early after max_changes bloom.c: core Bloom filter implementation for changed paths. bloom.c: introduce core Bloom filter constructs bloom.c: add the murmur3 hash implementation commit-graph: define and use MAX_NUM_CHUNKS
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "test-tool.h"
 | |
| #include "cache.h"
 | |
| #include "commit-graph.h"
 | |
| #include "repository.h"
 | |
| #include "object-store.h"
 | |
| 
 | |
| int cmd__read_graph(int argc, const char **argv)
 | |
| {
 | |
| 	struct commit_graph *graph = NULL;
 | |
| 	struct object_directory *odb;
 | |
| 
 | |
| 	setup_git_directory();
 | |
| 	odb = the_repository->objects->odb;
 | |
| 
 | |
| 	graph = read_commit_graph_one(the_repository, odb);
 | |
| 	if (!graph)
 | |
| 		return 1;
 | |
| 
 | |
| 
 | |
| 	printf("header: %08x %d %d %d %d\n",
 | |
| 		ntohl(*(uint32_t*)graph->data),
 | |
| 		*(unsigned char*)(graph->data + 4),
 | |
| 		*(unsigned char*)(graph->data + 5),
 | |
| 		*(unsigned char*)(graph->data + 6),
 | |
| 		*(unsigned char*)(graph->data + 7));
 | |
| 	printf("num_commits: %u\n", graph->num_commits);
 | |
| 	printf("chunks:");
 | |
| 
 | |
| 	if (graph->chunk_oid_fanout)
 | |
| 		printf(" oid_fanout");
 | |
| 	if (graph->chunk_oid_lookup)
 | |
| 		printf(" oid_lookup");
 | |
| 	if (graph->chunk_commit_data)
 | |
| 		printf(" commit_metadata");
 | |
| 	if (graph->chunk_extra_edges)
 | |
| 		printf(" extra_edges");
 | |
| 	if (graph->chunk_bloom_indexes)
 | |
| 		printf(" bloom_indexes");
 | |
| 	if (graph->chunk_bloom_data)
 | |
| 		printf(" bloom_data");
 | |
| 	printf("\n");
 | |
| 
 | |
| 	UNLEAK(graph);
 | |
| 
 | |
| 	return 0;
 | |
| }
 |