mirror of
				https://github.com/golang/go.git
				synced 2025-10-31 16:50:58 +00:00 
			
		
		
		
	 ac1d440ea6
			
		
	
	
		ac1d440ea6
		
	
	
	
	
		
			
			ORUNESTR represents the special case of integer->string conversion. If the integer is a constant, then the string is a constant too, so evconst needs to perform constant folding here. Passes toolstash-check. Fixes #34563. Change-Id: Ieab3d76794d8ce570106b6b707a4bcd725d156e9 Reviewed-on: https://go-review.googlesource.com/c/go/+/197677 Run-TryBot: Matthew Dempsky <mdempsky@google.com> Reviewed-by: Robert Griesemer <gri@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
		
			
				
	
	
		
			210 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // run
 | |
| 
 | |
| // Copyright 2009 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.
 | |
| 
 | |
| // Test simple boolean and numeric constants.
 | |
| 
 | |
| package main
 | |
| 
 | |
| import "os"
 | |
| 
 | |
| const (
 | |
| 	c0      = 0
 | |
| 	cm1     = -1
 | |
| 	chuge   = 1 << 100
 | |
| 	chuge_1 = chuge - 1
 | |
| 	c1      = chuge >> 100
 | |
| 	c3div2  = 3 / 2
 | |
| 	c1e3    = 1e3
 | |
| 
 | |
| 	rsh1 = 1e100 >> 1000
 | |
| 	rsh2 = 1e302 >> 1000
 | |
| 
 | |
| 	ctrue  = true
 | |
| 	cfalse = !ctrue
 | |
| 
 | |
| 	// Issue #34563
 | |
| 	_ = string(int(123))
 | |
| 	_ = string(rune(456))
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	f0              = 0.0
 | |
| 	fm1             = -1.
 | |
| 	fhuge   float64 = 1 << 100
 | |
| 	fhuge_1 float64 = chuge - 1
 | |
| 	f1      float64 = chuge >> 100
 | |
| 	f3div2          = 3. / 2.
 | |
| 	f1e3    float64 = 1e3
 | |
| )
 | |
| 
 | |
