diff --git a/drive/download.go b/drive/download.go index 011c8060..8fa31065 100644 --- a/drive/download.go +++ b/drive/download.go @@ -141,6 +141,20 @@ func (self *Drive) downloadRecursive(args DownloadArgs) error { } func (self *Drive) downloadBinary(f *drive.File, args DownloadArgs) (int64, int64, error) { + // Path to file + fpath := filepath.Join(args.Path, f.Name) + + // Check if file exists to force + if !args.Skip && !args.Force && fileExists(fpath) { + return 0, 0, fmt.Errorf("File '%s' already exists, use --force to overwrite or --skip to skip", fpath) + } + + //Check if file exists to skip + if args.Skip && fileExists(fpath) { + fmt.Printf("File '%s' already exists, skipping\n", fpath) + return 0, 0, nil + } + // Get timeout reader wrapper and context timeoutReaderWrapper, ctx := getTimeoutReaderWrapperContext(args.Timeout) @@ -159,9 +173,6 @@ func (self *Drive) downloadBinary(f *drive.File, args DownloadArgs) (int64, int6 // Close body on function exit defer res.Body.Close() - // Path to file - fpath := filepath.Join(args.Path, f.Name) - if !args.Stdout { fmt.Fprintf(args.Out, "Downloading %s -> %s\n", f.Name, fpath) } @@ -199,17 +210,6 @@ func (self *Drive) saveFile(args saveFileArgs) (int64, int64, error) { return 0, 0, err } - // Check if file exists to force - if !args.skip && !args.force && fileExists(args.fpath) { - return 0, 0, fmt.Errorf("File '%s' already exists, use --force to overwrite or --skip to skip", args.fpath) - } - - //Check if file exists to skip - if args.skip && fileExists(args.fpath) { - fmt.Printf("File '%s' already exists, skipping\n", args.fpath) - return 0, 0, nil - } - // Ensure any parent directories exists if err := mkdir(args.fpath); err != nil { return 0, 0, err