#include "cache.h"
#include "tag.h"
#include "commit.h"
+#include "repository.h"
#include "object-store.h"
#include "pkt-line.h"
#include "utf8.h"
return parse_timestamp(dateptr, NULL, 10);
}
-static struct commit_graft **commit_graft;
-static int commit_graft_alloc, commit_graft_nr;
-
static const unsigned char *commit_graft_sha1_access(size_t index, void *table)
{
struct commit_graft **commit_graft_table = table;
static int commit_graft_pos(const unsigned char *sha1)
{
- return sha1_pos(sha1, commit_graft, commit_graft_nr,
+ return sha1_pos(sha1, the_repository->parsed_objects->grafts,
+ the_repository->parsed_objects->grafts_nr,
commit_graft_sha1_access);
}
if (ignore_dups)
free(graft);
else {
- free(commit_graft[pos]);
- commit_graft[pos] = graft;
+ free(the_repository->parsed_objects->grafts[pos]);
+ the_repository->parsed_objects->grafts[pos] = graft;
}
return 1;
}
pos = -pos - 1;
- ALLOC_GROW(commit_graft, commit_graft_nr + 1, commit_graft_alloc);
- commit_graft_nr++;
- if (pos < commit_graft_nr)
- MOVE_ARRAY(commit_graft + pos + 1, commit_graft + pos,
- commit_graft_nr - pos - 1);
- commit_graft[pos] = graft;
+ ALLOC_GROW(the_repository->parsed_objects->grafts,
+ the_repository->parsed_objects->grafts_nr + 1,
+ the_repository->parsed_objects->grafts_alloc);
+ the_repository->parsed_objects->grafts_nr++;
+ if (pos < the_repository->parsed_objects->grafts_nr)
+ memmove(the_repository->parsed_objects->grafts + pos + 1,
+ the_repository->parsed_objects->grafts + pos,
+ (the_repository->parsed_objects->grafts_nr - pos - 1) *
+ sizeof(*the_repository->parsed_objects->grafts));
+ the_repository->parsed_objects->grafts[pos] = graft;
return 0;
}
pos = commit_graft_pos(oid->hash);
if (pos < 0)
return NULL;
- return commit_graft[pos];
+ return the_repository->parsed_objects->grafts[pos];
}
int for_each_commit_graft(each_commit_graft_fn fn, void *cb_data)
{
int i, ret;
- for (i = ret = 0; i < commit_graft_nr && !ret; i++)
- ret = fn(commit_graft[i], cb_data);
+ for (i = ret = 0; i < the_repository->parsed_objects->grafts_nr && !ret; i++)
+ ret = fn(the_repository->parsed_objects->grafts[i], cb_data);
return ret;
}
int pos = commit_graft_pos(oid->hash);
if (pos < 0)
return -1;
- if (pos + 1 < commit_graft_nr)
- MOVE_ARRAY(commit_graft + pos, commit_graft + pos + 1,
- commit_graft_nr - pos - 1);
- commit_graft_nr--;
+ if (pos + 1 < the_repository->parsed_objects->grafts_nr)
+ MOVE_ARRAY(the_repository->parsed_objects->grafts + pos,
+ the_repository->parsed_objects->grafts + pos + 1,
+ the_repository->parsed_objects->grafts_nr - pos - 1);
+ the_repository->parsed_objects->grafts_nr--;
return 0;
}