2006-02-26 01:19:46 +01:00
|
|
|
#ifndef REVISION_H
|
|
|
|
#define REVISION_H
|
|
|
|
|
|
|
|
#define SEEN (1u<<0)
|
|
|
|
#define UNINTERESTING (1u<<1)
|
2006-02-28 20:24:00 +01:00
|
|
|
#define TREECHANGE (1u<<2)
|
2006-03-01 00:07:20 +01:00
|
|
|
#define SHOWN (1u<<3)
|
2006-03-01 09:58:56 +01:00
|
|
|
#define TMP_MARK (1u<<4) /* for isolated cases; clean after use */
|
2006-03-28 09:58:34 +02:00
|
|
|
#define BOUNDARY (1u<<5)
|
Make "--parents" logs also be incremental
The parent rewriting feature caused us to create the whole history in one
go, and then simplify it later, because of how rewrite_parents() had been
written. However, with a little tweaking, it's perfectly possible to do
even that one incrementally.
Right now, this doesn't really much matter, because every user of
"--parents" will probably generally _also_ use "--topo-order", which will
cause the old non-incremental behaviour anyway. However, I'm hopeful that
we could make even the topological sort incremental, or at least
_partially_ so (for example, make it incremental up to the first merge).
In the meantime, this at least moves things in the right direction, and
removes a strange special case.
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
2006-04-09 02:05:58 +02:00
|
|
|
#define ADDED (1u<<6) /* Parents already parsed and added? */
|
2006-02-26 01:19:46 +01:00
|
|
|
|
2006-03-10 10:21:39 +01:00
|
|
|
struct rev_info;
|
|
|
|
|
|
|
|
typedef void (prune_fn_t)(struct rev_info *revs, struct commit *commit);
|
|
|
|
|
2006-02-26 01:19:46 +01:00
|
|
|
struct rev_info {
|
|
|
|
/* Starting list */
|
|
|
|
struct commit_list *commits;
|
|
|
|
struct object_list *pending_objects;
|
|
|
|
|
|
|
|
/* Basic information */
|
|
|
|
const char *prefix;
|
2006-03-10 10:21:39 +01:00
|
|
|
void *prune_data;
|
|
|
|
prune_fn_t *prune_fn;
|
2006-02-26 01:19:46 +01:00
|
|
|
|
|
|
|
/* Traversal flags */
|
|
|
|
unsigned int dense:1,
|
2006-03-01 00:07:20 +01:00
|
|
|
no_merges:1,
|
2006-02-26 01:19:46 +01:00
|
|
|
remove_empty_trees:1,
|
|
|
|
lifo:1,
|
|
|
|
topo_order:1,
|
|
|
|
tag_objects:1,
|
|
|
|
tree_objects:1,
|
|
|
|
blob_objects:1,
|
2006-02-27 17:54:36 +01:00
|
|
|
edge_hint:1,
|
|
|
|
limited:1,
|
2006-03-28 09:58:34 +02:00
|
|
|
unpacked:1,
|
2006-03-31 02:52:42 +02:00
|
|
|
boundary:1,
|
|
|
|
parents:1;
|
2006-02-26 01:19:46 +01:00
|
|
|
|
|
|
|
/* special limits */
|
|
|
|
int max_count;
|
|
|
|
unsigned long max_age;
|
|
|
|
unsigned long min_age;
|
2006-03-10 10:21:39 +01:00
|
|
|
|
|
|
|
topo_sort_set_fn_t topo_setter;
|
|
|
|
topo_sort_get_fn_t topo_getter;
|
2006-02-26 01:19:46 +01:00
|
|
|
};
|
|
|
|
|
2006-03-10 10:21:39 +01:00
|
|
|
#define REV_TREE_SAME 0
|
|
|
|
#define REV_TREE_NEW 1
|
|
|
|
#define REV_TREE_DIFFERENT 2
|
|
|
|
|
2006-02-26 01:19:46 +01:00
|
|
|
/* revision.c */
|
2006-03-10 10:21:39 +01:00
|
|
|
extern int rev_same_tree_as_empty(struct tree *t1);
|
|
|
|
extern int rev_compare_tree(struct tree *t1, struct tree *t2);
|
|
|
|
|
|
|
|
extern void init_revisions(struct rev_info *revs);
|
2006-02-28 20:24:00 +01:00
|
|
|
extern int setup_revisions(int argc, const char **argv, struct rev_info *revs, const char *def);
|
|
|
|
extern void prepare_revision_walk(struct rev_info *revs);
|
|
|
|
extern struct commit *get_revision(struct rev_info *revs);
|
|
|
|
|
2006-02-26 01:19:46 +01:00
|
|
|
extern void mark_parents_uninteresting(struct commit *commit);
|
|
|
|
extern void mark_tree_uninteresting(struct tree *tree);
|
|
|
|
|
|
|
|
struct name_path {
|
|
|
|
struct name_path *up;
|
|
|
|
int elem_len;
|
|
|
|
const char *elem;
|
|
|
|
};
|
|
|
|
|
|
|
|
extern struct object_list **add_object(struct object *obj,
|
|
|
|
struct object_list **p,
|
|
|
|
struct name_path *path,
|
|
|
|
const char *name);
|
|
|
|
|
|
|
|
#endif
|