mirror of
https://github.com/golang/go.git
synced 2025-05-29 03:11:26 +00:00
Updates #59488. Change-Id: I254da7cca071eeb5af2f8aecdcd9461703fe8677 Reviewed-on: https://go-review.googlesource.com/c/go/+/496257 Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com> Auto-Submit: Matthew Dempsky <mdempsky@google.com> Reviewed-by: Keith Randall <khr@golang.org> TryBot-Result: Gopher Robot <gobot@golang.org> Run-TryBot: Matthew Dempsky <mdempsky@google.com> Reviewed-by: Keith Randall <khr@google.com>
73 lines
1.5 KiB
Go
73 lines
1.5 KiB
Go
// Copyright 2023 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package runtime
|
|
|
|
import "unsafe"
|
|
|
|
func strmin(x, y string) string {
|
|
if y < x {
|
|
return y
|
|
}
|
|
return x
|
|
}
|
|
|
|
func strmax(x, y string) string {
|
|
if y > x {
|
|
return y
|
|
}
|
|
return x
|
|
}
|
|
|
|
func fmin32(x, y float32) float32 { return fmin(x, y) }
|
|
func fmin64(x, y float64) float64 { return fmin(x, y) }
|
|
func fmax32(x, y float32) float32 { return fmax(x, y) }
|
|
func fmax64(x, y float64) float64 { return fmax(x, y) }
|
|
|
|
type floaty interface{ ~float32 | ~float64 }
|
|
|
|
func fmin[F floaty](x, y F) F {
|
|
if y != y || y < x {
|
|
return y
|
|
}
|
|
if x != x || x < y || x != 0 {
|
|
return x
|
|
}
|
|
// x and y are both ±0
|
|
// if either is -0, return -0; else return +0
|
|
return forbits(x, y)
|
|
}
|
|
|
|
func fmax[F floaty](x, y F) F {
|
|
if y != y || y > x {
|
|
return y
|
|
}
|
|
if x != x || x > y || x != 0 {
|
|
return x
|
|
}
|
|
// x and y are both ±0
|
|
// if both are -0, return -0; else return +0
|
|
return fandbits(x, y)
|
|
}
|
|
|
|
func forbits[F floaty](x, y F) F {
|
|
switch unsafe.Sizeof(x) {
|
|
case 4:
|
|
*(*uint32)(unsafe.Pointer(&x)) |= *(*uint32)(unsafe.Pointer(&y))
|
|
case 8:
|
|
*(*uint64)(unsafe.Pointer(&x)) |= *(*uint64)(unsafe.Pointer(&y))
|
|
}
|
|
return x
|
|
}
|
|
|
|
func fandbits[F floaty](x, y F) F {
|
|
switch unsafe.Sizeof(x) {
|
|
case 4:
|
|
*(*uint32)(unsafe.Pointer(&x)) &= *(*uint32)(unsafe.Pointer(&y))
|
|
case 8:
|
|
*(*uint64)(unsafe.Pointer(&x)) &= *(*uint64)(unsafe.Pointer(&y))
|
|
}
|
|
return x
|
|
}
|