summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@lukeshu.com>2022-07-12 22:18:18 -0600
committerLuke Shumaker <lukeshu@lukeshu.com>2022-07-12 22:39:41 -0600
commitfb589cdfc5acd6bd629c3fcfbe42f94700e78899 (patch)
treef8246e733beac834a8f5039151bef073b1520682 /lib
parentec6929e40ca17cacb6a4ba23508d2b724b9201c1 (diff)
Define a Trees interface to abstract over broken trees
Diffstat (limited to 'lib')
-rw-r--r--lib/btrfs/io3_btree.go52
-rw-r--r--lib/btrfs/io4_fs.go2
2 files changed, 36 insertions, 18 deletions
diff --git a/lib/btrfs/io3_btree.go b/lib/btrfs/io3_btree.go
index 4d2e556..1cb1d74 100644
--- a/lib/btrfs/io3_btree.go
+++ b/lib/btrfs/io3_btree.go
@@ -17,6 +17,41 @@ import (
"git.lukeshu.com/btrfs-progs-ng/lib/util"
)
+type Trees interface {
+ // The lifecycle of callbacks is:
+ //
+ // 001 .PreNode()
+ // 002 (read node)
+ // 003 .Node() (or .BadNode())
+ // for item in node.items:
+ // if internal:
+ // 004 .PreKeyPointer()
+ // 005 (recurse)
+ // 006 .PostKeyPointer()
+ // else:
+ // 004 .Item() (or .BadItem())
+ // 007 .PostNode()
+ TreeWalk(treeID ObjID, errHandle func(*TreeError), cbs TreeWalkHandler)
+
+ TreeLookup(treeID ObjID, key Key) (Item, error)
+ TreeSearch(treeID ObjID, fn func(Key) int) (Item, error)
+
+ // If some items are able to be read, but there is an error reading the
+ // full set, then it might return *both* a list of items and an error.
+ //
+ // If no such item is found, an error that is io/fs.ErrNotExist is
+ // returned.
+ TreeSearchAll(treeID ObjID, fn func(Key) int) ([]Item, error)
+
+ // For bootstrapping purposes.
+ Superblock() (*Superblock, error)
+
+ // For reading raw data extants pointed at by tree items.
+ ReadAt(p []byte, off btrfsvol.LogicalAddr) (int, error)
+}
+
+var _ Trees = (*FS)(nil)
+
// - The first element will always have an ItemIdx of -1.
//
// - For .Item() callbacks, the last element will always have a
@@ -212,19 +247,6 @@ type TreeWalkHandler struct {
BadItem func(TreePath, Item) error
}
-// The lifecycle of callbacks is:
-//
-// 001 .PreNode()
-// 002 (read node)
-// 003 .Node() (or .BadNode())
-// for item in node.items:
-// if internal:
-// 004 .PreKeyPointer()
-// 005 (recurse)
-// 006 .PostKeyPointer()
-// else:
-// 004 .Item() (or .BadItem())
-// 007 .PostNode()
func (fs *FS) TreeWalk(treeID ObjID, errHandle func(*TreeError), cbs TreeWalkHandler) {
path := TreePath{
TreeID: treeID,
@@ -537,10 +559,6 @@ func (fs *FS) TreeLookup(treeID ObjID, key Key) (Item, error) {
return item, err
}
-// If some items are able to be read, but there is an error reading the full set, then it might
-// return *both* a list of items and an error.
-//
-// If no such item is found, an error that is io/fs.ErrNotExist is returned.
func (fs *FS) TreeSearchAll(treeID ObjID, fn func(Key) int) ([]Item, error) {
rootInfo, err := fs.lookupTree(treeID)
if err != nil {
diff --git a/lib/btrfs/io4_fs.go b/lib/btrfs/io4_fs.go
index 02f1969..07e52bb 100644
--- a/lib/btrfs/io4_fs.go
+++ b/lib/btrfs/io4_fs.go
@@ -55,7 +55,7 @@ type File struct {
}
type Subvolume struct {
- FS *FS
+ FS Trees
TreeID ObjID
rootOnce sync.Once