On Sat, 12 Jul 2008, Alexander N. Gavrilov wrote: > > Parent commits are usually older than their children. Thus, > on each iteration of the loop in rewrite_one, add_parents_to_list > traverses all commits previously processed by the loop. > It performs very poorly in case of very long rewrite chains. Good call, but you don't seem to invalidate the cache when we remove things from the list. The top of the limit_list() loop does that "get top entry from list, an free it", and I'm not seeing you invalidating the cache if that entry that just got free'd happened to be the cache entry? Or did I miss some reason why that couldn't happen? Linus -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html