mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-26 16:35:38 +00:00
return to old behavior, small fix.
This commit is contained in:
parent
5acc1e661e
commit
8f5ffe47ff
38
yq.go
38
yq.go
@ -37,32 +37,6 @@ func main() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//MoveFile - os.Rename() give error "invalid cross-device link" for Docker container with Volumes.
|
|
||||||
//MoveFile(source, destination) will work moving file between folders
|
|
||||||
func MoveFile(sourcePath, destPath string) error {
|
|
||||||
inputFile, err := os.Open(sourcePath) // nolint gosec
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("couldn't open source file: %s", err)
|
|
||||||
}
|
|
||||||
outputFile, err := os.Create(destPath)
|
|
||||||
if err != nil {
|
|
||||||
defer safelyCloseFile(inputFile)
|
|
||||||
return fmt.Errorf("couldn't open dest file: %s", err)
|
|
||||||
}
|
|
||||||
defer safelyCloseFile(outputFile)
|
|
||||||
_, err = io.Copy(outputFile, inputFile)
|
|
||||||
defer safelyCloseFile(inputFile)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("writing to output file failed: %s", err)
|
|
||||||
}
|
|
||||||
// The copy was successful, so now delete the original file
|
|
||||||
err = os.Remove(sourcePath)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("failed removing original file: %s", err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func newCommandCLI() *cobra.Command {
|
func newCommandCLI() *cobra.Command {
|
||||||
yaml.DefaultMapType = reflect.TypeOf(yaml.MapSlice{})
|
yaml.DefaultMapType = reflect.TypeOf(yaml.MapSlice{})
|
||||||
var rootCmd = &cobra.Command{
|
var rootCmd = &cobra.Command{
|
||||||
@ -651,14 +625,18 @@ func marshalContext(context interface{}) (string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func safelyRenameFile(from string, to string) {
|
func safelyRenameFile(from string, to string) {
|
||||||
if renameError := MoveFile(from, to); renameError != nil {
|
if renameError := os.Rename(from, to); renameError != nil {
|
||||||
log.Warningf("Error renaming from %v to %v, attemting to copy contents", from, to)
|
log.Debugf("Error renaming from %v to %v, attemting to copy contents", from, to)
|
||||||
log.Warning(renameError.Error())
|
log.Debug(renameError.Error())
|
||||||
// can't do this rename when running in docker to a file targeted in a mounted volume,
|
// can't do this rename when running in docker to a file targeted in a mounted volume,
|
||||||
// so gracefully degrade to copying the entire contents.
|
// so gracefully degrade to copying the entire contents.
|
||||||
if copyError := copyFileContents(from, to); copyError != nil {
|
if copyError := copyFileContents(from, to); copyError != nil {
|
||||||
log.Errorf("Failed copying from %v to %v", from, to)
|
log.Errorf("Failed copying from %v to %v", from, to)
|
||||||
log.Errorf(copyError.Error())
|
log.Error(copyError.Error())
|
||||||
|
removeErr := os.Remove(from)
|
||||||
|
if removeErr != nil {
|
||||||
|
log.Errorf("failed removing original file: %s", from)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user