aboutsummaryrefslogtreecommitdiff
path: root/object.c
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2007-04-24 22:12:48 -0700
committerJunio C Hamano <junkio@cox.net>2007-04-24 22:12:48 -0700
commit7c9375e7d1c64862c32749dac2fc873fa923ae7c (patch)
treeec989a86cff36bed234e077e1997391603338f3b /object.c
parentb01c7c0ee3b692055c6026a9e22380d6ad35811b (diff)
parent43342941dd736fe06fe607a1594422cc8ba461a1 (diff)
downloadgit-7c9375e7d1c64862c32749dac2fc873fa923ae7c.tar.xz
Merge branch 'mk/diff'
* mk/diff: Diff between two blobs should take mode changes into account now. use mode of the tree in git-diff, if <tree>:<file> syntax is used store mode in rev_list, if <tree>:<filename> syntax is used add add_object_array_with_mode add get_sha1_with_mode Add S_IFINVALID mode
Diffstat (limited to 'object.c')
-rw-r--r--object.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/object.c b/object.c
index 7bd3fec556..37d1363359 100644
--- a/object.c
+++ b/object.c
@@ -231,6 +231,11 @@ int object_list_contains(struct object_list *list, struct object *obj)
void add_object_array(struct object *obj, const char *name, struct object_array *array)
{
+ add_object_array_with_mode(obj, name, array, S_IFINVALID);
+}
+
+void add_object_array_with_mode(struct object *obj, const char *name, struct object_array *array, unsigned mode)
+{
unsigned nr = array->nr;
unsigned alloc = array->alloc;
struct object_array_entry *objects = array->objects;
@@ -243,5 +248,6 @@ void add_object_array(struct object *obj, const char *name, struct object_array
}
objects[nr].item = obj;
objects[nr].name = name;
+ objects[nr].mode = mode;
array->nr = ++nr;
}