aboutsummaryrefslogtreecommitdiff
path: root/commitgraph/read/commitat.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-26 09:17:14 +0000
committerGravatar Runxi Yu2026-03-26 09:18:30 +0000
commit3e884f5f3d42cbc4874a04da31dde10314b0cfad (patch)
treef5e1e325fd1a2a0801791c054010213214475d80 /commitgraph/read/commitat.go
parentnetwork/receivepack: Rename from receivepack (diff)
signatureNo signature
format: Move commitgraph and packfile here
Diffstat (limited to 'commitgraph/read/commitat.go')
-rw-r--r--commitgraph/read/commitat.go85
1 files changed, 0 insertions, 85 deletions
diff --git a/commitgraph/read/commitat.go b/commitgraph/read/commitat.go
deleted file mode 100644
index a39c5ccd..00000000
--- a/commitgraph/read/commitat.go
+++ /dev/null
@@ -1,85 +0,0 @@
-package read
-
-import (
- "encoding/binary"
-
- "codeberg.org/lindenii/furgit/internal/intconv"
- objectid "codeberg.org/lindenii/furgit/object/id"
-)
-
-// CommitAt returns decoded commit-graph metadata at one position.
-func (reader *Reader) CommitAt(pos Position) (Commit, error) {
- layer, err := reader.layerByPosition(pos)
- if err != nil {
- return Commit{}, err
- }
-
- hashSize := reader.algo.Size()
- stride := hashSize + 16
-
- strideU64, err := intconv.IntToUint64(stride)
- if err != nil {
- return Commit{}, err
- }
-
- start64 := uint64(pos.Index) * strideU64
- end64 := start64 + strideU64
-
- start, err := intconv.Uint64ToInt(start64)
- if err != nil {
- return Commit{}, err
- }
-
- end, err := intconv.Uint64ToInt(end64)
- if err != nil {
- return Commit{}, err
- }
-
- record := layer.chunkCommit[start:end]
-
- treeOID, err := objectid.FromBytes(reader.algo, record[:hashSize])
- if err != nil {
- return Commit{}, err
- }
-
- oid, err := reader.OIDAt(pos)
- if err != nil {
- return Commit{}, err
- }
-
- p1 := binary.BigEndian.Uint32(record[hashSize : hashSize+4])
- p2 := binary.BigEndian.Uint32(record[hashSize+4 : hashSize+8])
- genAndTimeHi := binary.BigEndian.Uint32(record[hashSize+8 : hashSize+12])
- timeLow := binary.BigEndian.Uint32(record[hashSize+12 : hashSize+16])
-
- timeHigh := uint64(genAndTimeHi & 0x3)
- commitTimeU64 := (timeHigh << 32) | uint64(timeLow)
-
- commitTime, err := intconv.Uint64ToInt64(commitTimeU64)
- if err != nil {
- return Commit{}, err
- }
-
- generationV1 := genAndTimeHi >> 2
-
- generationV2, err := reader.readGenerationV2(layer, pos.Index, commitTimeU64)
- if err != nil {
- return Commit{}, err
- }
-
- parent1, parent2, extra, err := reader.decodeParents(layer, p1, p2)
- if err != nil {
- return Commit{}, err
- }
-
- return Commit{
- OID: oid,
- TreeOID: treeOID,
- Parent1: parent1,
- Parent2: parent2,
- ExtraParents: extra,
- CommitTimeUnix: commitTime,
- GenerationV1: generationV1,
- GenerationV2: generationV2,
- }, nil
-}