Commit 340129e4 authored by Daniel Martí's avatar Daniel Martí

all: join a few chained ifs

I had been finding these over a year or so, but none were big enough
changes to warrant CLs. They're a handful now, so clean them all up in a
single commit.

The smaller bodies get a bit simpler, but most importantly, the larger
bodies get unindented.

Change-Id: I5707a6fee27d4c9ff9efd3d363af575d7a4bf2aa
Reviewed-on: https://go-review.googlesource.com/c/go/+/165340
Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent a125bdb4
...@@ -392,20 +392,16 @@ func newTypeEncoder(t reflect.Type, allowAddr bool) encoderFunc { ...@@ -392,20 +392,16 @@ func newTypeEncoder(t reflect.Type, allowAddr bool) encoderFunc {
if t.Implements(marshalerType) { if t.Implements(marshalerType) {
return marshalerEncoder return marshalerEncoder
} }
if t.Kind() != reflect.Ptr && allowAddr { if t.Kind() != reflect.Ptr && allowAddr && reflect.PtrTo(t).Implements(marshalerType) {
if reflect.PtrTo(t).Implements(marshalerType) {
return newCondAddrEncoder(addrMarshalerEncoder, newTypeEncoder(t, false)) return newCondAddrEncoder(addrMarshalerEncoder, newTypeEncoder(t, false))
} }
}
if t.Implements(textMarshalerType) { if t.Implements(textMarshalerType) {
return textMarshalerEncoder return textMarshalerEncoder
} }
if t.Kind() != reflect.Ptr && allowAddr { if t.Kind() != reflect.Ptr && allowAddr && reflect.PtrTo(t).Implements(textMarshalerType) {
if reflect.PtrTo(t).Implements(textMarshalerType) {
return newCondAddrEncoder(addrTextMarshalerEncoder, newTypeEncoder(t, false)) return newCondAddrEncoder(addrTextMarshalerEncoder, newTypeEncoder(t, false))
} }
}
switch t.Kind() { switch t.Kind() {
case reflect.Bool: case reflect.Bool:
......
...@@ -749,11 +749,9 @@ func (cr *connReader) handleReadError(_ error) { ...@@ -749,11 +749,9 @@ func (cr *connReader) handleReadError(_ error) {
// may be called from multiple goroutines. // may be called from multiple goroutines.
func (cr *connReader) closeNotify() { func (cr *connReader) closeNotify() {
res, _ := cr.conn.curReq.Load().(*response) res, _ := cr.conn.curReq.Load().(*response)
if res != nil { if res != nil && atomic.CompareAndSwapInt32(&res.didCloseNotify, 0, 1) {
if atomic.CompareAndSwapInt32(&res.didCloseNotify, 0, 1) {
res.closeNotifyCh <- true res.closeNotifyCh <- true
} }
}
} }
func (cr *connReader) Read(p []byte) (n int, err error) { func (cr *connReader) Read(p []byte) (n int, err error) {
......
...@@ -729,11 +729,9 @@ func (q *waitq) dequeue() *sudog { ...@@ -729,11 +729,9 @@ func (q *waitq) dequeue() *sudog {
// We use a flag in the G struct to tell us when someone // We use a flag in the G struct to tell us when someone
// else has won the race to signal this goroutine but the goroutine // else has won the race to signal this goroutine but the goroutine
// hasn't removed itself from the queue yet. // hasn't removed itself from the queue yet.
if sgp.isSelect { if sgp.isSelect && !atomic.Cas(&sgp.g.selectDone, 0, 1) {
if !atomic.Cas(&sgp.g.selectDone, 0, 1) {
continue continue
} }
}
return sgp return sgp
} }
......
...@@ -46,11 +46,10 @@ func (c *sigctxt) fault() uintptr { return uintptr(c.sigaddr()) } ...@@ -46,11 +46,10 @@ func (c *sigctxt) fault() uintptr { return uintptr(c.sigaddr()) }
// preparePanic sets up the stack to look like a call to sigpanic. // preparePanic sets up the stack to look like a call to sigpanic.
func (c *sigctxt) preparePanic(sig uint32, gp *g) { func (c *sigctxt) preparePanic(sig uint32, gp *g) {
if GOOS == "darwin" {
// Work around Leopard bug that doesn't set FPE_INTDIV. // Work around Leopard bug that doesn't set FPE_INTDIV.
// Look at instruction to see if it is a divide. // Look at instruction to see if it is a divide.
// Not necessary in Snow Leopard (si_code will be != 0). // Not necessary in Snow Leopard (si_code will be != 0).
if sig == _SIGFPE && gp.sigcode0 == 0 { if GOOS == "darwin" && sig == _SIGFPE && gp.sigcode0 == 0 {
pc := (*[4]byte)(unsafe.Pointer(gp.sigpc)) pc := (*[4]byte)(unsafe.Pointer(gp.sigpc))
i := 0 i := 0
if pc[i]&0xF0 == 0x40 { // 64-bit REX prefix if pc[i]&0xF0 == 0x40 { // 64-bit REX prefix
...@@ -62,7 +61,6 @@ func (c *sigctxt) preparePanic(sig uint32, gp *g) { ...@@ -62,7 +61,6 @@ func (c *sigctxt) preparePanic(sig uint32, gp *g) {
gp.sigcode0 = _FPE_INTDIV gp.sigcode0 = _FPE_INTDIV
} }
} }
}
pc := uintptr(c.rip()) pc := uintptr(c.rip())
sp := uintptr(c.rsp()) sp := uintptr(c.rsp())
......
...@@ -503,17 +503,15 @@ func raisebadsignal(sig uint32, c *sigctxt) { ...@@ -503,17 +503,15 @@ func raisebadsignal(sig uint32, c *sigctxt) {
//go:nosplit //go:nosplit
func crash() { func crash() {
if GOOS == "darwin" {
// OS X core dumps are linear dumps of the mapped memory, // OS X core dumps are linear dumps of the mapped memory,
// from the first virtual byte to the last, with zeros in the gaps. // from the first virtual byte to the last, with zeros in the gaps.
// Because of the way we arrange the address space on 64-bit systems, // Because of the way we arrange the address space on 64-bit systems,
// this means the OS X core file will be >128 GB and even on a zippy // this means the OS X core file will be >128 GB and even on a zippy
// workstation can take OS X well over an hour to write (uninterruptible). // workstation can take OS X well over an hour to write (uninterruptible).
// Save users from making that mistake. // Save users from making that mistake.
if GOARCH == "amd64" { if GOOS == "darwin" && GOARCH == "amd64" {
return return
} }
}
dieFromSignal(_SIGABRT) dieFromSignal(_SIGABRT)
} }
......
...@@ -1303,7 +1303,6 @@ func toOutputDir(path string) string { ...@@ -1303,7 +1303,6 @@ func toOutputDir(path string) string {
if *outputDir == "" || path == "" { if *outputDir == "" || path == "" {
return path return path
} }
if runtime.GOOS == "windows" {
// On Windows, it's clumsy, but we can be almost always correct // On Windows, it's clumsy, but we can be almost always correct
// by just looking for a drive letter and a colon. // by just looking for a drive letter and a colon.
// Absolute paths always have a drive letter (ignoring UNC). // Absolute paths always have a drive letter (ignoring UNC).
...@@ -1311,14 +1310,13 @@ func toOutputDir(path string) string { ...@@ -1311,14 +1310,13 @@ func toOutputDir(path string) string {
// what to do, but even then path/filepath doesn't help. // what to do, but even then path/filepath doesn't help.
// TODO: Worth doing better? Probably not, because we're here only // TODO: Worth doing better? Probably not, because we're here only
// under the management of go test. // under the management of go test.
if len(path) >= 2 { if runtime.GOOS == "windows" && len(path) >= 2 {
letter, colon := path[0], path[1] letter, colon := path[0], path[1]
if ('a' <= letter && letter <= 'z' || 'A' <= letter && letter <= 'Z') && colon == ':' { if ('a' <= letter && letter <= 'z' || 'A' <= letter && letter <= 'Z') && colon == ':' {
// If path starts with a drive letter we're stuck with it regardless. // If path starts with a drive letter we're stuck with it regardless.
return path return path
} }
} }
}
if os.IsPathSeparator(path[0]) { if os.IsPathSeparator(path[0]) {
return path return path
} }
......
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