Commit 28ac033b authored by Mikkel Krautz's avatar Mikkel Krautz Committed by Andrew Gerrand

dist: make sure OS X packages follow symlinks when installing

R=adg
CC=golang-dev
https://golang.org/cl/5970061
parent cb871ce3
...@@ -240,6 +240,11 @@ func (b *Build) Do() error { ...@@ -240,6 +240,11 @@ func (b *Build) Do() error {
return err return err
} }
// build package // build package
pkginfo, err := createPackageInfo(work)
if err != nil {
return err
}
defer os.Remove(pkginfo)
pm := packageMaker pm := packageMaker
if !exists(pm) { if !exists(pm) {
pm = "/Developer" + pm pm = "/Developer" + pm
...@@ -252,11 +257,10 @@ func (b *Build) Do() error { ...@@ -252,11 +257,10 @@ func (b *Build) Do() error {
_, err = b.run("", pm, "-v", _, err = b.run("", pm, "-v",
"-r", work, "-r", work,
"-o", targ, "-o", targ,
"--info", pkginfo,
"--scripts", scripts, "--scripts", scripts,
"--id", "com.googlecode.go",
"--title", "Go", "--title", "Go",
"--version", "1.0", "--target", "10.5")
"--target", "10.6")
targs = append(targs, targ) targs = append(targs, targ)
case "windows": case "windows":
// Create ZIP file. // Create ZIP file.
...@@ -794,3 +798,30 @@ func tarFileInfoHeader(fi os.FileInfo, filename string) (*tar.Header, error) { ...@@ -794,3 +798,30 @@ func tarFileInfoHeader(fi os.FileInfo, filename string) (*tar.Header, error) {
} }
return h, nil return h, nil
} }
// createPackageInfo creates a PackageInfo template file for use with PackageMaker.
// The returned filename points to a file in a temporary directory on the filesystem,
// and should be removed after use.
func createPackageInfo(work string) (filename string, err error) {
var size, nfiles int64
err = filepath.Walk(work, func(path string, info os.FileInfo, err error) error {
nfiles++
size += info.Size()
return nil
})
if err != nil {
return "", err
}
pi, err := ioutil.TempFile("", "PackageInfo")
if err != nil {
return "", err
}
defer pi.Close()
_, err = fmt.Fprintf(pi, "<pkg-info identifier=\"com.googlecode.go\" version=\"1.0\" followSymLinks=\"true\">\n"+
"\t<payload installKBytes=\"%v\" numberOfFiles=\"%v\"/>\n"+
"</pkg-info>\n", size/1024, nfiles)
if err != nil {
return "", err
}
return pi.Name(), nil
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment