ls-remote.c 1.32 KB
Newer Older
1
#include "common.h"
2

3
static int use_remote(git_repository *repo, char *name)
4 5 6
{
	git_remote *remote = NULL;
	int error;
7 8
	const git_remote_head **refs;
	size_t refs_len, i;
9
	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT;
10

11
	/* Find the remote by name */
12
	error = git_remote_lookup(&remote, repo, name);
13
	if (error < 0) {
14
		error = git_remote_create_anonymous(&remote, repo, name);
15 16 17 18
		if (error < 0)
			goto cleanup;
	}

19 20 21 22
	/**
	 * Connect to the remote and call the printing function for
	 * each of the remote references.
	 */
23
	callbacks.credentials = cred_acquire_cb;
24

25
	error = git_remote_connect(remote, GIT_DIRECTION_FETCH, &callbacks, NULL, NULL);
26
	if (error < 0)
27 28
		goto cleanup;

29 30 31 32 33 34 35 36 37 38 39 40
	/**
	 * Get the list of references on the remote and print out
	 * their name next to what they point to.
	 */
	if (git_remote_ls(&refs, &refs_len, remote) < 0)
		goto cleanup;

	for (i = 0; i < refs_len; i++) {
		char oid[GIT_OID_HEXSZ + 1] = {0};
		git_oid_fmt(oid, &refs[i]->oid);
		printf("%s\t%s\n", oid, refs[i]->name);
	}
41 42 43 44 45 46

cleanup:
	git_remote_free(remote);
	return error;
}

47
/** Entry point for this command */
48
int lg2_ls_remote(git_repository *repo, int argc, char **argv)
49
{
50
	int error;
51

52 53 54 55 56
	if (argc < 2) {
		fprintf(stderr, "usage: %s ls-remote <remote>\n", argv[-1]);
		return EXIT_FAILURE;
	}

57
	error = use_remote(repo, argv[1]);
58 59 60

	return error;
}