aboutsummaryrefslogtreecommitdiff
path: root/page.go
blob: 2910d54ae5dbb3fa20ab6743cdbe56d6318229f9 (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
49
50
51
52
53
54
55
56
57
58
59
package bolt

import (
	"unsafe"
)

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

const maxPageSize = 0x8000
const minKeysPerPage = 2
const maxNodesPerPage = 65535
const fillThreshold = 250 // 25%

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

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, error) {
	// Exit if page is not a meta page.
	if (p.flags & p_meta) == 0 {
		return nil, InvalidMetaPageError
	}

	// Cast the meta section and validate before returning.
	m := (*meta)(unsafe.Pointer(&p.ptr))
	if err := m.validate(); err != nil {
		return nil, err
	}
	return m, nil
}

// init initializes a page as a new meta page.
func (p *page) init(pageSize int) {
	p.flags = p_meta
	m := (*meta)(unsafe.Pointer(&p.ptr))
	m.magic = magic
	m.version = version
	m.pageSize = uint32(pageSize)
	m.pgid = 1
	m.sys.root = 0
}

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