Adjust expected errors to work with gccgo.

The change to assign.go is because the gcc testsuite fails to
handle .* in a normal way: it matches against the entire
compiler output, not just a single line.

assign.go:15:6: error: incompatible types in assignment (implicit assignment of 'sync.Mutex' hidden field 'key')
assign.go:19:6: error: incompatible types in assignment (implicit assignment of 'sync.Mutex' hidden field 'key')
assign.go:23:6: error: incompatible types in assignment (implicit assignment of 'sync.Mutex' hidden field 'key')
assign.go:27:6: error: incompatible types in assignment (implicit assignment of 'sync.Mutex' hidden field 'key')

chan/perm.go:14:5: error: incompatible types in assignment
chan/perm.go:15:5: error: incompatible types in assignment
chan/perm.go:16:6: error: incompatible types in assignment
chan/perm.go:17:6: error: incompatible types in assignment
chan/perm.go:24:7: error: invalid send on receive-only channel
chan/perm.go:25:12: error: invalid send on receive-only channel
chan/perm.go:31:4: error: invalid receive on send-only channel
chan/perm.go:32:9: error: invalid receive on send-only channel
chan/perm.go:38:2: error: invalid send on receive-only channel
chan/perm.go:42:2: error: invalid receive on send-only channel

initializerr.go:14:17: error: reference to undefined variable 'X'
initializerr.go:14:19: error: mixture of field and value initializers
initializerr.go:15:26: error: duplicate value for field 'Y'
initializerr.go:16:10: error: too many values in struct composite literal
initializerr.go:18:19: error: index expression is not integer constant
initializerr.go:17:11: error: too many elements in composite literal

R=rsc
DELTA=12  (0 added, 0 deleted, 12 changed)
OCL=29657
CL=29665
diff --git a/test/assign.go b/test/assign.go
index a98b7b7..9fe9ea0 100644
--- a/test/assign.go
+++ b/test/assign.go
@@ -16,18 +16,18 @@
 func main() {
 	{
 		var x, y sync.Mutex;
-		x = y;	// ERROR "assignment.*Mutex"
+		x = y;	// ERROR "assignment\[ -~\]*Mutex"
 	}
 	{
 		var x, y T;
-		x = y;	// ERROR "assignment.*Mutex"
+		x = y;	// ERROR "assignment\[ -~\]*Mutex"
 	}
 	{
 		var x, y [2]sync.Mutex;
-		x = y;	// ERROR "assignment.*Mutex"
+		x = y;	// ERROR "assignment\[ -~\]*Mutex"
 	}
 	{
 		var x, y [2]T;
-		x = y;	// ERROR "assignment.*Mutex"
+		x = y;	// ERROR "assignment\[ -~\]*Mutex"
 	}
 }
diff --git a/test/chan/perm.go b/test/chan/perm.go
index 31ab840..cdbef62 100644
--- a/test/chan/perm.go
+++ b/test/chan/perm.go
@@ -15,10 +15,10 @@
 func main() {
 	cr = c;		// ok
 	cs = c;		// ok
-	c = cr;		// ERROR "illegal types"
-	c = cs;		// ERROR "illegal types"
-	cr = cs;	// ERROR "illegal types"
-	cs = cr;	// ERROR "illegal types"
+	c = cr;		// ERROR "illegal types|incompatible"
+	c = cs;		// ERROR "illegal types|incompatible"
+	cr = cs;	// ERROR "illegal types|incompatible"
+	cs = cr;	// ERROR "illegal types|incompatible"
 
 	c <- 0;		// ok
 	ok := c <- 0;	// ok
diff --git a/test/golden.out b/test/golden.out
index b5dbddf..131fc89 100644
--- a/test/golden.out
+++ b/test/golden.out
@@ -27,7 +27,7 @@
 hello, world
 
 =========== ./initializerr.go
-BUG: errchk: ./initializerr.go:17: missing expected error: 'index'
+BUG: errchk: ./initializerr.go:17: missing expected error: 'index|too many'
 
 =========== ./peano.go
 0! = 1
diff --git a/test/initializerr.go b/test/initializerr.go
index 2700ba0..b0366dd 100644
--- a/test/initializerr.go
+++ b/test/initializerr.go
@@ -15,10 +15,10 @@
 }
 
 var x = 1
-var a1 = S { 0, X: 1 };	// ERROR "mixture"
+var a1 = S { 0, X: 1 };	// ERROR "mixture|undefined"
 var a2 = S { Y: 3, Z: 2, Y: 3 }; // ERROR "duplicate"
-var a3 = T { 1, 2, 3, 4, 5, 6 };	// ERROR "convert"
-var a4 = [5]byte{ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }	// ERROR "index"
+var a3 = T { 1, 2, 3, 4, 5, 6 };	// ERROR "convert|too many"
+var a4 = [5]byte{ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }	// ERROR "index|too many"
 var a5 = []byte { x: 2 }	// ERROR "index"
 
 var ok1 = S { }	// should be ok