diff options
author | n-peugnet <n.peugnet@free.fr> | 2021-09-01 16:01:57 +0200 |
---|---|---|
committer | n-peugnet <n.peugnet@free.fr> | 2021-09-01 16:01:57 +0200 |
commit | 34a84a44b4dfa513d8ceb1cfeec50ac78fb311e0 (patch) | |
tree | 8647ba8b5c5b6b6ce9387076f0cf7115d9951e95 | |
parent | ba102f52038ee1a47352443a44e8ccd4e20bcbcb (diff) | |
download | dna-backup-34a84a44b4dfa513d8ceb1cfeec50ac78fb311e0.tar.gz dna-backup-34a84a44b4dfa513d8ceb1cfeec50ac78fb311e0.zip |
first add of tar streamer
-rw-r--r-- | tar.go | 43 |
1 files changed, 43 insertions, 0 deletions
@@ -0,0 +1,43 @@ +package main + +import ( + "archive/tar" + "io" + "log" + "os" +) + +func streamFilesTar(files []File, stream io.WriteCloser) { + tarStream := tar.NewWriter(stream) + for _, f := range files { + file, err := os.Open(f.Path) + if err != nil { + log.Printf("Error reading file '%s': %s\n", f.Path, err) + continue + } + stat, err := file.Stat() + if err != nil { + log.Printf("Error getting stat of file '%s': %s\n", f.Path, err) + continue + } + hdr, err := tar.FileInfoHeader(stat, "") + if err != nil { + log.Printf("Error creating tar header for file '%s': %s\n", f.Path, err) + continue + } + if err := tarStream.WriteHeader(hdr); err != nil { + log.Printf("Error writing tar header to stream for file '%s': %s\n", f.Path, err) + continue + } + if _, err := io.Copy(tarStream, file); err != nil { + log.Printf("Error writing file to stream '%s': %s\n", f.Path, err) + continue + } + } + if err := tarStream.Close(); err != nil { + log.Fatal("Error closing tar stream:", err) + } + if err := stream.Close(); err != nil { + log.Fatal("Error closing stream:", err) + } +} |