From 7f880650f76417b4010da786f4c82009a987d4ab Mon Sep 17 00:00:00 2001 From: Russ Cox Date: Sat, 1 May 2010 13:15:42 -0700 Subject: gc: be pickier about slice, chan, array, and map sizes Fixes issue 589. R=ken2 CC=golang-dev http://codereview.appspot.com/1032044 --- test/fixedbugs/bug273.go | 95 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 95 insertions(+) create mode 100644 test/fixedbugs/bug273.go (limited to 'test/fixedbugs/bug273.go') diff --git a/test/fixedbugs/bug273.go b/test/fixedbugs/bug273.go new file mode 100644 index 000000000..ff8f1c6af --- /dev/null +++ b/test/fixedbugs/bug273.go @@ -0,0 +1,95 @@ +// $G $D/$F.go && $L $F.$A && ./$A.out + +// Copyright 2010 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. + +// http://code.google.com/p/go/issues/detail?id=589 + +package main + +import "unsafe" + +var bug = false + +var minus1 = -1 +var big int64 = 10 | 1<<32 + +func shouldfail(f func(), desc string) { + defer func() { recover() }() + f() + if !bug { + println("BUG") + bug = true + } + println("didn't crash: ", desc) +} + +func badlen() { + _ = make([]int, minus1) +} + +func biglen() { + _ = make([]int, big) +} + +func badcap() { + _ = make([]int, 10, minus1) +} + +func badcap1() { + _ = make([]int, 10, 5) +} + +func bigcap() { + _ = make([]int, 10, big) +} + +const ( + addrBits = 8*uint(unsafe.Sizeof((*byte)(nil))) + sh = addrBits/2 - 2 +) +func overflow() { + _ = make([][1<