aboutsummaryrefslogtreecommitdiff
path: root/internal/commitquery/node.go
blob: 7abf381d262c80c81f4ccd3b3c69094cfccc5beb (about) (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package commitquery

import (
	commitgraphread "codeberg.org/lindenii/furgit/format/commitgraph/read"
	"codeberg.org/lindenii/furgit/objectid"
)

// NodeIndex identifies one internal query node.
type NodeIndex int

// node stores one mutable commit traversal node.
type node struct {
	id objectid.ObjectID

	parents []NodeIndex

	commitTime int64
	generation uint64

	hasGeneration bool
	hasGraphPos   bool
	loaded        bool

	graphPos commitgraphread.Position
	marks    markBits

	touchedPhase uint32
}

// newNode allocates one empty internal node.
func (ctx *Context) newNode(id objectid.ObjectID) NodeIndex {
	count := len(ctx.nodes)

	idx := NodeIndex(count)

	ctx.nodes = append(ctx.nodes, node{id: id})

	return idx
}