backup: Allow specifying multiple exclude files

This commit is contained in:
Alexander Neumann 2017-04-16 20:52:41 +02:00
parent dd65ac56ef
commit 69dd1d2544

View file

@ -44,7 +44,7 @@ type BackupOptions struct {
Parent string Parent string
Force bool Force bool
Excludes []string Excludes []string
ExcludeFile string ExcludeFiles []string
ExcludeOtherFS bool ExcludeOtherFS bool
Stdin bool Stdin bool
StdinFilename string StdinFilename string
@ -68,7 +68,7 @@ func init() {
f.StringVar(&backupOptions.Parent, "parent", "", "use this parent snapshot (default: last snapshot in the repo that has the same target files/directories)") f.StringVar(&backupOptions.Parent, "parent", "", "use this parent snapshot (default: last snapshot in the repo that has the same target files/directories)")
f.BoolVarP(&backupOptions.Force, "force", "f", false, `force re-reading the target files/directories (overrides the "parent" flag)`) f.BoolVarP(&backupOptions.Force, "force", "f", false, `force re-reading the target files/directories (overrides the "parent" flag)`)
f.StringSliceVarP(&backupOptions.Excludes, "exclude", "e", nil, "exclude a `pattern` (can be specified multiple times)") f.StringSliceVarP(&backupOptions.Excludes, "exclude", "e", nil, "exclude a `pattern` (can be specified multiple times)")
f.StringVar(&backupOptions.ExcludeFile, "exclude-file", "", "read exclude patterns from a file") f.StringSliceVar(&backupOptions.ExcludeFiles, "exclude-file", nil, "read exclude patterns from a `file` (can be specified multiple times)")
f.BoolVarP(&backupOptions.ExcludeOtherFS, "one-file-system", "x", false, "exclude other file systems") f.BoolVarP(&backupOptions.ExcludeOtherFS, "one-file-system", "x", false, "exclude other file systems")
f.BoolVar(&backupOptions.Stdin, "stdin", false, "read backup from stdin") f.BoolVar(&backupOptions.Stdin, "stdin", false, "read backup from stdin")
f.StringVar(&backupOptions.StdinFilename, "stdin-filename", "stdin", "file name to use when reading from stdin") f.StringVar(&backupOptions.StdinFilename, "stdin-filename", "stdin", "file name to use when reading from stdin")
@ -406,29 +406,31 @@ func runBackup(opts BackupOptions, gopts GlobalOptions, args []string) error {
Verbosef("scan %v\n", target) Verbosef("scan %v\n", target)
// add patterns from file // add patterns from file
if opts.ExcludeFile != "" { if len(opts.ExcludeFiles) > 0 {
file, err := fs.Open(opts.ExcludeFile) for _, filename := range opts.ExcludeFiles {
if err != nil { file, err := fs.Open(filename)
Warnf("error reading exclude patterns: %v", err) if err != nil {
return nil Warnf("error reading exclude patterns: %v", err)
} return nil
scanner := bufio.NewScanner(file)
for scanner.Scan() {
line := strings.TrimSpace(scanner.Text())
// ignore empty lines
if line == "" {
continue
} }
// strip comments scanner := bufio.NewScanner(file)
if strings.HasPrefix(line, "#") { for scanner.Scan() {
continue line := strings.TrimSpace(scanner.Text())
}
line = os.ExpandEnv(line) // ignore empty lines
opts.Excludes = append(opts.Excludes, line) if line == "" {
continue
}
// strip comments
if strings.HasPrefix(line, "#") {
continue
}
line = os.ExpandEnv(line)
opts.Excludes = append(opts.Excludes, line)
}
} }
} }