diff options
| author | Michael Haggerty <mhagger@alum.mit.edu> | 2014-02-28 17:29:16 +0100 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-02-28 13:17:56 -0800 | 
| commit | 1f91e79cf61eaa7cb26eb0aa1e257b7681c4c328 (patch) | |
| tree | 181d07d3f639afa87294ea0f35ebb9ce363a21a7 | |
| parent | afc711b8e1ee89626f0dddf0ef01fb73168d47ca (diff) | |
| download | git-1f91e79cf61eaa7cb26eb0aa1e257b7681c4c328.tar.gz | |
Add docstrings for lookup_replace_object() and do_lookup_replace_object()
Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | cache.h | 13 | ||||
| -rw-r--r-- | replace_object.c | 7 | 
2 files changed, 20 insertions, 0 deletions
| @@ -798,13 +798,26 @@ static inline void *read_sha1_file(const unsigned char *sha1, enum object_type *  {  	return read_sha1_file_extended(sha1, type, size, LOOKUP_REPLACE_OBJECT);  } + +/* + * This internal function is only declared here for the benefit of + * lookup_replace_object().  Please do not call it directly. + */  extern const unsigned char *do_lookup_replace_object(const unsigned char *sha1); + +/* + * If object sha1 should be replaced, return the replacement object's + * name (replaced recursively, if necessary).  The return value is + * either sha1 or a pointer to a permanently-allocated value.  When + * object replacement is suppressed, always return sha1. + */  static inline const unsigned char *lookup_replace_object(const unsigned char *sha1)  {  	if (!check_replace_refs)  		return sha1;  	return do_lookup_replace_object(sha1);  } +  static inline const unsigned char *lookup_replace_object_extended(const unsigned char *sha1, unsigned flag)  {  	if (!(flag & LOOKUP_REPLACE_OBJECT)) diff --git a/replace_object.c b/replace_object.c index c5cf9f4467..31fabde72b 100644 --- a/replace_object.c +++ b/replace_object.c @@ -92,6 +92,13 @@ static void prepare_replace_object(void)  /* We allow "recursive" replacement. Only within reason, though */  #define MAXREPLACEDEPTH 5 +/* + * If a replacement for object sha1 has been set up, return the + * replacement object's name (replaced recursively, if necessary). + * The return value is either sha1 or a pointer to a + * permanently-allocated value.  This function always respects replace + * references, regardless of the value of check_replace_refs. + */  const unsigned char *do_lookup_replace_object(const unsigned char *sha1)  {  	int pos, depth = MAXREPLACEDEPTH; | 
