mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-06 17:20:22 +00:00
Load prune configuration when a remote is created.
This commit is contained in:
parent
c4a2fd5c1d
commit
1ef3f0cebb
46
src/remote.c
46
src/remote.c
@ -21,6 +21,7 @@
|
|||||||
#include "push.h"
|
#include "push.h"
|
||||||
|
|
||||||
static int dwim_refspecs(git_vector *out, git_vector *refspecs, git_vector *refs);
|
static int dwim_refspecs(git_vector *out, git_vector *refspecs, git_vector *refs);
|
||||||
|
static int lookup_remote_prune_config(git_remote *remote, git_config *config, const char *name);
|
||||||
|
|
||||||
static int add_refspec_to(git_vector *vector, const char *string, bool is_fetch)
|
static int add_refspec_to(git_vector *vector, const char *string, bool is_fetch)
|
||||||
{
|
{
|
||||||
@ -138,6 +139,7 @@ static int canonicalize_url(git_buf *out, const char *in)
|
|||||||
static int create_internal(git_remote **out, git_repository *repo, const char *name, const char *url, const char *fetch)
|
static int create_internal(git_remote **out, git_repository *repo, const char *name, const char *url, const char *fetch)
|
||||||
{
|
{
|
||||||
git_remote *remote;
|
git_remote *remote;
|
||||||
|
git_config *config;
|
||||||
git_buf canonical_url = GIT_BUF_INIT, fetchbuf = GIT_BUF_INIT;
|
git_buf canonical_url = GIT_BUF_INIT, fetchbuf = GIT_BUF_INIT;
|
||||||
int error = -1;
|
int error = -1;
|
||||||
|
|
||||||
@ -165,6 +167,12 @@ static int create_internal(git_remote **out, git_repository *repo, const char *n
|
|||||||
if (add_refspec(remote, fetch, true) < 0)
|
if (add_refspec(remote, fetch, true) < 0)
|
||||||
goto on_error;
|
goto on_error;
|
||||||
|
|
||||||
|
if ((error = git_repository_config_snapshot(&config, repo)) < 0)
|
||||||
|
goto on_error;
|
||||||
|
|
||||||
|
if (lookup_remote_prune_config(remote, config, name) < 0)
|
||||||
|
goto on_error;
|
||||||
|
|
||||||
/* Move the data over to where the matching functions can find them */
|
/* Move the data over to where the matching functions can find them */
|
||||||
if (dwim_refspecs(&remote->active_refspecs, &remote->refspecs, &remote->refs) < 0)
|
if (dwim_refspecs(&remote->active_refspecs, &remote->refspecs, &remote->refs) < 0)
|
||||||
goto on_error;
|
goto on_error;
|
||||||
@ -181,6 +189,7 @@ static int create_internal(git_remote **out, git_repository *repo, const char *n
|
|||||||
|
|
||||||
on_error:
|
on_error:
|
||||||
git_remote_free(remote);
|
git_remote_free(remote);
|
||||||
|
git_config_free(config);
|
||||||
git_buf_free(&fetchbuf);
|
git_buf_free(&fetchbuf);
|
||||||
git_buf_free(&canonical_url);
|
git_buf_free(&canonical_url);
|
||||||
return error;
|
return error;
|
||||||
@ -444,7 +453,30 @@ int git_remote_lookup(git_remote **out, git_repository *repo, const char *name)
|
|||||||
if (download_tags_value(remote, config) < 0)
|
if (download_tags_value(remote, config) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
git_buf_clear(&buf);
|
if ((error = lookup_remote_prune_config(remote, config, name)) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
/* Move the data over to where the matching functions can find them */
|
||||||
|
if (dwim_refspecs(&remote->active_refspecs, &remote->refspecs, &remote->refs) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
*out = remote;
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
git_config_free(config);
|
||||||
|
git_buf_free(&buf);
|
||||||
|
|
||||||
|
if (error < 0)
|
||||||
|
git_remote_free(remote);
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lookup_remote_prune_config(git_remote *remote, git_config *config, const char *name)
|
||||||
|
{
|
||||||
|
git_buf buf = GIT_BUF_INIT;
|
||||||
|
int error = 0;
|
||||||
|
|
||||||
git_buf_printf(&buf, "remote.%s.prune", name);
|
git_buf_printf(&buf, "remote.%s.prune", name);
|
||||||
|
|
||||||
if ((error = git_config_get_bool(&remote->prune_refs, config, git_buf_cstr(&buf))) < 0) {
|
if ((error = git_config_get_bool(&remote->prune_refs, config, git_buf_cstr(&buf))) < 0) {
|
||||||
@ -460,19 +492,7 @@ int git_remote_lookup(git_remote **out, git_repository *repo, const char *name)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Move the data over to where the matching functions can find them */
|
|
||||||
if (dwim_refspecs(&remote->active_refspecs, &remote->refspecs, &remote->refs) < 0)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
*out = remote;
|
|
||||||
|
|
||||||
cleanup:
|
|
||||||
git_config_free(config);
|
|
||||||
git_buf_free(&buf);
|
git_buf_free(&buf);
|
||||||
|
|
||||||
if (error < 0)
|
|
||||||
git_remote_free(remote);
|
|
||||||
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -481,3 +481,47 @@ void test_network_fetchlocal__call_progress(void)
|
|||||||
git_remote_free(remote);
|
git_remote_free(remote);
|
||||||
git_repository_free(repo);
|
git_repository_free(repo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_network_fetchlocal__prune_load_remote_prune_config(void)
|
||||||
|
{
|
||||||
|
git_repository *repo;
|
||||||
|
git_remote *origin;
|
||||||
|
git_config *config;
|
||||||
|
git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");
|
||||||
|
const char *url = cl_git_path_url(git_repository_path(remote_repo));
|
||||||
|
|
||||||
|
cl_set_cleanup(&cleanup_local_repo, "foo");
|
||||||
|
cl_git_pass(git_repository_init(&repo, "foo", true));
|
||||||
|
|
||||||
|
cl_git_pass(git_repository_config(&config, repo));
|
||||||
|
cl_git_pass(git_config_set_bool(config, "remote.origin.prune", 1));
|
||||||
|
|
||||||
|
cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url));
|
||||||
|
cl_assert_equal_i(1, git_remote_prune_refs(origin));
|
||||||
|
|
||||||
|
git_config_free(config);
|
||||||
|
git_remote_free(origin);
|
||||||
|
git_repository_free(repo);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_network_fetchlocal__prune_load_fetch_prune_config(void)
|
||||||
|
{
|
||||||
|
git_repository *repo;
|
||||||
|
git_remote *origin;
|
||||||
|
git_config *config;
|
||||||
|
git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");
|
||||||
|
const char *url = cl_git_path_url(git_repository_path(remote_repo));
|
||||||
|
|
||||||
|
cl_set_cleanup(&cleanup_local_repo, "foo");
|
||||||
|
cl_git_pass(git_repository_init(&repo, "foo", true));
|
||||||
|
|
||||||
|
cl_git_pass(git_repository_config(&config, repo));
|
||||||
|
cl_git_pass(git_config_set_bool(config, "fetch.prune", 1));
|
||||||
|
|
||||||
|
cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url));
|
||||||
|
cl_assert_equal_i(1, git_remote_prune_refs(origin));
|
||||||
|
|
||||||
|
git_config_free(config);
|
||||||
|
git_remote_free(origin);
|
||||||
|
git_repository_free(repo);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user