]> granicus.if.org Git - git/commitdiff
unpack-trees: fix accidentally quadratic behavior
authorDavid Turner <dturner@twopensource.com>
Fri, 22 Jan 2016 19:58:43 +0000 (14:58 -0500)
committerJunio C Hamano <gitster@pobox.com>
Fri, 22 Jan 2016 21:03:10 +0000 (13:03 -0800)
While unpacking trees (e.g. during git checkout), when we hit a cache
entry that's past and outside our path, we cut off iteration.

This provides about a 45% speedup on git checkout between master and
master^20000 on Twitter's monorepo.  Speedup in general will depend on
repostitory structure, number of changes, and packfile packing
decisions.

Signed-off-by: David Turner <dturner@twopensource.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
unpack-trees.c

index 5f541c28c6aadda347c85018a6591ac6b2622820..9f55cc28b9dd41231644053b49875671f5a505fa 100644 (file)
@@ -695,8 +695,19 @@ static int find_cache_pos(struct traverse_info *info,
                                ++o->cache_bottom;
                        continue;
                }
-               if (!ce_in_traverse_path(ce, info))
+               if (!ce_in_traverse_path(ce, info)) {
+                       /*
+                        * Check if we can skip future cache checks
+                        * (because we're already past all possible
+                        * entries in the traverse path).
+                        */
+                       if (info->traverse_path) {
+                               if (strncmp(ce->name, info->traverse_path,
+                                           info->pathlen) > 0)
+                                       break;
+                       }
                        continue;
+               }
                ce_name = ce->name + pfxlen;
                ce_slash = strchr(ce_name, '/');
                if (ce_slash)