This repository has been archived by the owner on May 15, 2023. It is now read-only.
/
package.go
73 lines (60 loc) · 1.6 KB
/
package.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
package main
import (
"archive/tar"
"compress/gzip"
"fmt"
"io"
"os"
"path"
"path/filepath"
)
func buildPackage(app application, writer io.WriteCloser, files <-chan FileStat) error {
destBaseDir := app.tarPrefix
defer closer(writer)
gw, err := gzip.NewWriterLevel(writer, gzip.BestCompression)
if err != nil {
return err
}
defer closer(gw)
tw := tar.NewWriter(gw)
defer closer(tw)
var compressed int64
var size int64
for file := range files {
written, err := addFile(tw, destBaseDir, file)
if err != nil {
return err
}
size = size + written
compressed++
}
app.Debugf("%d files (%s) were compressed into a tar\n", compressed, byteCountDecimal(size))
return nil
}
func addFile(tw *tar.Writer, destBaseDir string, file FileStat) (int64, error) {
header, err := tar.FileInfoHeader(file.stat, file.link)
if err != nil {
return 0, fmt.Errorf("FileInfoHeader: %s", err)
}
// tweak the Name inside the tar so that get tar:ed out properly
header.Name = filepath.Join(destBaseDir, file.relativePath)
// write the header to the tarball archive
if err := tw.WriteHeader(header); err != nil {
return 0, fmt.Errorf("WriteHeader: %s", err)
}
// return on non-regular files, no other data to copy into the tarball
if !file.stat.Mode().IsRegular() {
return 0, nil
}
f, err := os.Open(path.Join(file.baseDir, file.relativePath))
if err != nil {
return 0, fmt.Errorf("cant open file: %s", err)
}
defer closer(f)
// copy the file data to the tarball
n, err := io.Copy(tw, f)
if err != nil {
return n, fmt.Errorf("can't copy file data into tarball: %s", err)
}
return n, nil
}