Commit 4c5c0f43 authored by Russ Cox's avatar Russ Cox

update tests for CL 30586.

won't submit unless 30586 goes in.

R=r
DELTA=94  (65 added, 16 deleted, 13 changed)
OCL=30592
CL=30755
parent eaa92e02
...@@ -9,7 +9,7 @@ package main ...@@ -9,7 +9,7 @@ package main
func putint(digits *string) { func putint(digits *string) {
var i byte; var i byte;
i = (*digits)[7]; // compiles i = (*digits)[7]; // compiles
i = digits[7]; // doesn't compile i = digits[7]; // ERROR "illegal"
} }
func main() { func main() {
...@@ -21,5 +21,5 @@ func main() { ...@@ -21,5 +21,5 @@ func main() {
bug022.go:8: illegal types for operand bug022.go:8: illegal types for operand
(*<string>*STRING) INDEXPTR (<int32>INT32) (*<string>*STRING) INDEXPTR (<int32>INT32)
bug022.go:8: illegal types for operand bug022.go:8: illegal types for operand
(<uint8>UINT8) AS (<uint8>UINT8) AS
*/ */
...@@ -12,7 +12,6 @@ func foo(a []int) int { ...@@ -12,7 +12,6 @@ func foo(a []int) int {
func main() { func main() {
a := &[]int{12}; a := &[]int{12};
if x := a[0] ; x != 12 { panicln(1) }
if x := (*a)[0]; x != 12 { panicln(2) } if x := (*a)[0]; x != 12 { panicln(2) }
if x := foo(*a) ; x != 12 { panicln(3) } // fails (x is incorrect) if x := foo(*a) ; x != 12 { panicln(3) } // fails (x is incorrect)
} }
...@@ -28,5 +27,5 @@ panic on line 83 PC=0x14d6 ...@@ -28,5 +27,5 @@ panic on line 83 PC=0x14d6
0x52bb?zi 0x52bb?zi
mainstart(1, 0, 1606416432, ...) mainstart(1, 0, 1606416432, ...)
mainstart(0x1, 0x7fff5fbff830, 0x0, ...) mainstart(0x1, 0x7fff5fbff830, 0x0, ...)
uetli:~/Source/go1/test/bugs gri$ uetli:~/Source/go1/test/bugs gri$
*/ */
...@@ -8,9 +8,9 @@ package main ...@@ -8,9 +8,9 @@ package main
type myMap map[string] int; type myMap map[string] int;
func f() *myMap { func f() myMap {
m := make(map[string] int); m := make(map[string] int);
return &m return m
} }
func main() { func main() {
...@@ -23,9 +23,6 @@ func main() { ...@@ -23,9 +23,6 @@ func main() {
{ {
x, ok := (*mp)["key"] x, ok := (*mp)["key"]
} }
{
x, ok := mp["key"]
}
{ {
x, ok := f()["key"] x, ok := f()["key"]
} }
......
...@@ -33,11 +33,7 @@ func crash() ...@@ -33,11 +33,7 @@ func crash()
// these uses of nil pointers // these uses of nil pointers
// would crash but should type check // would crash but should type check
println("crash", println("crash",
len(m1)+ len(a1) + cap(a1));
len(s1)+
len(a1)+
len(b1)+
cap(b1));
} }
func nocrash() func nocrash()
...@@ -49,19 +45,15 @@ func nocrash() ...@@ -49,19 +45,15 @@ func nocrash()
// it might also help in the traceback. // it might also help in the traceback.
x := x :=
len(m0)+ len(m0)+
len(m2)+ len(m3);
len(m3)+ if x != 1 {
len(m4);
if x != 2 {
panicln("wrong maplen"); panicln("wrong maplen");
} }
x = x =
len(s0)+ len(s0)+
len(s2)+ len(s3);
len(s3)+ if x != 1 {
len(s4);
if x != 2 {
panicln("wrong stringlen"); panicln("wrong stringlen");
} }
...@@ -74,19 +66,15 @@ func nocrash() ...@@ -74,19 +66,15 @@ func nocrash()
x = x =
len(b0)+ len(b0)+
len(b2)+ len(b3);
len(b3)+ if x != 3 {
len(b4);
if x != 6 {
panicln("wrong slicelen"); panicln("wrong slicelen");
} }
x = x =
cap(b0)+ cap(b0)+
cap(b2)+ cap(b3);
cap(b3)+ if x != 3 {
cap(b4);
if x != 6 {
panicln("wrong slicecap"); panicln("wrong slicecap");
} }
} }
......
// errchk $G -e $D/$F.go
// 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.
package main
var m0 map[string]int
var m1 *map[string]int
var m2 *map[string]int = &m0
var m3 map[string]int = map[string]int{"a": 1}
var m4 *map[string]int = &m3
var s0 string
var s1 *string
var s2 *string = &s0
var s3 string = "a"
var s4 *string = &s3
var a0 [10]int
var a1 *[10]int
var a2 *[10]int = &a0
var b0 []int
var b1 *[]int
var b2 *[]int = &b0
var b3 []int = []int{1, 2, 3}
var b4 *[]int = &b3
func f()
{
// this is spaced funny so that
// the compiler will print a different
// line number for each len call when
// it decides there are type errors.
x :=
len(m0)+
len(m1)+ // ERROR "illegal"
len(m2)+ // ERROR "illegal"
len(m3)+
len(m4)+ // ERROR "illegal"
len(s0)+
len(s1)+ // ERROR "illegal"
len(s2)+ // ERROR "illegal"
len(s3)+
len(s4)+ // ERROR "illegal"
len(a0)+
len(a1)+
len(a2)+
cap(a0)+
cap(a1)+
cap(a2)+
len(b0)+
len(b1)+ // ERROR "illegal"
len(b2)+ // ERROR "illegal"
len(b3)+
len(b4)+ // ERROR "illegal"
cap(b0)+
cap(b1)+ // ERROR "illegal"
cap(b2)+ // ERROR "illegal"
cap(b3)+
cap(b4); // ERROR "illegal"
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment