On Mon, Aug 14, 2017 at 11:35:33AM -0700, Junio C Hamano wrote: > Junio C Hamano <gitster@xxxxxxxxx> writes: > > > Perhaps we may want to replace the calls to progress_delay() with a > > call to a simpler wrapper that does not let the callers give their > > own delay threashold to simplify the API. > > ... which does not look too bad, but because it makes me wonder if > we even need to make the delay-threshold customizable per callers, > I'll wait further discussions before committing to the approach. For what it's worth, I had a similar "why is this even part of the API" thought when writing earlier in the thread. > For example, I do not quite understand why 95 is a good value for > prune-packed while 0 is a good value for prune. And I also wondered this same thing. I do not have a good answer. > The rename detection in diffcore-rename, delay in blame, and > checkout (via unpack-trees) all of which use 50-percent threshold > with 1 second delay, sort of make sense to me in that if we > completed 50 percent within 1 second, it is likely we will finish > all in 2 seconds (which is the norm for everybody else), perhaps as > a better version of 0-percent 2 seconds rule. Just thinking what could go wrong for a moment. If we reach 51% in one second, would we then never show progress? That seems like a misfeature when the counter is spiky. E.g., consider something like object transfer (which doesn't do a delayed progress, but pretend for a moment as it makes a simple example). Imagine we have 100 objects, 99 of which are 10KB and one of which is 100MB. And that the big object comes at slot 75. No matter how the delay works, the counter is going to jump quickly to 75% as we send the small objects, and then appear to stall on the large one. That's unavoidable without feeding the progress code more data about the items. But what does the user see? With (0,2), we start the progress meter at 2 seconds, the user sees it stall at 75%, and then eventually it unclogs. With (50,1), we check the percentage after 1 second and see we are already at 75%. We then disable the meter totally. After 2 seconds, we get the same stall but the user sees nothing. So in that case we should always base our decision only on time taken. And that gives me an answer for your question above: the difference is whether we expect the counter to move smoothly, or to be spiky. If it's smooth, the (50,1) case is slightly nicer in that it puts the progress in front of the user more quickly. I'm not sure if that's actually worth pushing an additional decision onto the person writing the calling code, though (especially when we are just now puzzling out the method for making such a decision from first principles). So I'd vote to drop that parameter entirely. And if 1 second seems noticeably snappier, then we should probably just move everything to a 1 second delay (I don't have a strong feeling either way). -Peff