Commit 0ab3a2ab by Ben Straub

Deploy GIT_INIT_STRUCTURE

parent c7231c45
...@@ -225,12 +225,10 @@ static int retrieve_symlink_caps(git_repository *repo, bool *can_symlink) ...@@ -225,12 +225,10 @@ static int retrieve_symlink_caps(git_repository *repo, bool *can_symlink)
static void normalize_options( static void normalize_options(
git_checkout_opts *normalized, git_checkout_opts *proposed) git_checkout_opts *normalized, git_checkout_opts *proposed)
{ {
git_checkout_opts init_opts = GIT_CHECKOUT_OPTS_INIT;
assert(normalized); assert(normalized);
if (!proposed) if (!proposed)
memmove(normalized, &init_opts, sizeof(git_checkout_opts)); GIT_INIT_STRUCTURE(normalized, GIT_CHECKOUT_OPTS_VERSION);
else else
memmove(normalized, proposed, sizeof(git_checkout_opts)); memmove(normalized, proposed, sizeof(git_checkout_opts));
......
...@@ -82,6 +82,16 @@ GIT_INLINE(bool) giterr__check_version(const void *structure, unsigned int expec ...@@ -82,6 +82,16 @@ GIT_INLINE(bool) giterr__check_version(const void *structure, unsigned int expec
} }
#define GITERR_CHECK_VERSION(S,V,N) if (!giterr__check_version(S,V,N)) return -1 #define GITERR_CHECK_VERSION(S,V,N) if (!giterr__check_version(S,V,N)) return -1
/**
* Initialize a structure with a version.
*/
GIT_INLINE(void) git__init_structure(void *structure, size_t len, unsigned int version)
{
memset(structure, 0, len);
*((int*)structure) = version;
}
#define GIT_INIT_STRUCTURE(S,V) git__init_structure(S, sizeof(*S), V)
/* NOTE: other giterr functions are in the public errors.h header file */ /* NOTE: other giterr functions are in the public errors.h header file */
#include "util.h" #include "util.h"
......
GIT_INLINE(void) reset_checkout_opts(git_checkout_opts *opts)
{
git_checkout_opts init_opts = GIT_CHECKOUT_OPTS_INIT;
memmove(opts, &init_opts, sizeof(git_checkout_opts));
}
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
#include "git2/checkout.h" #include "git2/checkout.h"
#include "repository.h" #include "repository.h"
#include "checkout_util.h"
static git_repository *g_repo; static git_repository *g_repo;
static git_checkout_opts g_opts; static git_checkout_opts g_opts;
...@@ -26,7 +25,7 @@ void test_checkout_index__initialize(void) ...@@ -26,7 +25,7 @@ void test_checkout_index__initialize(void)
{ {
git_tree *tree; git_tree *tree;
reset_checkout_opts(&g_opts); GIT_INIT_STRUCTURE(&g_opts, GIT_CHECKOUT_OPTS_VERSION);
g_opts.checkout_strategy = GIT_CHECKOUT_SAFE; g_opts.checkout_strategy = GIT_CHECKOUT_SAFE;
g_repo = cl_git_sandbox_init("testrepo"); g_repo = cl_git_sandbox_init("testrepo");
...@@ -67,7 +66,7 @@ void test_checkout_index__cannot_checkout_a_bare_repository(void) ...@@ -67,7 +66,7 @@ void test_checkout_index__cannot_checkout_a_bare_repository(void)
{ {
test_checkout_index__cleanup(); test_checkout_index__cleanup();
reset_checkout_opts(&g_opts); GIT_INIT_STRUCTURE(&g_opts, GIT_CHECKOUT_OPTS_VERSION);
g_repo = cl_git_sandbox_init("testrepo.git"); g_repo = cl_git_sandbox_init("testrepo.git");
cl_git_fail(git_checkout_index(g_repo, NULL, NULL)); cl_git_fail(git_checkout_index(g_repo, NULL, NULL));
......
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
#include "git2/checkout.h" #include "git2/checkout.h"
#include "repository.h" #include "repository.h"
#include "checkout_util.h"
static git_repository *g_repo; static git_repository *g_repo;
static git_checkout_opts g_opts; static git_checkout_opts g_opts;
...@@ -12,7 +11,7 @@ void test_checkout_tree__initialize(void) ...@@ -12,7 +11,7 @@ void test_checkout_tree__initialize(void)
{ {
g_repo = cl_git_sandbox_init("testrepo"); g_repo = cl_git_sandbox_init("testrepo");
reset_checkout_opts(&g_opts); GIT_INIT_STRUCTURE(&g_opts, GIT_CHECKOUT_OPTS_VERSION);
g_opts.checkout_strategy = GIT_CHECKOUT_SAFE; g_opts.checkout_strategy = GIT_CHECKOUT_SAFE;
} }
......
...@@ -12,7 +12,7 @@ void test_diff_blob__initialize(void) ...@@ -12,7 +12,7 @@ void test_diff_blob__initialize(void)
g_repo = cl_git_sandbox_init("attr"); g_repo = cl_git_sandbox_init("attr");
reset_diff_opts(&opts); GIT_INIT_STRUCTURE(&opts, GIT_DIFF_OPTIONS_VERSION);
opts.context_lines = 1; opts.context_lines = 1;
opts.interhunk_lines = 0; opts.interhunk_lines = 0;
......
...@@ -49,9 +49,3 @@ extern int diff_foreach_via_iterator( ...@@ -49,9 +49,3 @@ extern int diff_foreach_via_iterator(
extern void diff_print(FILE *fp, git_diff_list *diff); extern void diff_print(FILE *fp, git_diff_list *diff);
GIT_INLINE(void) reset_diff_opts(git_diff_options *opts)
{
git_diff_options init = GIT_DIFF_OPTIONS_INIT;
memmove(opts, &init, sizeof(init));
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment