Пример #1
0
func GetUserStore(dir string) (*UserFileStore, error) {
	var bf *fmap.BlockFile
	var users *bptree.BpTree
	path := filepath.Join(dir, "users.bptree")
	err := createOrOpen(path,
		func(path string) (err error) {
			bf, err = fmap.CreateBlockFile(path)
			if err != nil {
				return err
			}
			users, err = bptree.New(bf, -1, -1)
			return err
		},
		func(path string) (err error) {
			bf, err = fmap.OpenBlockFile(path)
			if err != nil {
				return err
			}
			users, err = bptree.Open(bf)
			return err
		},
	)
	if err != nil {
		return nil, err
	}
	s := &UserFileStore{
		path:  path,
		bf:    bf,
		users: users,
	}
	return s, bf.Sync()
}
Пример #2
0
func NewAt(bf *fmap.BlockFile, ctrl_a uint64) (*List, error) {
	vc_a, err := bf.Allocate()
	if err != nil {
		return nil, err
	}
	it_a, err := bf.Allocate()
	if err != nil {
		return nil, err
	}
	v, err := bptree.NewVarchar(bf, vc_a)
	if err != nil {
		return nil, err
	}
	it, err := bptree.NewAt(bf, it_a, 8, 8)
	if err != nil {
		return nil, err
	}
	l := &List{
		bf:      bf,
		varchar: v,
		idxTree: it,
		a:       ctrl_a,
		count:   0,
	}
	err = l.bf.Do(ctrl_a, 1, func(bytes []byte) error {
		c := l.asCtrl(bytes)
		c.Init(vc_a, it_a)
		return nil
	})
	if err != nil {
		return nil, err
	}
	return l, nil
}
Пример #3
0
// Open a varchar structure in the given blockfile with the given offset
// as the control block. This function will confirm that the control
// block is indeed a properly formated control block.
func OpenVarchar(bf *fmap.BlockFile, a uint64) (v *Varchar, err error) {
	v = &Varchar{bf: bf, a: a, blkSize: bf.BlockSize()}
	var ptOff uint64
	var szOff uint64
	err = v.bf.Do(v.a, 1, func(bytes []byte) error {
		ctrl := asCtrl(bytes)
		if ctrl.flags&consts.VARCHAR_CTRL == 0 {
			return errors.Errorf("Expected a Varchar control block")
		}
		ptOff = ctrl.posTree
		szOff = ctrl.sizeTree
		return nil
	})
	if err != nil {
		return nil, err
	}
	v.posTree, err = OpenAt(bf, ptOff)
	if err != nil {
		return nil, err
	}
	v.sizeTree, err = OpenAt(bf, szOff)
	if err != nil {
		return nil, err
	}
	return v, nil
}
Пример #4
0
func Open(bf *fmap.BlockFile) (*List, error) {
	data, err := bf.ControlData()
	if err != nil {
		return nil, err
	}
	ctrl_a := *slice.AsUint64(&data)
	return OpenAt(bf, ctrl_a)
}
Пример #5
0
func New(bf *fmap.BlockFile) (*List, error) {
	ctrl_a, err := bf.Allocate()
	if err != nil {
		return nil, err
	}
	data := make([]byte, 8)
	moff := slice.AsUint64(&data)
	*moff = ctrl_a
	err = bf.SetControlData(data)
	if err != nil {
		return nil, err
	}
	return NewAt(bf, ctrl_a)
}
Пример #6
0
// Create a new varchar structure. This takes a blockfile and an offset
// of an allocated block. The block becomes the control block for the
// varchar file (storing the free list for the allocator). It is
// important for the parent structure to track the location of this
// control block.
func NewVarchar(bf *fmap.BlockFile, a uint64) (v *Varchar, err error) {
	ptOff, err := bf.Allocate()
	if err != nil {
		return nil, err
	}
	posTree, err := NewAt(bf, ptOff, 8, 0)
	if err != nil {
		return nil, err
	}
	szOff, err := bf.Allocate()
	if err != nil {
		return nil, err
	}
	sizeTree, err := NewAt(bf, szOff, 4, 8)
	if err != nil {
		return nil, err
	}
	v = &Varchar{
		bf:       bf,
		posTree:  posTree,
		sizeTree: sizeTree,
		a:        a,
		blkSize:  bf.BlockSize(),
	}
	err = v.bf.Do(v.a, 1, func(bytes []byte) error {
		ctrl := asCtrl(bytes)
		ctrl.Init(ptOff, szOff)
		return nil
	})
	if err != nil {
		return nil, err
	}
	return v, nil
}
Пример #7
0
func (t *T) newLeafIn(bf *fmap.BlockFile, a uint64) {
	t.assert_nil(bf.Do(a, 1, func(bytes []byte) error {
		_, err := newLeaf(0, bytes, 8, 8)
		return err
	}))
}
Пример #8
0
func (t *T) assert_alc(bf *fmap.BlockFile) uint64 {
	a, err := bf.Allocate()
	t.assert_nil(err)
	return a
}