github.com/aloncn/graphics-go@v0.0.1/src/go/types/testdata/builtins.src (about)

     1  // Copyright 2012 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  // builtin calls
     6  
     7  package builtins
     8  
     9  import "unsafe"
    10  
    11  func f0() {}
    12  
    13  func append1() {
    14  	var b byte
    15  	var x int
    16  	var s []byte
    17  	_ = append() // ERROR not enough arguments
    18  	_ = append("foo" /* ERROR not a slice */ )
    19  	_ = append(nil /* ERROR not a slice */ , s)
    20  	_ = append(x /* ERROR not a slice */ , s)
    21  	_ = append(s)
    22  	append /* ERROR not used */ (s)
    23  
    24  	_ = append(s, b)
    25  	_ = append(s, x /* ERROR cannot use x */ )
    26  	_ = append(s, s /* ERROR cannot use s */ )
    27  	_ = append(s... /* ERROR can only use ... with matching parameter */ )
    28  	_ = append(s, b, s... /* ERROR can only use ... with matching parameter */ )
    29  	_ = append(s, 1, 2, 3)
    30  	_ = append(s, 1, 2, 3, x /* ERROR cannot use x */ , 5, 6, 6)
    31  	_ = append(s, 1, 2, s... /* ERROR can only use ... with matching parameter */ )
    32  	_ = append([]interface{}(nil), 1, 2, "foo", x, 3.1425, false)
    33  
    34  	type S []byte
    35  	type T string
    36  	var t T
    37  	_ = append(s, "foo" /* ERROR cannot convert */ )
    38  	_ = append(s, "foo"...)
    39  	_ = append(S(s), "foo" /* ERROR cannot convert */ )
    40  	_ = append(S(s), "foo"...)
    41  	_ = append(s, t /* ERROR cannot use t */ )
    42  	_ = append(s, t...)
    43  	_ = append(s, T("foo")...)
    44  	_ = append(S(s), t /* ERROR cannot use t */ )
    45  	_ = append(S(s), t...)
    46  	_ = append(S(s), T("foo")...)
    47  	_ = append([]string{}, t /* ERROR cannot use t */ , "foo")
    48  	_ = append([]T{}, t, "foo")
    49  }
    50  
    51  // from the spec
    52  func append2() {
    53  	s0 := []int{0, 0}
    54  	s1 := append(s0, 2)                // append a single element     s1 == []int{0, 0, 2}
    55  	s2 := append(s1, 3, 5, 7)          // append multiple elements    s2 == []int{0, 0, 2, 3, 5, 7}
    56  	s3 := append(s2, s0...)            // append a slice              s3 == []int{0, 0, 2, 3, 5, 7, 0, 0}
    57  	s4 := append(s3[3:6], s3[2:]...)   // append overlapping slice    s4 == []int{3, 5, 7, 2, 3, 5, 7, 0, 0}
    58  
    59  	var t []interface{}
    60  	t = append(t, 42, 3.1415, "foo")   //                             t == []interface{}{42, 3.1415, "foo"}
    61  
    62  	var b []byte
    63  	b = append(b, "bar"...)            // append string contents      b == []byte{'b', 'a', 'r' }
    64  
    65  	_ = s4
    66  }
    67  
    68  func append3() {
    69  	f1 := func() (s []int) { return }
    70  	f2 := func() (s []int, x int) { return }
    71  	f3 := func() (s []int, x, y int) { return }
    72  	f5 := func() (s []interface{}, x int, y float32, z string, b bool) { return }
    73  	ff := func() (int, float32) { return 0, 0 }
    74  	_ = append(f0 /* ERROR used as value */ ())
    75  	_ = append(f1())
    76  	_ = append(f2())
    77  	_ = append(f3())
    78  	_ = append(f5())
    79  	_ = append(ff /* ERROR not a slice */ ()) // TODO(gri) better error message
    80  }
    81  
    82  func cap1() {
    83  	var a [10]bool
    84  	var p *[20]int
    85  	var c chan string
    86  	_ = cap() // ERROR not enough arguments
    87  	_ = cap(1, 2) // ERROR too many arguments
    88  	_ = cap(42 /* ERROR invalid */)
    89  	const _3 = cap(a)
    90  	assert(_3 == 10)
    91  	const _4 = cap(p)
    92  	assert(_4 == 20)
    93  	_ = cap(c)
    94  	cap /* ERROR not used */ (c)
    95  
    96  	// issue 4744
    97  	type T struct{ a [10]int }
    98  	const _ = cap(((*T)(nil)).a)
    99  
   100  	var s [][]byte
   101  	_ = cap(s)
   102  	_ = cap(s... /* ERROR invalid use of \.\.\. */ )
   103  }
   104  
   105  func cap2() {
   106  	f1a := func() (a [10]int) { return }
   107  	f1s := func() (s []int) { return }
   108  	f2 := func() (s []int, x int) { return }
   109  	_ = cap(f0 /* ERROR used as value */ ())
   110  	_ = cap(f1a())
   111  	_ = cap(f1s())
   112  	_ = cap(f2()) // ERROR too many arguments
   113  }
   114  
   115  // test cases for issue 7387
   116  func cap3() {
   117  	var f = func() int { return 0 }
   118  	var x = f()
   119  	const (
   120  		_ = cap([4]int{})
   121  		_ = cap([4]int{x})
   122  		_ = cap /* ERROR not constant */ ([4]int{f()})
   123  		_ = cap /* ERROR not constant */ ([4]int{cap([]int{})})
   124  		_ = cap([4]int{cap([4]int{})})
   125  	)
   126  	var y float64
   127  	var z complex128
   128  	const (
   129  		_ = cap([4]float64{})
   130  		_ = cap([4]float64{y})
   131  		_ = cap([4]float64{real(2i)})
   132  		_ = cap /* ERROR not constant */ ([4]float64{real(z)})
   133  	)
   134  	var ch chan [10]int
   135  	const (
   136  		_ = cap /* ERROR not constant */ (<-ch)
   137  		_ = cap /* ERROR not constant */ ([4]int{(<-ch)[0]})
   138  	)
   139  }
   140  
   141  func close1() {
   142  	var c chan int
   143  	var r <-chan int
   144  	close() // ERROR not enough arguments
   145  	close(1, 2) // ERROR too many arguments
   146  	close(42 /* ERROR not a channel */)
   147  	close(r /* ERROR receive-only channel */)
   148  	close(c)
   149  	_ = close /* ERROR used as value */ (c)
   150  
   151  	var s []chan int
   152  	close(s... /* ERROR invalid use of \.\.\. */ )
   153  }
   154  
   155  func close2() {
   156  	f1 := func() (ch chan int) { return }
   157  	f2 := func() (ch chan int, x int) { return }
   158  	close(f0 /* ERROR used as value */ ())
   159  	close(f1())
   160  	close(f2()) // ERROR too many arguments
   161  }
   162  
   163  func complex1() {
   164  	var i32 int32
   165  	var f32 float32
   166  	var f64 float64
   167  	var c64 complex64
   168  	var c128 complex128
   169  	_ = complex() // ERROR not enough arguments
   170  	_ = complex(1) // ERROR not enough arguments
   171  	_ = complex(true /* ERROR mismatched types */ , 0)
   172  	_ = complex(i32 /* ERROR expected floating-point */ , 0)
   173  	_ = complex("foo" /* ERROR mismatched types */ , 0)
   174  	_ = complex(c64 /* ERROR expected floating-point */ , 0)
   175  	_ = complex(0 /* ERROR mismatched types */ , true)
   176  	_ = complex(0 /* ERROR expected floating-point */ , i32)
   177  	_ = complex(0 /* ERROR mismatched types */ , "foo")
   178  	_ = complex(0 /* ERROR expected floating-point */ , c64)
   179  	_ = complex(f32, f32)
   180  	_ = complex(f32, 1)
   181  	_ = complex(f32, 1.0)
   182  	_ = complex(f32, 'a')
   183  	_ = complex(f64, f64)
   184  	_ = complex(f64, 1)
   185  	_ = complex(f64, 1.0)
   186  	_ = complex(f64, 'a')
   187  	_ = complex(f32 /* ERROR mismatched types */ , f64)
   188  	_ = complex(f64 /* ERROR mismatched types */ , f32)
   189  	_ = complex(1, 1)
   190  	_ = complex(1, 1.1)
   191  	_ = complex(1, 'a')
   192  	complex /* ERROR not used */ (1, 2)
   193  
   194  	var _ complex64 = complex(f32, f32)
   195  	var _ complex64 = complex /* ERROR cannot use .* in variable declaration */ (f64, f64)
   196  
   197  	var _ complex128 = complex /* ERROR cannot use .* in variable declaration */ (f32, f32)
   198  	var _ complex128 = complex(f64, f64)
   199  
   200  	// untyped constants
   201  	const _ int = complex(1, 0)
   202  	const _ float32 = complex(1, 0)
   203  	const _ complex64 = complex(1, 0)
   204  	const _ complex128 = complex(1, 0)
   205  	const _ = complex(0i, 0i)
   206  	const _ = complex(0i, 0)
   207  	const _ int = 1.0 + complex(1, 0i)
   208  
   209  	const _ int = complex /* ERROR int */ (1.1, 0)
   210  	const _ float32 = complex /* ERROR float32 */ (1, 2)
   211  
   212  	// untyped values
   213  	var s uint
   214  	_ = complex(1 /* ERROR integer */ <<s, 0)
   215  	const _ = complex /* ERROR not constant */ (1 /* ERROR integer */ <<s, 0)
   216  	var _ int = complex /* ERROR cannot use .* in variable declaration */ (1 /* ERROR integer */ <<s, 0)
   217  
   218  	// floating-point argument types must be identical
   219  	type F32 float32
   220  	type F64 float64
   221  	var x32 F32
   222  	var x64 F64
   223  	c64 = complex(x32, x32)
   224  	_ = complex(x32 /* ERROR mismatched types */ , f32)
   225  	_ = complex(f32 /* ERROR mismatched types */ , x32)
   226  	c128 = complex(x64, x64)
   227  	_ = c128
   228  	_ = complex(x64 /* ERROR mismatched types */ , f64)
   229  	_ = complex(f64 /* ERROR mismatched types */ , x64)
   230  
   231  	var t []float32
   232  	_ = complex(t... /* ERROR invalid use of \.\.\. */ )
   233  }
   234  
   235  func complex2() {
   236  	f1 := func() (x float32) { return }
   237  	f2 := func() (x, y float32) { return }
   238  	f3 := func() (x, y, z float32) { return }
   239  	_ = complex(f0 /* ERROR used as value */ ())
   240  	_ = complex(f1()) // ERROR not enough arguments
   241  	_ = complex(f2())
   242  	_ = complex(f3()) // ERROR too many arguments
   243  }
   244  
   245  func copy1() {
   246  	copy() // ERROR not enough arguments
   247  	copy("foo") // ERROR not enough arguments
   248  	copy([ /* ERROR copy expects slice arguments */ ...]int{}, []int{})
   249  	copy([ /* ERROR copy expects slice arguments */ ]int{}, [...]int{})
   250  	copy([ /* ERROR different element types */ ]int8{}, "foo")
   251  
   252  	// spec examples
   253  	var a = [...]int{0, 1, 2, 3, 4, 5, 6, 7}
   254  	var s = make([]int, 6)
   255  	var b = make([]byte, 5)
   256  	n1 := copy(s, a[0:])            // n1 == 6, s == []int{0, 1, 2, 3, 4, 5}
   257  	n2 := copy(s, s[2:])            // n2 == 4, s == []int{2, 3, 4, 5, 4, 5}
   258  	n3 := copy(b, "Hello, World!")  // n3 == 5, b == []byte("Hello")
   259  	_, _, _ = n1, n2, n3
   260  
   261  	var t [][]int
   262  	copy(t, t)
   263  	copy(t /* ERROR copy expects slice arguments */ , nil)
   264  	copy(nil /* ERROR copy expects slice arguments */ , t)
   265  	copy(nil /* ERROR copy expects slice arguments */ , nil)
   266  	copy(t... /* ERROR invalid use of \.\.\. */ )
   267  }
   268  
   269  func copy2() {
   270  	f1 := func() (a []int) { return }
   271  	f2 := func() (a, b []int) { return }
   272  	f3 := func() (a, b, c []int) { return }
   273  	copy(f0 /* ERROR used as value */ ())
   274  	copy(f1()) // ERROR not enough arguments
   275  	copy(f2())
   276  	copy(f3()) // ERROR too many arguments
   277  }
   278  
   279  func delete1() {
   280  	var m map[string]int
   281  	var s string
   282  	delete() // ERROR not enough arguments
   283  	delete(1) // ERROR not enough arguments
   284  	delete(1, 2, 3) // ERROR too many arguments
   285  	delete(m, 0 /* ERROR not assignable */)
   286  	delete(m, s)
   287  	_ = delete /* ERROR used as value */ (m, s)
   288  
   289  	var t []map[string]string
   290  	delete(t... /* ERROR invalid use of \.\.\. */ )
   291  }
   292  
   293  func delete2() {
   294  	f1 := func() (m map[string]int) { return }
   295  	f2 := func() (m map[string]int, k string) { return }
   296  	f3 := func() (m map[string]int, k string, x float32) { return }
   297  	delete(f0 /* ERROR used as value */ ())
   298  	delete(f1()) // ERROR not enough arguments
   299  	delete(f2())
   300  	delete(f3()) // ERROR too many arguments
   301  }
   302  
   303  func imag1() {
   304  	var f32 float32
   305  	var f64 float64
   306  	var c64 complex64
   307  	var c128 complex128
   308  	_ = imag() // ERROR not enough arguments
   309  	_ = imag(1, 2) // ERROR too many arguments
   310  	_ = imag(10)
   311  	_ = imag(2.7182818)
   312  	_ = imag("foo" /* ERROR expected complex */)
   313  	_ = imag('a')
   314  	const _5 = imag(1 + 2i)
   315  	assert(_5 == 2)
   316  	f32 = _5
   317  	f64 = _5
   318  	const _6 = imag(0i)
   319  	assert(_6 == 0)
   320  	f32 = imag(c64)
   321  	f64 = imag(c128)
   322  	f32 = imag /* ERROR cannot use .* in assignment */ (c128)
   323  	f64 = imag /* ERROR cannot use .* in assignment */ (c64)
   324  	imag /* ERROR not used */ (c64)
   325  	_, _ = f32, f64
   326  
   327  	// complex type may not be predeclared
   328  	type C64 complex64
   329  	type C128 complex128
   330  	var x64 C64
   331  	var x128 C128
   332  	f32 = imag(x64)
   333  	f64 = imag(x128)
   334  
   335  	var a []complex64
   336  	_ = imag(a... /* ERROR invalid use of \.\.\. */ )
   337  
   338  	// if argument is untyped, result is untyped
   339  	const _ byte = imag(1.2 + 3i)
   340  	const _ complex128 = imag(1.2 + 3i)
   341  
   342  	// lhs constant shift operands are typed as complex128
   343  	var s uint
   344  	_ = imag(1 /* ERROR must be integer */ << s)
   345  }
   346  
   347  func imag2() {
   348  	f1 := func() (x complex128) { return }
   349  	f2 := func() (x, y complex128) { return }
   350  	_ = imag(f0 /* ERROR used as value */ ())
   351  	_ = imag(f1())
   352  	_ = imag(f2()) // ERROR too many arguments
   353  }
   354  
   355  func len1() {
   356  	const c = "foobar"
   357  	var a [10]bool
   358  	var p *[20]int
   359  	var m map[string]complex128
   360  	_ = len() // ERROR not enough arguments
   361  	_ = len(1, 2) // ERROR too many arguments
   362  	_ = len(42 /* ERROR invalid */)
   363  	const _3 = len(c)
   364  	assert(_3 == 6)
   365  	const _4 = len(a)
   366  	assert(_4 == 10)
   367  	const _5 = len(p)
   368  	assert(_5 == 20)
   369  	_ = len(m)
   370  	len /* ERROR not used */ (c)
   371  
   372  	// esoteric case
   373  	var t string
   374  	var hash map[interface{}][]*[10]int
   375  	const n = len /* ERROR not constant */ (hash[recover()][len(t)])
   376  	assert(n == 10) // ok because n has unknown value and no error is reported
   377  	var ch <-chan int
   378  	const nn = len /* ERROR not constant */ (hash[<-ch][len(t)])
   379  
   380  	// issue 4744
   381  	type T struct{ a [10]int }
   382  	const _ = len(((*T)(nil)).a)
   383  
   384  	var s [][]byte
   385  	_ = len(s)
   386  	_ = len(s... /* ERROR invalid use of \.\.\. */ )
   387  }
   388  
   389  func len2() {
   390  	f1 := func() (x []int) { return }
   391  	f2 := func() (x, y []int) { return }
   392  	_ = len(f0 /* ERROR used as value */ ())
   393  	_ = len(f1())
   394  	_ = len(f2()) // ERROR too many arguments
   395  }
   396  
   397  // test cases for issue 7387
   398  func len3() {
   399  	var f = func() int { return 0 }
   400  	var x = f()
   401  	const (
   402  		_ = len([4]int{})
   403  		_ = len([4]int{x})
   404  		_ = len /* ERROR not constant */ ([4]int{f()})
   405  		_ = len /* ERROR not constant */ ([4]int{len([]int{})})
   406  		_ = len([4]int{len([4]int{})})
   407  	)
   408  	var y float64
   409  	var z complex128
   410  	const (
   411  		_ = len([4]float64{})
   412  		_ = len([4]float64{y})
   413  		_ = len([4]float64{real(2i)})
   414  		_ = len /* ERROR not constant */ ([4]float64{real(z)})
   415  	)
   416  	var ch chan [10]int
   417  	const (
   418  		_ = len /* ERROR not constant */ (<-ch)
   419  		_ = len /* ERROR not constant */ ([4]int{(<-ch)[0]})
   420  	)
   421  }
   422  
   423  func make1() {
   424  	var n int
   425  	var m float32
   426  	var s uint
   427  
   428  	_ = make() // ERROR not enough arguments
   429  	_ = make(1 /* ERROR not a type */)
   430  	_ = make(int /* ERROR cannot make */)
   431  
   432  	// slices
   433  	_ = make/* ERROR arguments */ ([]int)
   434  	_ = make/* ERROR arguments */ ([]int, 2, 3, 4)
   435  	_ = make([]int, int /* ERROR not an expression */)
   436  	_ = make([]int, 10, float32 /* ERROR not an expression */)
   437  	_ = make([]int, "foo" /* ERROR cannot convert */)
   438  	_ = make([]int, 10, 2.3 /* ERROR truncated */)
   439  	_ = make([]int, 5, 10.0)
   440  	_ = make([]int, 0i)
   441  	_ = make([]int, 1.0)
   442  	_ = make([]int, 1.0<<s)
   443  	_ = make([]int, 1.1 /* ERROR int */ <<s)
   444  	_ = make([]int, - /* ERROR must not be negative */ 1, 10)
   445  	_ = make([]int, 0, - /* ERROR must not be negative */ 1)
   446  	_ = make([]int, - /* ERROR must not be negative */ 1, - /* ERROR must not be negative */ 1)
   447  	_ = make([]int, 1 /* ERROR overflows */ <<100, 1 /* ERROR overflows */ <<100)
   448  	_ = make([]int, 10 /* ERROR length and capacity swapped */ , 9)
   449  	_ = make([]int, 1 /* ERROR overflows */ <<100, 12345)
   450  	_ = make([]int, m /* ERROR must be integer */ )
   451          _ = &make /* ERROR cannot take address */ ([]int, 0)
   452  
   453  	// maps
   454  	_ = make /* ERROR arguments */ (map[int]string, 10, 20)
   455  	_ = make(map[int]float32, int /* ERROR not an expression */)
   456  	_ = make(map[int]float32, "foo" /* ERROR cannot convert */)
   457  	_ = make(map[int]float32, 10)
   458  	_ = make(map[int]float32, n)
   459  	_ = make(map[int]float32, int64(n))
   460  	_ = make(map[string]bool, 10.0)
   461  	_ = make(map[string]bool, 10.0<<s)
   462          _ = &make /* ERROR cannot take address */ (map[string]bool)
   463  
   464  	// channels
   465  	_ = make /* ERROR arguments */ (chan int, 10, 20)
   466  	_ = make(chan int, int /* ERROR not an expression */)
   467  	_ = make(chan<- int, "foo" /* ERROR cannot convert */)
   468  	_ = make(chan int, - /* ERROR must not be negative */ 10)
   469  	_ = make(<-chan float64, 10)
   470  	_ = make(chan chan int, n)
   471  	_ = make(chan string, int64(n))
   472  	_ = make(chan bool, 10.0)
   473  	_ = make(chan bool, 10.0<<s)
   474          _ = &make /* ERROR cannot take address */ (chan bool)
   475  
   476  	make /* ERROR not used */ ([]int, 10)
   477  
   478  	var t []int
   479  	_ = make([]int, t[0], t[1])
   480  	_ = make([]int, t... /* ERROR invalid use of \.\.\. */ )
   481  }
   482  
   483  func make2() {
   484  	f1 /* ERROR not used */ := func() (x []int) { return }
   485  	_ = make(f0 /* ERROR not a type */ ())
   486  	_ = make(f1 /* ERROR not a type */ ())
   487  }
   488  
   489  func new1() {
   490  	_ = new() // ERROR not enough arguments
   491  	_ = new(1, 2) // ERROR too many arguments
   492  	_ = new("foo" /* ERROR not a type */)
   493  	p := new(float64)
   494  	_ = new(struct{ x, y int })
   495  	q := new(*float64)
   496  	_ = *p == **q
   497  	new /* ERROR not used */ (int)
   498          _ = &new /* ERROR cannot take address */ (int)
   499  
   500  	_ = new(int... /* ERROR invalid use of \.\.\. */ )
   501  }
   502  
   503  func new2() {
   504  	f1 /* ERROR not used */ := func() (x []int) { return }
   505  	_ = new(f0 /* ERROR not a type */ ())
   506  	_ = new(f1 /* ERROR not a type */ ())
   507  }
   508  
   509  func panic1() {
   510  	panic() // ERROR not enough arguments
   511  	panic(1, 2) // ERROR too many arguments
   512  	panic(0)
   513  	panic("foo")
   514  	panic(false)
   515  	panic(1<<10)
   516  	panic(1 /* ERROR overflows */ <<1000)
   517  	_ = panic /* ERROR used as value */ (0)
   518  
   519  	var s []byte
   520  	panic(s)
   521  	panic(s... /* ERROR invalid use of \.\.\. */ )
   522  }
   523  
   524  func panic2() {
   525  	f1 := func() (x int) { return }
   526  	f2 := func() (x, y int) { return }
   527  	panic(f0 /* ERROR used as value */ ())
   528  	panic(f1())
   529  	panic(f2()) // ERROR too many arguments
   530  }
   531  
   532  func print1() {
   533  	print()
   534  	print(1)
   535  	print(1, 2)
   536  	print("foo")
   537  	print(2.718281828)
   538  	print(false)
   539  	print(1<<10)
   540  	print(1 /* ERROR overflows */ <<1000)
   541  	println(nil /* ERROR untyped nil */ )
   542  
   543  	var s []int
   544  	print(s... /* ERROR invalid use of \.\.\. */ )
   545  	_ = print /* ERROR used as value */ ()
   546  }
   547  
   548  func print2() {
   549  	f1 := func() (x int) { return }
   550  	f2 := func() (x, y int) { return }
   551  	f3 := func() (x int, y float32, z string) { return }
   552  	print(f0 /* ERROR used as value */ ())
   553  	print(f1())
   554  	print(f2())
   555  	print(f3())
   556  }
   557  
   558  func println1() {
   559  	println()
   560  	println(1)
   561  	println(1, 2)
   562  	println("foo")
   563  	println(2.718281828)
   564  	println(false)
   565  	println(1<<10)
   566  	println(1 /* ERROR overflows */ <<1000)
   567  	println(nil /* ERROR untyped nil */ )
   568  
   569  	var s []int
   570  	println(s... /* ERROR invalid use of \.\.\. */ )
   571  	_ = println /* ERROR used as value */ ()
   572  }
   573  
   574  func println2() {
   575  	f1 := func() (x int) { return }
   576  	f2 := func() (x, y int) { return }
   577  	f3 := func() (x int, y float32, z string) { return }
   578  	println(f0 /* ERROR used as value */ ())
   579  	println(f1())
   580  	println(f2())
   581  	println(f3())
   582  }
   583  
   584  func real1() {
   585  	var f32 float32
   586  	var f64 float64
   587  	var c64 complex64
   588  	var c128 complex128
   589  	_ = real() // ERROR not enough arguments
   590  	_ = real(1, 2) // ERROR too many arguments
   591  	_ = real(10)
   592  	_ = real(2.7182818)
   593  	_ = real("foo" /* ERROR expected complex */)
   594  	const _5 = real(1 + 2i)
   595  	assert(_5 == 1)
   596  	f32 = _5
   597  	f64 = _5
   598  	const _6 = real(0i)
   599  	assert(_6 == 0)
   600  	f32 = real(c64)
   601  	f64 = real(c128)
   602  	f32 = real /* ERROR cannot use .* in assignment */ (c128)
   603  	f64 = real /* ERROR cannot use .* in assignment */ (c64)
   604  	real /* ERROR not used */ (c64)
   605  
   606  	// complex type may not be predeclared
   607  	type C64 complex64
   608  	type C128 complex128
   609  	var x64 C64
   610  	var x128 C128
   611  	f32 = imag(x64)
   612  	f64 = imag(x128)
   613  	_, _ = f32, f64
   614  
   615  	var a []complex64
   616  	_ = real(a... /* ERROR invalid use of \.\.\. */ )
   617  
   618  	// if argument is untyped, result is untyped
   619  	const _ byte = real(1 + 2.3i)
   620  	const _ complex128 = real(1 + 2.3i)
   621  
   622  	// lhs constant shift operands are typed as complex128
   623  	var s uint
   624  	_ = real(1 /* ERROR must be integer */ << s)
   625  }
   626  
   627  func real2() {
   628  	f1 := func() (x complex128) { return }
   629  	f2 := func() (x, y complex128) { return }
   630  	_ = real(f0 /* ERROR used as value */ ())
   631  	_ = real(f1())
   632  	_ = real(f2()) // ERROR too many arguments
   633  }
   634  
   635  func recover1() {
   636  	_ = recover()
   637  	_ = recover(10) // ERROR too many arguments
   638  	recover()
   639  
   640  	var s []int
   641  	recover(s... /* ERROR invalid use of \.\.\. */ )
   642  }
   643  
   644  func recover2() {
   645  	f1 := func() (x int) { return }
   646  	f2 := func() (x, y int) { return }
   647  	_ = recover(f0 /* ERROR used as value */ ())
   648  	_ = recover(f1()) // ERROR too many arguments
   649  	_ = recover(f2()) // ERROR too many arguments
   650  }
   651  
   652  // assuming types.DefaultPtrSize == 8
   653  type S0 struct{      // offset
   654  	a bool       //  0
   655  	b rune       //  4
   656  	c *int       //  8
   657  	d bool       // 16
   658  	e complex128 // 24
   659  }                    // 40
   660  
   661  type S1 struct{   // offset
   662  	x float32 //  0
   663  	y string  //  8
   664  	z *S1     // 24
   665  	S0        // 32
   666  }                 // 72
   667  
   668  type S2 struct{ // offset
   669  	*S1     //  0
   670  }               //  8
   671  
   672  type S3 struct { // offset
   673  	a int64  //  0
   674  	b int32  //  8
   675  }                // 12
   676  
   677  type S4 struct { // offset
   678  	S3       //  0
   679  	int32    // 12
   680  }                // 16
   681  
   682  type S5 struct {   // offset
   683  	a [3]int32 //  0
   684  	b int32    // 12
   685  }                  // 16
   686  
   687  func (S2) m() {}
   688  
   689  func Alignof1() {
   690  	var x int
   691  	_ = unsafe.Alignof() // ERROR not enough arguments
   692  	_ = unsafe.Alignof(1, 2) // ERROR too many arguments
   693  	_ = unsafe.Alignof(int /* ERROR not an expression */)
   694  	_ = unsafe.Alignof(42)
   695  	_ = unsafe.Alignof(new(struct{}))
   696  	_ = unsafe.Alignof(1<<10)
   697  	_ = unsafe.Alignof(1 /* ERROR overflows */ <<1000)
   698  	_ = unsafe.Alignof(nil /* ERROR "untyped nil */ )
   699  	unsafe /* ERROR not used */ .Alignof(x)
   700  
   701  	var y S0
   702  	assert(unsafe.Alignof(y.a) == 1)
   703  	assert(unsafe.Alignof(y.b) == 4)
   704  	assert(unsafe.Alignof(y.c) == 8)
   705  	assert(unsafe.Alignof(y.d) == 1)
   706  	assert(unsafe.Alignof(y.e) == 8)
   707  
   708  	var s []byte
   709  	_ = unsafe.Alignof(s)
   710  	_ = unsafe.Alignof(s... /* ERROR invalid use of \.\.\. */ )
   711  }
   712  
   713  func Alignof2() {
   714  	f1 := func() (x int32) { return }
   715  	f2 := func() (x, y int32) { return }
   716  	_ = unsafe.Alignof(f0 /* ERROR used as value */ ())
   717  	assert(unsafe.Alignof(f1()) == 4)
   718  	_ = unsafe.Alignof(f2()) // ERROR too many arguments
   719  }
   720  
   721  func Offsetof1() {
   722  	var x struct{ f int }
   723  	_ = unsafe.Offsetof() // ERROR not enough arguments
   724  	_ = unsafe.Offsetof(1, 2) // ERROR too many arguments
   725  	_ = unsafe.Offsetof(int /* ERROR not a selector expression */ )
   726  	_ = unsafe.Offsetof(x /* ERROR not a selector expression */ )
   727  	_ = unsafe.Offsetof(nil /* ERROR not a selector expression */ )
   728  	_ = unsafe.Offsetof(x.f)
   729  	_ = unsafe.Offsetof((x.f))
   730  	_ = unsafe.Offsetof((((((((x))).f)))))
   731  	unsafe /* ERROR not used */ .Offsetof(x.f)
   732  
   733  	var y0 S0
   734  	assert(unsafe.Offsetof(y0.a) == 0)
   735  	assert(unsafe.Offsetof(y0.b) == 4)
   736  	assert(unsafe.Offsetof(y0.c) == 8)
   737  	assert(unsafe.Offsetof(y0.d) == 16)
   738  	assert(unsafe.Offsetof(y0.e) == 24)
   739  
   740  	var y1 S1
   741  	assert(unsafe.Offsetof(y1.x) == 0)
   742  	assert(unsafe.Offsetof(y1.y) == 8)
   743  	assert(unsafe.Offsetof(y1.z) == 24)
   744  	assert(unsafe.Offsetof(y1.S0) == 32)
   745  
   746  	assert(unsafe.Offsetof(y1.S0.a) == 0) // relative to S0
   747  	assert(unsafe.Offsetof(y1.a) == 32)   // relative to S1
   748  	assert(unsafe.Offsetof(y1.b) == 36)   // relative to S1
   749  	assert(unsafe.Offsetof(y1.c) == 40)   // relative to S1
   750  	assert(unsafe.Offsetof(y1.d) == 48)   // relative to S1
   751  	assert(unsafe.Offsetof(y1.e) == 56)   // relative to S1
   752  
   753  	var y1p *S1
   754  	assert(unsafe.Offsetof(y1p.S0) == 32)
   755  
   756  	type P *S1
   757  	var p P = y1p
   758  	assert(unsafe.Offsetof(p.S0) == 32)
   759  
   760  	var y2 S2
   761  	assert(unsafe.Offsetof(y2.S1) == 0)
   762  	_ = unsafe.Offsetof(y2 /* ERROR embedded via a pointer */ .x)
   763  	_ = unsafe.Offsetof(y2 /* ERROR method value */ .m)
   764  
   765  	var s []byte
   766  	_ = unsafe.Offsetof(s... /* ERROR invalid use of \.\.\. */ )
   767  }
   768  
   769  func Offsetof2() {
   770  	f1 := func() (x int32) { return }
   771  	f2 := func() (x, y int32) { return }
   772  	_ = unsafe.Offsetof(f0 /* ERROR not a selector expression */ ())
   773  	_ = unsafe.Offsetof(f1 /* ERROR not a selector expression */ ())
   774  	_ = unsafe.Offsetof(f2 /* ERROR not a selector expression */ ())
   775  }
   776  
   777  func Sizeof1() {
   778  	var x int
   779  	_ = unsafe.Sizeof() // ERROR not enough arguments
   780  	_ = unsafe.Sizeof(1, 2) // ERROR too many arguments
   781  	_ = unsafe.Sizeof(int /* ERROR not an expression */)
   782  	_ = unsafe.Sizeof(42)
   783  	_ = unsafe.Sizeof(new(complex128))
   784  	_ = unsafe.Sizeof(1<<10)
   785  	_ = unsafe.Sizeof(1 /* ERROR overflows */ <<1000)
   786  	_ = unsafe.Sizeof(nil /* ERROR untyped nil */ )
   787  	unsafe /* ERROR not used */ .Sizeof(x)
   788  
   789  	// basic types have size guarantees
   790  	assert(unsafe.Sizeof(byte(0)) == 1)
   791  	assert(unsafe.Sizeof(uint8(0)) == 1)
   792  	assert(unsafe.Sizeof(int8(0)) == 1)
   793  	assert(unsafe.Sizeof(uint16(0)) == 2)
   794  	assert(unsafe.Sizeof(int16(0)) == 2)
   795  	assert(unsafe.Sizeof(uint32(0)) == 4)
   796  	assert(unsafe.Sizeof(int32(0)) == 4)
   797  	assert(unsafe.Sizeof(float32(0)) == 4)
   798  	assert(unsafe.Sizeof(uint64(0)) == 8)
   799  	assert(unsafe.Sizeof(int64(0)) == 8)
   800  	assert(unsafe.Sizeof(float64(0)) == 8)
   801  	assert(unsafe.Sizeof(complex64(0)) == 8)
   802  	assert(unsafe.Sizeof(complex128(0)) == 16)
   803  
   804  	var y0 S0
   805  	assert(unsafe.Sizeof(y0.a) == 1)
   806  	assert(unsafe.Sizeof(y0.b) == 4)
   807  	assert(unsafe.Sizeof(y0.c) == 8)
   808  	assert(unsafe.Sizeof(y0.d) == 1)
   809  	assert(unsafe.Sizeof(y0.e) == 16)
   810  	assert(unsafe.Sizeof(y0) == 40)
   811  
   812  	var y1 S1
   813  	assert(unsafe.Sizeof(y1) == 72)
   814  
   815  	var y2 S2
   816  	assert(unsafe.Sizeof(y2) == 8)
   817  
   818  	var y3 S3
   819  	assert(unsafe.Sizeof(y3) == 12)
   820  
   821  	var y4 S4
   822  	assert(unsafe.Sizeof(y4) == 16)
   823  
   824  	var y5 S5
   825  	assert(unsafe.Sizeof(y5) == 16)
   826  
   827  	var a3 [10]S3
   828  	assert(unsafe.Sizeof(a3) == 156)
   829  
   830  	// test case for issue 5670
   831  	type T struct {
   832  		a int32
   833  		_ int32
   834  		c int32
   835  	}
   836  	assert(unsafe.Sizeof(T{}) == 12)
   837  
   838  	var s []byte
   839  	_ = unsafe.Sizeof(s)
   840  	_ = unsafe.Sizeof(s... /* ERROR invalid use of \.\.\. */ )
   841  }
   842  
   843  func Sizeof2() {
   844  	f1 := func() (x int64) { return }
   845  	f2 := func() (x, y int64) { return }
   846  	_ = unsafe.Sizeof(f0 /* ERROR used as value */ ())
   847  	assert(unsafe.Sizeof(f1()) == 8)
   848  	_ = unsafe.Sizeof(f2()) // ERROR too many arguments
   849  }
   850  
   851  // self-testing only
   852  func assert1() {
   853  	var x int
   854  	assert() /* ERROR not enough arguments */
   855  	assert(1, 2) /* ERROR too many arguments */
   856  	assert("foo" /* ERROR boolean constant */ )
   857  	assert(x /* ERROR boolean constant */)
   858  	assert(true)
   859  	assert /* ERROR failed */ (false)
   860  	_ = assert(true)
   861  
   862  	var s []byte
   863  	assert(s... /* ERROR invalid use of \.\.\. */ )
   864  }
   865  
   866  func assert2() {
   867  	f1 := func() (x bool) { return }
   868  	f2 := func() (x bool) { return }
   869  	assert(f0 /* ERROR used as value */ ())
   870  	assert(f1 /* ERROR boolean constant */ ())
   871  	assert(f2 /* ERROR boolean constant */ ())
   872  }
   873  
   874  // self-testing only
   875  func trace1() {
   876  	// Uncomment the code below to test trace - will produce console output
   877  	// _ = trace /* ERROR no value */ ()
   878  	// _ = trace(1)
   879  	// _ = trace(true, 1.2, '\'', "foo", 42i, "foo" <= "bar")
   880  
   881  	var s []byte
   882  	trace(s... /* ERROR invalid use of \.\.\. */ )
   883  }
   884  
   885  func trace2() {
   886  	f1 := func() (x int) { return }
   887  	f2 := func() (x int, y string) { return }
   888  	f3 := func() (x int, y string, z []int) { return }
   889  	_ = f1
   890  	_ = f2
   891  	_ = f3
   892  	// Uncomment the code below to test trace - will produce console output
   893  	// trace(f0())
   894  	// trace(f1())
   895  	// trace(f2())
   896  	// trace(f3())
   897  	// trace(f0(), 1)
   898  	// trace(f1(), 1, 2)
   899  	// trace(f2(), 1, 2, 3)
   900  	// trace(f3(), 1, 2, 3, 4)
   901  }