File: issue11326.go

package info (click to toggle)
golang 2%3A1.5.3-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 56,996 kB
  • ctags: 113,101
  • sloc: asm: 31,099; ansic: 6,131; yacc: 2,100; sh: 1,442; perl: 1,116; xml: 623; python: 286; makefile: 82; cpp: 22; awk: 7
file content (28 lines) | stat: -rw-r--r-- 1,210 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
// errorcheck

// Copyright 2015 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 main

import "fmt"

func main() {
	var g = 1e81391777742999 // ERROR "exponent too large"
	// The next should only cause a problem when converted to float64
	// by the assignment, but instead the compiler rejects it outright,
	// rather than mishandle it. Specifically, when handled, 'var h' prints:
	//	issue11326.go:N: constant 0.93342e+536870911 overflows float64
	// The rejection of 'var i' is just insurance. It seems to work correctly.
	// See golang.org/issue/11326.
	// var h = 1e2147483647     // should be "1.00000e+2147483647 overflows float64"
	var h = 1e2147483647 // ERROR "exponent too large"
	// var i = 1e214748364  // should be "1.00000e\+214748364 overflows float64"
	var i = 1e214748364 // ERROR "exponent too large"
	var j = 1e21474836  // ERROR "1.00000e\+21474836 overflows float64"
	var k = 1e2147483   // ERROR "1.00000e\+2147483 overflows float64"
	var l = 1e214748    // ERROR "1.00000e\+214748 overflows float64"
	var m = 1e21474     // ERROR "1.00000e\+21474 overflows float64"
	fmt.Println(g)
}