|
|
|
#ifndef TREE_H
|
|
|
|
#define TREE_H
|
|
|
|
|
|
|
|
#include "object.h"
|
|
|
|
|
|
|
|
struct repository;
|
|
|
|
struct strbuf;
|
|
|
|
|
|
|
|
struct tree {
|
|
|
|
struct object object;
|
|
|
|
void *buffer;
|
|
|
|
unsigned long size;
|
|
|
|
};
|
|
|
|
|
|
|
|
extern const char *tree_type;
|
|
|
|
|
|
|
|
struct tree *lookup_tree(struct repository *r, const struct object_id *oid);
|
|
|
|
|
|
|
|
int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size);
|
|
|
|
|
add quieter versions of parse_{tree,commit}
When we call parse_commit, it will complain to stderr if the
object does not exist or cannot be read. This means that we
may produce useless error messages if this situation is
expected (e.g., because the object is marked UNINTERESTING,
or because revs->ignore_missing_links is set).
We can fix this by adding a new "parse_X_gently" form that
takes a flag to suppress the messages. The existing
"parse_X" form is already gentle in the sense that it
returns an error rather than dying, and we could in theory
just add a "quiet" flag to it (with existing callers passing
"0"). But doing it this way means we do not have to disturb
existing callers.
Note also that the new flag is "quiet_on_missing", and not
just "quiet". We could add a flag to suppress _all_ errors,
but besides being a more invasive change (we would have to
pass the flag down to sub-functions, too), there is a good
reason not to: we would never want to use it. Missing a
linked object is expected in some circumstances, but it is
never expected to have a malformed commit, or to get a tree
when we wanted a commit. We should always complain about
these corruptions.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
10 years ago
|
|
|
int parse_tree_gently(struct tree *tree, int quiet_on_missing);
|
|
|
|
static inline int parse_tree(struct tree *tree)
|
|
|
|
{
|
|
|
|
return parse_tree_gently(tree, 0);
|
|
|
|
}
|
|
|
|
void free_tree_buffer(struct tree *tree);
|
|
|
|
|
|
|
|
/* Parses and returns the tree in the given ent, chasing tags and commits. */
|
|
|
|
struct tree *parse_tree_indirect(const struct object_id *oid);
|
|
|
|
|
|
|
|
#define READ_TREE_RECURSIVE 1
|
|
|
|
typedef int (*read_tree_fn_t)(const struct object_id *, struct strbuf *, const char *, unsigned int, int, void *);
|
|
|
|
|
|
|
|
int read_tree_recursive(struct repository *r,
|
|
|
|
struct tree *tree,
|
|
|
|
const char *base, int baselen,
|
|
|
|
int stage, const struct pathspec *pathspec,
|
|
|
|
read_tree_fn_t fn, void *context);
|
|
|
|
|
|
|
|
int read_tree(struct repository *r, struct tree *tree,
|
|
|
|
int stage, struct pathspec *pathspec,
|
|
|
|
struct index_state *istate);
|
|
|
|
|
|
|
|
#endif /* TREE_H */
|