1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
// Copyright 2015 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.
// Test compound objects
package main
import (
"testing"
)
func string_ssa(a, b string, x bool) string {
s := ""
if x {
s = a
} else {
s = b
}
return s
}
func testString(t *testing.T) {
a := "foo"
b := "barz"
if want, got := a, string_ssa(a, b, true); got != want {
t.Errorf("string_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
if want, got := b, string_ssa(a, b, false); got != want {
t.Errorf("string_ssa(%v, %v, false) = %v, want %v\n", a, b, got, want)
}
}
//go:noinline
func complex64_ssa(a, b complex64, x bool) complex64 {
var c complex64
if x {
c = a
} else {
c = b
}
return c
}
//go:noinline
func complex128_ssa(a, b complex128, x bool) complex128 {
var c complex128
if x {
c = a
} else {
c = b
}
return c
}
func testComplex64(t *testing.T) {
var a complex64 = 1 + 2i
var b complex64 = 3 + 4i
if want, got := a, complex64_ssa(a, b, true); got != want {
t.Errorf("complex64_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
if want, got := b, complex64_ssa(a, b, false); got != want {
t.Errorf("complex64_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
}
func testComplex128(t *testing.T) {
var a complex128 = 1 + 2i
var b complex128 = 3 + 4i
if want, got := a, complex128_ssa(a, b, true); got != want {
t.Errorf("complex128_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
if want, got := b, complex128_ssa(a, b, false); got != want {
t.Errorf("complex128_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
}
func slice_ssa(a, b []byte, x bool) []byte {
var s []byte
if x {
s = a
} else {
s = b
}
return s
}
func testSlice(t *testing.T) {
a := []byte{3, 4, 5}
b := []byte{7, 8, 9}
if want, got := byte(3), slice_ssa(a, b, true)[0]; got != want {
t.Errorf("slice_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
if want, got := byte(7), slice_ssa(a, b, false)[0]; got != want {
t.Errorf("slice_ssa(%v, %v, false) = %v, want %v\n", a, b, got, want)
}
}
func interface_ssa(a, b interface{}, x bool) interface{} {
var s interface{}
if x {
s = a
} else {
s = b
}
return s
}
func testInterface(t *testing.T) {
a := interface{}(3)
b := interface{}(4)
if want, got := 3, interface_ssa(a, b, true).(int); got != want {
t.Errorf("interface_ssa(%v, %v, true) = %v, want %v\n", a, b, got, want)
}
if want, got := 4, interface_ssa(a, b, false).(int); got != want {
t.Errorf("interface_ssa(%v, %v, false) = %v, want %v\n", a, b, got, want)
}
}
func TestCompound(t *testing.T) {
testString(t)
testSlice(t)
testInterface(t)
testComplex64(t)
testComplex128(t)
}
|