Fix range header reset on retry in common_download_file_single #27
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Fixes an issue where HTTP Range headers were not being properly reset during download retries, potentially causing incorrect resume behavior when partial downloads fail and are retried.
Problem
In
common_download_file_single, when downloading files with resume support, if a download request failed partway through, subsequent retry attempts would continue using the original Range header value. This could lead to:Root Cause
The function used
curl_perform_with_retry()which performs multiple attempts with the same HTTP headers. Once a Range header was set for partial downloads (line 434-438), it persisted unchanged across all retry attempts, regardless of whether additional bytes were written during failed attempts.Solution
Replaced the generic
curl_perform_with_retrycall with custom retry logic that:Example Scenario
Before this fix:
After this fix:
Testing
This change ensures robust and correct resume behavior for interrupted downloads while maintaining the same retry logic and error handling.
Warning
Firewall rules blocked me from connecting to one or more addresses (expand for details)
I tried to connect to the following addresses, but was blocked by firewall rules:
ggml.ai/home/REDACTED/work/llama.cpp/llama.cpp/build/bin/test-arg-parser(dns block)huggingface.co/usr/lib/git-core/git-remote-https origin REDACTED(dns block)/home/REDACTED/work/llama.cpp/llama.cpp/build/bin/test-thread-safety -hf ggml-org/models -hff tinyllamas/stories15M-q4_0.gguf -ngl 99 -p The meaning of life is -n 128 -c 256 -ub 32 -np 4 -t 2(dns block)/home/REDACTED/work/llama.cpp/llama.cpp/build/bin/llama-eval-callback --hf-repo ggml-org/models --hf-file tinyllamas/stories260K.gguf --model stories260K.gguf --prompt hello --seed 42 -ngl 0(dns block)If you need me to access, download, or install something from one of these locations, you can either:
✨ Let Copilot coding agent set things up for you — coding agent works faster and does higher quality work when set up for your repo.