2
2
mirror of https://github.com/octoleo/restic.git synced 2024-11-25 14:17:42 +00:00
restic/internal/backend/layout_default.go

80 lines
1.9 KiB
Go
Raw Permalink Normal View History

2017-03-26 20:20:10 +00:00
package backend
2017-07-02 13:29:54 +00:00
import (
"encoding/hex"
2017-07-23 12:21:03 +00:00
2017-07-24 15:42:25 +00:00
"github.com/restic/restic/internal/restic"
2017-07-02 13:29:54 +00:00
)
2017-03-26 20:20:10 +00:00
// DefaultLayout implements the default layout for local and sftp backends, as
// described in the Design document. The `data` directory has one level of
// subdirs, two characters each (taken from the first two characters of the
// file name).
type DefaultLayout struct {
Path string
Join func(...string) string
}
var defaultLayoutPaths = map[restic.FileType]string{
restic.DataFile: "data",
restic.SnapshotFile: "snapshots",
restic.IndexFile: "index",
restic.LockFile: "locks",
restic.KeyFile: "keys",
}
2017-06-07 19:59:41 +00:00
func (l *DefaultLayout) String() string {
return "<DefaultLayout>"
}
// Name returns the name for this layout.
func (l *DefaultLayout) Name() string {
return "default"
}
2017-03-26 20:20:10 +00:00
// Dirname returns the directory path for a given file type and name.
func (l *DefaultLayout) Dirname(h restic.Handle) string {
p := defaultLayoutPaths[h.Type]
if h.Type == restic.DataFile && len(h.Name) > 2 {
p = l.Join(p, h.Name[:2]) + "/"
2017-03-26 20:20:10 +00:00
}
return l.Join(l.Path, p) + "/"
2017-03-26 20:20:10 +00:00
}
// Filename returns a path to a file, including its name.
func (l *DefaultLayout) Filename(h restic.Handle) string {
name := h.Name
if h.Type == restic.ConfigFile {
return l.Join(l.Path, "config")
2017-03-26 20:20:10 +00:00
}
return l.Join(l.Dirname(h), name)
}
2017-07-02 13:29:54 +00:00
// Paths returns all directory names needed for a repo.
2017-03-26 20:20:10 +00:00
func (l *DefaultLayout) Paths() (dirs []string) {
for _, p := range defaultLayoutPaths {
dirs = append(dirs, l.Join(l.Path, p))
}
2017-07-02 13:29:54 +00:00
// also add subdirs
for i := 0; i < 256; i++ {
subdir := hex.EncodeToString([]byte{byte(i)})
dirs = append(dirs, l.Join(l.Path, defaultLayoutPaths[restic.DataFile], subdir))
}
2017-03-26 20:20:10 +00:00
return dirs
}
2017-04-10 21:21:23 +00:00
// Basedir returns the base dir name for type t.
func (l *DefaultLayout) Basedir(t restic.FileType) (dirname string, subdirs bool) {
if t == restic.DataFile {
subdirs = true
}
dirname = l.Join(l.Path, defaultLayoutPaths[t])
return
2017-04-10 21:21:23 +00:00
}