mirror of
https://github.com/git/git.git
synced 2024-11-24 02:17:02 +08:00
read_sha1_file(): get rid of read_sha1_file_repl() madness
Most callers want to silently get a replacement object, and they do not care what the real name of the replacement object is. Worse yet, no sane interface to return the underlying object without replacement is provided. Remove the function and make only the few callers that want the name of the replacement object find it themselves. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
abb25ac365
commit
4bbf5a2615
@ -23,8 +23,8 @@ static int verify_object(const unsigned char *sha1, const char *expected_type)
|
||||
int ret = -1;
|
||||
enum object_type type;
|
||||
unsigned long size;
|
||||
const unsigned char *repl;
|
||||
void *buffer = read_sha1_file_repl(sha1, &type, &size, &repl);
|
||||
void *buffer = read_sha1_file(sha1, &type, &size);
|
||||
const unsigned char *repl = lookup_replace_object(sha1);
|
||||
|
||||
if (buffer) {
|
||||
if (type == type_from_string(expected_type))
|
||||
|
6
cache.h
6
cache.h
@ -758,11 +758,7 @@ int offset_1st_component(const char *path);
|
||||
|
||||
/* Read and unpack a sha1 file into memory, write memory to a sha1 file */
|
||||
extern int sha1_object_info(const unsigned char *, unsigned long *);
|
||||
extern void *read_sha1_file_repl(const unsigned char *sha1, enum object_type *type, unsigned long *size, const unsigned char **replacement);
|
||||
static inline void *read_sha1_file(const unsigned char *sha1, enum object_type *type, unsigned long *size)
|
||||
{
|
||||
return read_sha1_file_repl(sha1, type, size, NULL);
|
||||
}
|
||||
extern void *read_sha1_file(const unsigned char *sha1, enum object_type *type, unsigned long *size);
|
||||
extern const unsigned char *lookup_replace_object(const unsigned char *sha1);
|
||||
extern int hash_sha1_file(const void *buf, unsigned long len, const char *type, unsigned char *sha1);
|
||||
extern int write_sha1_file(const void *buf, unsigned long len, const char *type, unsigned char *return_sha1);
|
||||
|
4
object.c
4
object.c
@ -188,8 +188,8 @@ struct object *parse_object(const unsigned char *sha1)
|
||||
unsigned long size;
|
||||
enum object_type type;
|
||||
int eaten;
|
||||
const unsigned char *repl;
|
||||
void *buffer = read_sha1_file_repl(sha1, &type, &size, &repl);
|
||||
const unsigned char *repl = lookup_replace_object(sha1);
|
||||
void *buffer = read_sha1_file(sha1, &type, &size);
|
||||
|
||||
if (buffer) {
|
||||
struct object *obj;
|
||||
|
12
sha1_file.c
12
sha1_file.c
@ -2206,10 +2206,9 @@ static void *read_object(const unsigned char *sha1, enum object_type *type,
|
||||
* deal with them should arrange to call read_object() and give error
|
||||
* messages themselves.
|
||||
*/
|
||||
void *read_sha1_file_repl(const unsigned char *sha1,
|
||||
enum object_type *type,
|
||||
unsigned long *size,
|
||||
const unsigned char **replacement)
|
||||
void *read_sha1_file(const unsigned char *sha1,
|
||||
enum object_type *type,
|
||||
unsigned long *size)
|
||||
{
|
||||
const unsigned char *repl = lookup_replace_object(sha1);
|
||||
void *data;
|
||||
@ -2218,11 +2217,8 @@ void *read_sha1_file_repl(const unsigned char *sha1,
|
||||
|
||||
errno = 0;
|
||||
data = read_object(repl, type, size);
|
||||
if (data) {
|
||||
if (replacement)
|
||||
*replacement = repl;
|
||||
if (data)
|
||||
return data;
|
||||
}
|
||||
|
||||
if (errno && errno != ENOENT)
|
||||
die_errno("failed to read object %s", sha1_to_hex(sha1));
|
||||
|
Loading…
Reference in New Issue
Block a user