Hash :
9994cd3f
        
        Author :
  
        
        Date :
2018-06-25T11:56:52
        
      
treewide: remove use of C++ style comments
C++ style comment ("//") are not specified by the ISO C90 standard and
thus do not conform to it. While libgit2 aims to conform to C90, we did
not enforce it until now, which is why quite a lot of these
non-conforming comments have snuck into our codebase. Do a tree-wide
conversion of all C++ style comments to the supported C style comments
to allow us enforcing strict C90 compliance in a later commit.
      
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
#include <git2.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#ifdef _WIN32
# include <io.h>
# include <Windows.h>
# define open _open
# define read _read
# define close _close
#define ssize_t unsigned int
#else
# include <unistd.h>
#endif
#include "common.h"
/*
 * This could be run in the main loop whilst the application waits for
 * the indexing to finish in a worker thread
 */
static int index_cb(const git_transfer_progress *stats, void *data)
{
	(void)data;
	printf("\rProcessing %d of %d", stats->indexed_objects, stats->total_objects);
	return 0;
}
int index_pack(git_repository *repo, int argc, char **argv)
{
	git_indexer *idx;
	git_transfer_progress stats = {0, 0};
	int error;
	char hash[GIT_OID_HEXSZ + 1] = {0};
	int fd;
	ssize_t read_bytes;
	char buf[512];
	(void)repo;
	if (argc < 2) {
		fprintf(stderr, "usage: %s index-pack <packfile>\n", argv[-1]);
		return EXIT_FAILURE;
	}
	if (git_indexer_new(&idx, ".", 0, NULL, NULL, NULL) < 0) {
		puts("bad idx");
		return -1;
	}
	if ((fd = open(argv[1], 0)) < 0) {
		perror("open");
		return -1;
	}
	do {
		read_bytes = read(fd, buf, sizeof(buf));
		if (read_bytes < 0)
			break;
		if ((error = git_indexer_append(idx, buf, read_bytes, &stats)) < 0)
			goto cleanup;
		index_cb(&stats, NULL);
	} while (read_bytes > 0);
	if (read_bytes < 0) {
		error = -1;
		perror("failed reading");
		goto cleanup;
	}
	if ((error = git_indexer_commit(idx, &stats)) < 0)
		goto cleanup;
	printf("\rIndexing %d of %d\n", stats.indexed_objects, stats.total_objects);
	git_oid_fmt(hash, git_indexer_hash(idx));
	puts(hash);
 cleanup:
	close(fd);
	git_indexer_free(idx);
	return error;
}