aboutsummaryrefslogtreecommitdiff
path: root/delta/apply/header.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-25 14:32:04 +0000
committerGravatar Runxi Yu2026-03-25 14:32:04 +0000
commit329e6b4557dd90405d0560edcba2ce0440633de0 (patch)
tree9092540230972efd0a0c267dcc337bb57c0d6be7 /delta/apply/header.go
parent*: refstore -> ref/store (diff)
signatureNo signature
*: delta -> packfile/delta
Diffstat (limited to 'delta/apply/header.go')
-rw-r--r--delta/apply/header.go47
1 files changed, 0 insertions, 47 deletions
diff --git a/delta/apply/header.go b/delta/apply/header.go
deleted file mode 100644
index 69c9659a..00000000
--- a/delta/apply/header.go
+++ /dev/null
@@ -1,47 +0,0 @@
-package apply
-
-import (
- "fmt"
- "io"
-)
-
-// ReadHeaderSizes reads the first two varints in one inflated delta stream.
-//
-// Callers that continue reading the same stream should pass their own buffered
-// byte reader and keep using that same reader afterwards.
-func ReadHeaderSizes(reader io.ByteReader) (int, int, error) {
- srcSize, err := readVarintFromByteReader(reader)
- if err != nil {
- return 0, 0, err
- }
-
- dstSize, err := readVarintFromByteReader(reader)
- if err != nil {
- return 0, 0, err
- }
-
- return srcSize, dstSize, nil
-}
-
-// readVarintFromByteReader parses one Git delta varint from reader.
-func readVarintFromByteReader(reader io.ByteReader) (int, error) {
- value := 0
- shift := uint(0)
-
- for {
- b, err := reader.ReadByte()
- if err != nil {
- return 0, fmt.Errorf("delta/apply: malformed delta varint: %w", err)
- }
-
- value |= int(b&0x7f) << shift
- if b&0x80 == 0 {
- return value, nil
- }
-
- shift += 7
- if shift > 63 {
- return 0, fmt.Errorf("delta/apply: delta varint overflow")
- }
- }
-}