|
|
|
#ifndef REFS_H
|
|
|
|
#define REFS_H
|
|
|
|
|
|
|
|
struct ref_lock {
|
Enable the packed refs file format
This actually "turns on" the packed ref file format, now that the
infrastructure to do so sanely exists (ie notably the change to make the
reference reading logic take refnames rather than pathnames to the loose
objects that no longer necessarily even exist).
In particular, when the ref lookup hits a refname that has no loose file
associated with it, it falls back on the packed-ref information. Also, the
ref-locking code, while still using a loose file for the locking itself
(and _creating_ a loose file for the new ref) no longer requires that the
old ref be in such an unpacked state.
Finally, this does a minimal hack to git-checkout.sh to rather than check
the ref-file directly, do a "git-rev-parse" on the "heads/$refname".
That's not really wonderful - we should rather really have a special
routine to verify the names as proper branch head names, but it is a
workable solution for now.
With this, I can literally do something like
git pack-refs
find .git/refs -type f -print0 | xargs -0 rm -f --
and the end result is a largely working repository (ie I've done two
commits - which creates _one_ unpacked ref file - done things like run
"gitk" and "git log" etc, and it all looks ok).
There are probably things missing, but I'm hoping that the missing things
are now of the "small and obvious" kind, and that somebody else might want
to start looking at this too. Hint hint ;)
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
19 years ago
|
|
|
char *ref_name;
|
|
|
|
char *log_file;
|
|
|
|
struct lock_file *lk;
|
|
|
|
unsigned char old_sha1[20];
|
|
|
|
int lock_fd;
|
|
|
|
int force_write;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define REF_ISSYMREF 01
|
|
|
|
#define REF_ISPACKED 02
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Calls the specified function for each ref file until it returns nonzero,
|
|
|
|
* and returns the value
|
|
|
|
*/
|
|
|
|
typedef int each_ref_fn(const char *refname, const unsigned char *sha1, int flags, void *cb_data);
|
|
|
|
extern int head_ref(each_ref_fn, void *);
|
|
|
|
extern int for_each_ref(each_ref_fn, void *);
|
|
|
|
extern int for_each_tag_ref(each_ref_fn, void *);
|
|
|
|
extern int for_each_branch_ref(each_ref_fn, void *);
|
|
|
|
extern int for_each_remote_ref(each_ref_fn, void *);
|
|
|
|
|
|
|
|
extern int peel_ref(const char *, unsigned char *);
|
|
|
|
|
|
|
|
/** Reads the refs file specified into sha1 **/
|
|
|
|
extern int get_ref_sha1(const char *ref, unsigned char *sha1);
|
|
|
|
|
|
|
|
/** Locks a "refs/" ref returning the lock on success and NULL on failure. **/
|
|
|
|
extern struct ref_lock *lock_ref_sha1(const char *ref, const unsigned char *old_sha1);
|
|
|
|
|
|
|
|
/** Locks any ref (for 'HEAD' type refs). */
|
|
|
|
extern struct ref_lock *lock_any_ref_for_update(const char *ref, const unsigned char *old_sha1);
|
|
|
|
|
|
|
|
/** Release any lock taken but not written. **/
|
|
|
|
extern void unlock_ref(struct ref_lock *lock);
|
|
|
|
|
|
|
|
/** Writes sha1 into the ref specified by the lock. **/
|
|
|
|
extern int write_ref_sha1(struct ref_lock *lock, const unsigned char *sha1, const char *msg);
|
|
|
|
|
|
|
|
/** Reads log for the value of ref during at_time. **/
|
|
|
|
extern int read_ref_at(const char *ref, unsigned long at_time, int cnt, unsigned char *sha1);
|
|
|
|
|
|
|
|
/** Returns 0 if target has the right format for a ref. **/
|
|
|
|
extern int check_ref_format(const char *target);
|
|
|
|
|
|
|
|
/** rename ref, return 0 on success **/
|
|
|
|
extern int rename_ref(const char *oldref, const char *newref, const char *logmsg);
|
|
|
|
|
|
|
|
#endif /* REFS_H */
|