| // 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. | 
 |  | 
 | // Internally a map holds elements in up to 255 bytes of key+value. | 
 | // When key or value or both are too large, it uses pointers to key+value | 
 | // instead.  Test all the combinations. | 
 |  | 
 | package main | 
 |  | 
 | func seq(x, y int) [1000]byte { | 
 | 	var r [1000]byte | 
 | 	for i := 0; i < len(r); i++ { | 
 | 		r[i] = byte(x + i*y) | 
 | 	} | 
 | 	return r | 
 | } | 
 |  | 
 | func cmp(x, y [1000]byte) { | 
 | 	for i := 0; i < len(x); i++ { | 
 | 		if x[i] != y[i] { | 
 | 			panic("BUG mismatch") | 
 | 		} | 
 | 	} | 
 | } | 
 |  | 
 | func main() { | 
 | 	m := make(map[int][1000]byte) | 
 | 	m[1] = seq(11, 13) | 
 | 	m[2] = seq(2, 9) | 
 | 	m[3] = seq(3, 17) | 
 |  | 
 | 	cmp(m[1], seq(11, 13)) | 
 | 	cmp(m[2], seq(2, 9)) | 
 | 	cmp(m[3], seq(3, 17)) | 
 | 	 | 
 |  | 
 | 	{ | 
 | 		type T [1]byte | 
 | 		type V [1]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 |   	} | 
 | 	{ | 
 | 		type T [100]byte | 
 | 		type V [1]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [1]byte | 
 | 		type V [100]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [1000]byte | 
 | 		type V [1]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [1]byte | 
 | 		type V [1000]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [1000]byte | 
 | 		type V [1000]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [200]byte | 
 | 		type V [1]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [1]byte | 
 | 		type V [200]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 | 		} | 
 | 	} | 
 | 	{ | 
 | 		type T [200]byte | 
 | 		type V [200]byte | 
 | 		m := make(map[T]V) | 
 | 		m[T{}] = V{1} | 
 | 		m[T{1}] = V{2} | 
 | 		if x, y := m[T{}][0], m[T{1}][0]; x != 1 || y != 2 { | 
 | 			println(x, y) | 
 | 			panic("bad map") | 
 |   		} | 
 |   	} | 
 | } |