func (command UntagCommand) untagPathAll(store *storage.Storage, path string) error { absPath, err := filepath.Abs(path) if err != nil { return fmt.Errorf("%v: could not get absolute path: %v", path, err) } file, err := store.FileByPath(absPath) if err != nil { return fmt.Errorf("%v: could not retrieve file: %v", path, err) } if file == nil { return fmt.Errorf("%v: file is not tagged.", path) } if command.verbose { log.Infof("%v: removing all tags.", file.Path()) } if err := store.RemoveFileTagsByFileId(file.Id); err != nil { return fmt.Errorf("%v: could not remove file's tags: %v", file.Path(), err) } if err := command.removeUntaggedFile(store, file); err != nil { return err } if command.recursive { childFiles, err := store.FilesByDirectory(file.Path()) if err != nil { return fmt.Errorf("%v: could not retrieve files for directory: %v", file.Path()) } for _, childFile := range childFiles { if err := store.RemoveFileTagsByFileId(childFile.Id); err != nil { return fmt.Errorf("%v: could not remove file's tags: %v", childFile.Path(), err) } if err := command.removeUntaggedFile(store, childFile); err != nil { return err } } } return nil }
func (command RepairCommand) repairMissing(store *storage.Storage, missing databaseFileMap) error { for path, dbFile := range missing { if command.force && !command.pretend { if err := store.RemoveFileTagsByFileId(dbFile.Id); err != nil { return fmt.Errorf("%v: could not delete file-tags: %v", path, err) } if err := store.RemoveFile(dbFile.Id); err != nil { return fmt.Errorf("%v: could not delete file: %v", path, err) } log.Infof("%v: removed", path) } else { log.Infof("%v: missing", path) } } return nil }