 e3f1da982e
			
		
	
	e3f1da982e
	
	
	
		
			
			Continue where ae021d87 (use skip_prefix to avoid magic numbers) left off
and use skip_prefix() in more places for determining the lengths of prefix
strings to avoid using dependent constants and other indirect methods.
Signed-off-by: Rene Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			42 lines
		
	
	
		
			980 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			980 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2005, 2006 Rene Scharfe
 | |
|  */
 | |
| #include "cache.h"
 | |
| #include "commit.h"
 | |
| #include "tar.h"
 | |
| #include "builtin.h"
 | |
| #include "quote.h"
 | |
| 
 | |
| static const char builtin_get_tar_commit_id_usage[] =
 | |
| "git get-tar-commit-id < <tarfile>";
 | |
| 
 | |
| /* ustar header + extended global header content */
 | |
| #define RECORDSIZE	(512)
 | |
| #define HEADERSIZE (2 * RECORDSIZE)
 | |
| 
 | |
| int cmd_get_tar_commit_id(int argc, const char **argv, const char *prefix)
 | |
| {
 | |
| 	char buffer[HEADERSIZE];
 | |
| 	struct ustar_header *header = (struct ustar_header *)buffer;
 | |
| 	char *content = buffer + RECORDSIZE;
 | |
| 	const char *comment;
 | |
| 	ssize_t n;
 | |
| 
 | |
| 	if (argc != 1)
 | |
| 		usage(builtin_get_tar_commit_id_usage);
 | |
| 
 | |
| 	n = read_in_full(0, buffer, HEADERSIZE);
 | |
| 	if (n < HEADERSIZE)
 | |
| 		die("git get-tar-commit-id: read error");
 | |
| 	if (header->typeflag[0] != 'g')
 | |
| 		return 1;
 | |
| 	if (!skip_prefix(content, "52 comment=", &comment))
 | |
| 		return 1;
 | |
| 
 | |
| 	n = write_in_full(1, comment, 41);
 | |
| 	if (n < 41)
 | |
| 		die_errno("git get-tar-commit-id: write error");
 | |
| 
 | |
| 	return 0;
 | |
| }
 |