Commit 2b8e143d authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/vet: infer asm arch from build context

If we cannot infer the asm arch from the filename
or the build tags, assume that it is the
current build arch. Assembly files with no
restrictions ought to be usable on all arches.

Updates #11041

Change-Id: I0ae807dbbd5fb67ca21d0157fe180237a074113a
Reviewed-on: https://go-review.googlesource.com/27151
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarRob Pike <r@golang.org>
parent 752e1615
...@@ -10,6 +10,7 @@ import ( ...@@ -10,6 +10,7 @@ import (
"bytes" "bytes"
"fmt" "fmt"
"go/ast" "go/ast"
"go/build"
"go/token" "go/token"
"regexp" "regexp"
"strconv" "strconv"
...@@ -178,10 +179,19 @@ Files: ...@@ -178,10 +179,19 @@ Files:
if m := asmTEXT.FindStringSubmatch(line); m != nil { if m := asmTEXT.FindStringSubmatch(line); m != nil {
flushRet() flushRet()
if arch == "" {
for _, a := range arches {
if a.name == build.Default.GOARCH {
arch = a.name
archDef = a
break
}
}
if arch == "" { if arch == "" {
f.Warnf(token.NoPos, "%s: cannot determine architecture for assembly file", f.name) f.Warnf(token.NoPos, "%s: cannot determine architecture for assembly file", f.name)
continue Files continue Files
} }
}
fnName = m[1] fnName = m[1]
fn = knownFunc[m[1]][arch] fn = knownFunc[m[1]][arch]
if fn != nil { if fn != 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