diff options
| author | 2026-02-21 14:56:56 +0800 | |
|---|---|---|
| committer | 2026-02-21 15:01:46 +0800 | |
| commit | 3011c5e84e9c05bfabe0a5f24b8b267b4bd23912 (patch) | |
| tree | 611bd4be729be1287924d77d0ed85615114ca0c1 /repository/read_stored.go | |
| parent | repository: Add Repository abstraction (diff) | |
| signature | No signature | |
repository, objectstored: Add Stored interface and implementations
Diffstat (limited to 'repository/read_stored.go')
| -rw-r--r-- | repository/read_stored.go | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/repository/read_stored.go b/repository/read_stored.go new file mode 100644 index 00000000..b26421e8 --- /dev/null +++ b/repository/read_stored.go @@ -0,0 +1,99 @@ +package repository + +import ( + "fmt" + + "codeberg.org/lindenii/furgit/object" + "codeberg.org/lindenii/furgit/objectid" + "codeberg.org/lindenii/furgit/objectstored" + "codeberg.org/lindenii/furgit/objecttype" +) + +// ReadStored reads, parses, and wraps one object by ID. +func (repo *Repository) ReadStored(id objectid.ObjectID) (objectstored.StoredObject, error) { + parsed, err := repo.readParsedObject(id) + if err != nil { + return nil, err + } + switch parsed := parsed.(type) { + case *object.Blob: + return objectstored.NewStoredBlob(id, parsed), nil + case *object.Tree: + return objectstored.NewStoredTree(id, parsed), nil + case *object.Commit: + return objectstored.NewStoredCommit(id, parsed), nil + case *object.Tag: + return objectstored.NewStoredTag(id, parsed), nil + default: + return nil, fmt.Errorf("repository: unsupported parsed object type %T", parsed) + } +} + +// ReadStoredBlob reads and parses a blob object by ID. +func (repo *Repository) ReadStoredBlob(id objectid.ObjectID) (*objectstored.StoredBlob, error) { + stored, err := repo.ReadStored(id) + if err != nil { + return nil, err + } + blob, ok := stored.(*objectstored.StoredBlob) + if !ok { + return nil, fmt.Errorf("repository: expected blob object %s, got %v", id, stored.Object().ObjectType()) + } + return blob, nil +} + +// ReadStoredTree reads and parses a tree object by ID. +func (repo *Repository) ReadStoredTree(id objectid.ObjectID) (*objectstored.StoredTree, error) { + stored, err := repo.ReadStored(id) + if err != nil { + return nil, err + } + tree, ok := stored.(*objectstored.StoredTree) + if !ok { + return nil, fmt.Errorf("repository: expected tree object %s, got %v", id, stored.Object().ObjectType()) + } + return tree, nil +} + +// ReadStoredCommit reads and parses a commit object by ID. +func (repo *Repository) ReadStoredCommit(id objectid.ObjectID) (*objectstored.StoredCommit, error) { + stored, err := repo.ReadStored(id) + if err != nil { + return nil, err + } + commit, ok := stored.(*objectstored.StoredCommit) + if !ok { + return nil, fmt.Errorf("repository: expected commit object %s, got %v", id, stored.Object().ObjectType()) + } + return commit, nil +} + +// ReadStoredTag reads and parses a tag object by ID. +func (repo *Repository) ReadStoredTag(id objectid.ObjectID) (*objectstored.StoredTag, error) { + stored, err := repo.ReadStored(id) + if err != nil { + return nil, err + } + tag, ok := stored.(*objectstored.StoredTag) + if !ok { + return nil, fmt.Errorf("repository: expected tag object %s, got %v", id, stored.Object().ObjectType()) + } + return tag, nil +} + +// readParsedObject reads bytes content from storage and parses one object. +func (repo *Repository) readParsedObject(id objectid.ObjectID) (object.Object, error) { + ty, content, err := repo.objects.ReadBytesContent(id) + if err != nil { + return nil, err + } + parsed, err := object.ParseObjectWithoutHeader(ty, content, repo.algo) + if err != nil { + tyName, ok := objecttype.Name(ty) + if !ok { + tyName = fmt.Sprintf("type %d", ty) + } + return nil, fmt.Errorf("repository: parse object %s (%s): %w", id, tyName, err) + } + return parsed, nil +} |
