On Thu, Apr 21, 2016 at 12:27 PM, Junio C Hamano <gitster@xxxxxxxxx> wrote: > Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> writes: > >> But this patch is small and simple, and has some excuses for its >> behavior. What do people think? > > I like it that you call it "excuse" not "rationale", as I couldn't > form a logical connection between your "4 (2) letters" and "10000 > (100)" at all ;-) Think of the distance number as a "order of magnitude in complexity", and it actually makes a certain amount of sense. It's not the same as the length of the string, but the "log()" of the distance number really does give a kind of complexity value. Think of it this way: if things are entirely linear (all just first parenthood), there will be just a single simple number, and the relationship between the simple distance number (that just increments by one for each parent traversed) and the length of the string that describes it will really be "log10(distance)". That's literally how many characters you need to describe the linear distance number. So a simple linear distance of 'n' commits will need on the order of 'log10(n)' digits to describe it (ie a number around a thousand will need around three digits). The "100" and "10000" are just extending that notion of distance to the more complex cases., and expresses their complexity in the same logarithmic units. The same way you need four digits to express a _linear_ distance of 10000, you need four characters to express that "~n^p" case of "merge parent p, n generations back". And if you don't have the generation thing, you only need two characters to express parent #'p': "^p". So two characters really *are* equivalent to ~100 linear steps, and four characters really *are* equivalent to ~10000 linear steps. So it's not _just_ an excuse. There's an actual rationale for picking those numbers, and why they are equivalent in a complexity measure. 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