| func assert(t bool, s string) {
 | |
| 	if !t {
 | |
| 		panic(s)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func ints() {
 | |
| 	assert(c0 == 0, "c0")
 | |
| 	assert(c1 == 1, "c1")
 | |
| 	assert(chuge > chuge_1, "chuge")
 | |
| 	assert(chuge_1+1 == chuge, "chuge 1")
 | |
| 	assert(chuge+cm1+1 == chuge, "cm1")
 | |
| 	assert(c3div2 == 1, "3/2")
 | |
| 	assert(c1e3 == 1000, "c1e3 int")
 | |
| 	assert(c1e3 == 1e3, "c1e3 float")
 | |
| 	assert(rsh1 == 0, "rsh1")
 | |
| 	assert(rsh2 == 9, "rsh2")
 | |
| 
 | |
| 	// verify that all (in range) are assignable as ints
 | |
| 	var i int
 | |
| 	i = c0
 | |
| 	assert(i == c0, "i == c0")
 | |
| 	i = cm1
 | |
| 	assert(i == cm1, "i == cm1")
 | |
| 	i = c1
 | |
| 	assert(i == c1, "i == c1")
 | |
| 	i = c3div2
 | |
| 	assert(i == c3div2, "i == c3div2")
 | |
| 	i = c1e3
 | |
| 	assert(i == c1e3, "i == c1e3")
 | |
| 
 | |
| 	// verify that all are assignable as floats
 | |
| 	var f float64
 | |
| 	f = c0
 | |
| 	assert(f == c0, "f == c0")
 | |
| 	f = cm1
 | |
| 	assert(f == cm1, "f == cm1")
 | |
| 	f = chuge
 | |
| 	assert(f == chuge, "f == chuge")
 | |
| 	f = chuge_1
 | |
| 	assert(f == chuge_1, "f == chuge_1")
 | |
| 	f = c1
 | |
| 	assert(f == c1, "f == c1")
 | |
| 	f = c3div2
 | |
| 	assert(f == c3div2, "f == c3div2")
 | |
| 	f = c1e3
 | |
| 	assert(f == c1e3, "f == c1e3")
 | |
| }
 | |
| 
 | |
| func floats() {
 | |
| 	assert(f0 == c0, "f0")
 | |
| 	assert(f1 == c1, "f1")
 | |
| 	// TODO(gri): exp/ssa/interp constant folding is incorrect.
 | |
| 	if os.Getenv("GOSSAINTERP") == "" {
 | |
| 		assert(fhuge == fhuge_1, "fhuge") // float64 can't distinguish fhuge, fhuge_1.
 | |
| 	}
 | |
| 	assert(fhuge_1+1 == fhuge, "fhuge 1")
 | |
| 	assert(fhuge+fm1+1 == fhuge, "fm1")
 | |
| 	assert(f3div2 == 1.5, "3./2.")
 | |
| 	assert(f1e3 == 1000, "f1e3 int")
 | |
| 	assert(f1e3 == 1.e3, "f1e3 float")
 | |
| 
 | |
| 	// verify that all (in range) are assignable as ints
 | |
| 	var i int
 | |
| 	i = f0
 | |
| 	assert(i == f0, "i == f0")
 | |
| 	i = fm1
 | |
| 	assert(i == fm1, "i == fm1")
 | |
| 
 | |
| 	// verify that all are assignable as floats
 | |
| 	var f float64
 | |
| 	f = f0
 | |
| 	assert(f == f0, "f == f0")
 | |
| 	f = fm1
 | |
| 	assert(f == fm1, "f == fm1")
 | |
| 	f = fhuge
 | |
| 	assert(f == fhuge, "f == fhuge")
 | |
| 	f = fhuge_1
 | |
| 	assert(f == fhuge_1, "f == fhuge_1")
 | |
| 	f = f1
 | |
| 	assert(f == f1, "f == f1")
 | |
| 	f = f3div2
 | |
| 	assert(f == f3div2, "f == f3div2")
 | |
| 	f = f1e3
 | |
| 	assert(f == f1e3, "f == f1e3")
 | |
| }
 | |
| 
 | |
| func interfaces() {
 | |
| 	var (
 | |
| 		nilN interface{}
 | |
| 		nilI *int
 | |
| 		five = 5
 | |
| 
 | |
| 		_ = nil == interface{}(nil)
 | |
| 		_ = interface{}(nil) == nil
 | |
| 	)
 | |
| 	ii := func(i1 interface{}, i2 interface{}) bool { return i1 == i2 }
 | |
| 	ni := func(n interface{}, i int) bool { return n == i }
 | |
| 	in := func(i int, n interface{}) bool { return i == n }
 | |
| 	pi := func(p *int, i interface{}) bool { return p == i }
 | |
| 	ip := func(i interface{}, p *int) bool { return i == p }
 | |
| 
 | |
| 	assert((interface{}(nil) == interface{}(nil)) == ii(nilN, nilN),
 | |
| 		"for interface{}==interface{} compiler == runtime")
 | |
| 
 | |
| 	assert(((*int)(nil) == interface{}(nil)) == pi(nilI, nilN),
 | |
| 		"for *int==interface{} compiler == runtime")
 | |
| 	assert((interface{}(nil) == (*int)(nil)) == ip(nilN, nilI),
 | |
| 		"for interface{}==*int compiler == runtime")
 | |
| 
 | |
| 	assert((&five == interface{}(nil)) == pi(&five, nilN),
 | |
| 		"for interface{}==*int compiler == runtime")
 | |
| 	assert((interface{}(nil) == &five) == ip(nilN, &five),
 | |
| 		"for interface{}==*int compiler == runtime")
 | |
| 
 | |
| 	assert((5 == interface{}(5)) == ni(five, five),
 | |
| 		"for int==interface{} compiler == runtime")
 | |
| 	assert((interface{}(5) == 5) == in(five, five),
 | |
| 		"for interface{}==int comipiler == runtime")
 | |
| }
 | |
| 
 | |
| // Test that typed floating-point and complex arithmetic
 | |
| // is computed with correct precision.
 | |
| func truncate() {
 | |
| 	const (
 | |
| 		x30 = 1 << 30
 | |
| 		x60 = 1 << 60
 | |
| 
 | |
| 		staticF32 = float32(x30) + 1 - x30
 | |
| 		staticF64 = float64(x60) + 1 - x60
 | |
| 		staticC64 = complex64(x30) + 1 - x30
 | |
| 		staticC128 = complex128(x60) + 1 - x60
 | |
| 	)
 | |
| 	dynamicF32 := float32(x30)
 | |
| 	dynamicF32 += 1
 | |
| 	dynamicF32 -= x30
 | |
| 
 | |
| 	dynamicF64 := float64(x60)
 | |
| 	dynamicF64 += 1
 | |
| 	dynamicF64 -= x60
 | |
| 
 | |
| 	dynamicC64 := complex64(x30)
 | |
| 	dynamicC64 += 1
 | |
| 	dynamicC64 -= x30
 | |
| 
 | |
| 	dynamicC128 := complex128(x60)
 | |
| 	dynamicC128 += 1
 | |
| 	dynamicC128 -= x60
 | |
| 
 | |
| 	assert(staticF32 == 0, "staticF32 == 0")
 | |
| 	assert(staticF64 == 0, "staticF64 == 0")
 | |
| 	assert(dynamicF32 == 0, "dynamicF32 == 0")
 | |
| 	assert(dynamicF64 == 0, "dynamicF64 == 0")
 | |
| 	assert(staticC64 == 0, "staticC64 == 0")
 | |
| 	assert(staticC128 == 0, "staticC128 == 0")
 | |
| 	assert(dynamicC64 == 0, "dynamicC64 == 0")
 | |
| 	assert(dynamicC128 == 0, "dynamicC128 == 0")
 | |
| }
 | |
| 
 | |
| func main() {
 | |
| 	ints()
 | |
| 	floats()
 | |
| 	interfaces()
 | |
| 	truncate()
 | |
| 
 | |
| 	assert(ctrue == true, "ctrue == true")
 | |
| 	assert(cfalse == false, "cfalse == false")
 | |
| }
 |