1
0
Fork 0
mirror of https://github.com/restic/restic.git synced 2025-01-03 05:35:43 +00:00

Add Remove()

This commit is contained in:
Alexander Neumann 2014-04-19 19:46:20 +02:00
parent d156b2d245
commit 70856673db
4 changed files with 101 additions and 6 deletions

View file

@ -24,7 +24,7 @@ var _ = Describe("Hashing", func() {
{sha1.New, "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", "84983e441c3bd26ebaae4aa1f95129e5e54670f1"}, {sha1.New, "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", "84983e441c3bd26ebaae4aa1f95129e5e54670f1"},
} }
var _ = Describe("Reader", func() { Describe("Reader", func() {
Context("Static Strings", func() { Context("Static Strings", func() {
It("Should compute digest", func() { It("Should compute digest", func() {
for _, t := range static_tests { for _, t := range static_tests {
@ -47,9 +47,13 @@ var _ = Describe("Hashing", func() {
} }
}) })
}) })
Context("Random Strings", func() {
})
}) })
var _ = Describe("Writer", func() { Describe("Writer", func() {
Context("Static Strings", func() { Context("Static Strings", func() {
It("Should compute digest", func() { It("Should compute digest", func() {
for _, t := range static_tests { for _, t := range static_tests {
@ -59,7 +63,7 @@ var _ = Describe("Hashing", func() {
n, err := w.Write([]byte(t.text)) n, err := w.Write([]byte(t.text))
if n != len(t.text) { if n != len(t.text) {
Fail("not enough bytes read") Fail("not enough bytes written")
} }
if err != nil { if err != nil {

View file

@ -27,6 +27,7 @@ type Repository interface {
PutFile(path string) (ID, error) PutFile(path string) (ID, error)
Get(ID) (io.Reader, error) Get(ID) (io.Reader, error)
Test(ID) (bool, error) Test(ID) (bool, error)
Remove(ID) error
Link(name string, id ID) error Link(name string, id ID) error
Unlink(name string) error Unlink(name string) error
Resolve(name string) (ID, error) Resolve(name string) (ID, error)
@ -184,6 +185,11 @@ func (r *Dir) Get(id ID) (io.Reader, error) {
return file, nil return file, nil
} }
// Remove removes the content stored at ID.
func (r *Dir) Remove(id ID) error {
return os.Remove(path.Join(r.path, objectPath, id.String()))
}
// Unlink removes a named ID. // Unlink removes a named ID.
func (r *Dir) Unlink(name string) error { func (r *Dir) Unlink(name string) error {
return os.Remove(path.Join(r.path, refPath, Name(name).Encode())) return os.Remove(path.Join(r.path, refPath, Name(name).Encode()))
@ -208,7 +214,7 @@ func (r *Dir) Link(name string, id ID) error {
return err return err
} }
f.Write(id) f.Write([]byte(hex.EncodeToString(id)))
return nil return nil
} }
@ -220,12 +226,20 @@ func (r *Dir) Resolve(name string) (ID, error) {
return nil, err return nil, err
} }
id := make([]byte, r.hash().Size()) // read hex string
_, err = io.ReadFull(f, id) l := r.hash().Size()
buf := make([]byte, l*2)
_, err = io.ReadFull(f, buf)
if err != nil { if err != nil {
return nil, err return nil, err
} }
id := make([]byte, l)
_, err = hex.Decode(id, buf)
if err != nil {
return nil, err
}
return ID(id), nil return ID(id), nil
} }

View file

@ -91,6 +91,9 @@ var _ = Describe("Storage", func() {
// remove link // remove link
Expect(repo.Unlink(test.data)).NotTo(HaveOccurred()) Expect(repo.Unlink(test.data)).NotTo(HaveOccurred())
// remove string
Expect(repo.Remove(id))
} }
}) })
}) })

74
storagetest/main.go Normal file
View file

@ -0,0 +1,74 @@
package main
import (
"crypto/sha256"
"io"
"log"
"os"
"github.com/fd0/khepri/storage"
)
func hash(filename string) (storage.ID, error) {
h := sha256.New()
f, err := os.Open(filename)
if err != nil {
return nil, err
}
io.Copy(h, f)
return h.Sum([]byte{}), nil
}
func main() {
repo, err := storage.NewDir("repo")
if err != nil {
log.Fatalf("error: %v", err)
}
switch os.Args[1] {
case "add":
for _, file := range os.Args[2:] {
f, err := os.Open(file)
if err != nil {
log.Printf("error opening file %q: %v", file, err)
continue
}
id, err := repo.Put(f)
if err != nil {
log.Printf("Put() error: %v", err)
continue
}
log.Printf("archived file %q as ID %v", file, id)
}
case "link":
file := os.Args[2]
name := os.Args[3]
id, err := hash(file)
if err != nil {
log.Fatalf("error hashing filq %q: %v", file, err)
}
present, err := repo.Test(id)
if err != nil {
log.Fatalf("error testing presence of id %v: %v", id, err)
}
if !present {
log.Printf("adding file to repo as ID %v", id)
_, err = repo.PutFile(file)
if err != nil {
log.Fatalf("error adding file %q: %v", file, err)
}
}
err = repo.Link(name, id)
if err != nil {
log.Fatalf("error linking name %q to id %v", name, id)
}
default:
log.Fatalf("unknown command: %q", os.Args[1])
}
}