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;
|
int ret = -1;
|
||||||
enum object_type type;
|
enum object_type type;
|
||||||
unsigned long size;
|
unsigned long size;
|
||||||
const unsigned char *repl;
|
void *buffer = read_sha1_file(sha1, &type, &size);
|
||||||
void *buffer = read_sha1_file_repl(sha1, &type, &size, &repl);
|
const unsigned char *repl = lookup_replace_object(sha1);
|
||||||
|
|
||||||
if (buffer) {
|
if (buffer) {
|
||||||
if (type == type_from_string(expected_type))
|
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 */
|
/* 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 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);
|
extern void *read_sha1_file(const unsigned char *sha1, enum object_type *type, unsigned long *size);
|
||||||
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 const unsigned char *lookup_replace_object(const unsigned char *sha1);
|
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 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);
|
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;
|
unsigned long size;
|
||||||
enum object_type type;
|
enum object_type type;
|
||||||
int eaten;
|
int eaten;
|
||||||
const unsigned char *repl;
|
const unsigned char *repl = lookup_replace_object(sha1);
|
||||||
void *buffer = read_sha1_file_repl(sha1, &type, &size, &repl);
|
void *buffer = read_sha1_file(sha1, &type, &size);
|
||||||
|
|
||||||
if (buffer) {
|
if (buffer) {
|
||||||
struct object *obj;
|
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
|
* deal with them should arrange to call read_object() and give error
|
||||||
* messages themselves.
|
* messages themselves.
|
||||||
*/
|
*/
|
||||||
void *read_sha1_file_repl(const unsigned char *sha1,
|
void *read_sha1_file(const unsigned char *sha1,
|
||||||
enum object_type *type,
|
enum object_type *type,
|
||||||
unsigned long *size,
|
unsigned long *size)
|
||||||
const unsigned char **replacement)
|
|
||||||
{
|
{
|
||||||
const unsigned char *repl = lookup_replace_object(sha1);
|
const unsigned char *repl = lookup_replace_object(sha1);
|
||||||
void *data;
|
void *data;
|
||||||
@ -2218,11 +2217,8 @@ void *read_sha1_file_repl(const unsigned char *sha1,
|
|||||||
|
|
||||||
errno = 0;
|
errno = 0;
|
||||||
data = read_object(repl, type, size);
|
data = read_object(repl, type, size);
|
||||||
if (data) {
|
if (data)
|
||||||
if (replacement)
|
|
||||||
*replacement = repl;
|
|
||||||
return data;
|
return data;
|
||||||
}
|
|
||||||
|
|
||||||
if (errno && errno != ENOENT)
|
if (errno && errno != ENOENT)
|
||||||
die_errno("failed to read object %s", sha1_to_hex(sha1));
|
die_errno("failed to read object %s", sha1_to_hex(sha1));
|
||||||
|
Loading…
Reference in New Issue
Block a user