aboutsummaryrefslogtreecommitdiff
path: root/page.go
blob: 12d1cee4c1987e63598341faf05dd0ae0ffdb748 (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
40
41
42
43
44
45
46
47
48
package bolt

import (
	"unsafe"
)

const pageHeaderSize = int(unsafe.Offsetof(((*page)(nil)).ptr))

const maxAllocSize = 0xFFFFFFF
const minKeysPerPage = 2
const maxNodesPerPage = 65535

const (
	p_branch   = 0x01
	p_leaf     = 0x02
	p_meta     = 0x04
	p_freelist = 0x08
)

type pgid uint64

type page struct {
	id       pgid
	flags    uint16
	count    uint16
	overflow uint32
	ptr      uintptr
}

// meta returns a pointer to the metadata section of the page.
func (p *page) meta() *meta {
	return (*meta)(unsafe.Pointer(&p.ptr))
}

// lnode retrieves the leaf node by index
func (p *page) lnode(index int) *lnode {
	return &((*[maxNodesPerPage]lnode)(unsafe.Pointer(&p.ptr)))[index]
}

// bnode retrieves the branch node by index
func (p *page) bnode(index int) *bnode {
	return &((*[maxNodesPerPage]bnode)(unsafe.Pointer(&p.ptr)))[index]
}

// freelist retrieves a list of page ids from a freelist page.
func (p *page) freelist() []pgid {
	return ((*[maxNodesPerPage]pgid)(unsafe.Pointer(&p.ptr)))[0:p.count]
}