Commit 708304be authored by Ian Lance Taylor's avatar Ian Lance Taylor

cmd/go: check for SWIG version that is too old to use

Fixes #7983.

LGTM=crawshaw
R=golang-codereviews, crawshaw
CC=golang-codereviews, rsc
https://golang.org/cl/96540044
parent e22705bf
...@@ -2348,6 +2348,10 @@ func (b *builder) swig(p *Package, obj string, gccfiles, gxxfiles, mfiles []stri ...@@ -2348,6 +2348,10 @@ func (b *builder) swig(p *Package, obj string, gccfiles, gxxfiles, mfiles []stri
outObj = append(outObj, ofile) outObj = append(outObj, ofile)
} }
if err := b.swigVersionCheck(); err != nil {
return nil, nil, err
}
intgosize, err := b.swigIntSize(obj) intgosize, err := b.swigIntSize(obj)
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
...@@ -2386,6 +2390,41 @@ func (b *builder) swig(p *Package, obj string, gccfiles, gxxfiles, mfiles []stri ...@@ -2386,6 +2390,41 @@ func (b *builder) swig(p *Package, obj string, gccfiles, gxxfiles, mfiles []stri
return outGo, outObj, nil return outGo, outObj, nil
} }
// Make sure SWIG is new enough.
var (
swigCheckOnce sync.Once
swigCheck error
)
func (b *builder) swigDoVersionCheck() error {
out, err := b.runOut("", "", nil, "swig", "-version")
if err != nil {
return err
}
re := regexp.MustCompile(`[vV]ersion +([\d])`)
matches := re.FindSubmatch(out)
if matches == nil {
// Can't find version number; hope for the best.
return nil
}
major, err := strconv.Atoi(string(matches[1]))
if err != nil {
// Can't find version number; hope for the best.
return nil
}
if major < 3 {
return errors.New("must have SWIG version >= 3.0")
}
return nil
}
func (b *builder) swigVersionCheck() error {
swigCheckOnce.Do(func() {
swigCheck = b.swigDoVersionCheck()
})
return swigCheck
}
// This code fails to build if sizeof(int) <= 32 // This code fails to build if sizeof(int) <= 32
const swigIntSizeCode = ` const swigIntSizeCode = `
package main package main
...@@ -2458,7 +2497,7 @@ func (b *builder) swigOne(p *Package, file, obj string, cxx bool, intgosize stri ...@@ -2458,7 +2497,7 @@ func (b *builder) swigOne(p *Package, file, obj string, cxx bool, intgosize stri
if out, err := b.runOut(p.Dir, p.ImportPath, nil, "swig", args, file); err != nil { if out, err := b.runOut(p.Dir, p.ImportPath, nil, "swig", args, file); err != nil {
if len(out) > 0 { if len(out) > 0 {
if bytes.Contains(out, []byte("Unrecognized option -intgosize")) { if bytes.Contains(out, []byte("Unrecognized option -intgosize")) {
return "", "", "", errors.New("must have SWIG version >= 3.0\n") return "", "", "", errors.New("must have SWIG version >= 3.0")
} }
b.showOutput(p.Dir, p.ImportPath, b.processOutput(out)) b.showOutput(p.Dir, p.ImportPath, b.processOutput(out))
return "", "", "", errPrintedOutput return "", "", "", errPrintedOutput
......
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