mirror of
https://github.com/golang/go
synced 2024-11-05 22:46:12 -07:00
548 lines
12 KiB
Go
548 lines
12 KiB
Go
|
// run
|
||
|
|
||
|
// Copyright 2012 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.
|
||
|
|
||
|
// Issue 2615: a long chain of else if's causes an overflow
|
||
|
// in the parser stack.
|
||
|
|
||
|
package main
|
||
|
|
||
|
// test returns the index of the lowest set bit in a 256-bit vector.
|
||
|
func test(x [4]uint64) int {
|
||
|
if x[0]&(1<<0) != 0 {
|
||
|
return 0
|
||
|
} else if x[0]&(1<<1) != 0 {
|
||
|
return 1
|
||
|
} else if x[0]&(1<<2) != 0 {
|
||
|
return 2
|
||
|
} else if x[0]&(1<<3) != 0 {
|
||
|
return 3
|
||
|
} else if x[0]&(1<<4) != 0 {
|
||
|
return 4
|
||
|
} else if x[0]&(1<<5) != 0 {
|
||
|
return 5
|
||
|
} else if x[0]&(1<<6) != 0 {
|
||
|
return 6
|
||
|
} else if x[0]&(1<<7) != 0 {
|
||
|
return 7
|
||
|
} else if x[0]&(1<<8) != 0 {
|
||
|
return 8
|
||
|
} else if x[0]&(1<<9) != 0 {
|
||
|
return 9
|
||
|
} else if x[0]&(1<<10) != 0 {
|
||
|
return 10
|
||
|
} else if x[0]&(1<<11) != 0 {
|
||
|
return 11
|
||
|
} else if x[0]&(1<<12) != 0 {
|
||
|
return 12
|
||
|
} else if x[0]&(1<<13) != 0 {
|
||
|
return 13
|
||
|
} else if x[0]&(1<<14) != 0 {
|
||
|
return 14
|
||
|
} else if x[0]&(1<<15) != 0 {
|
||
|
return 15
|
||
|
} else if x[0]&(1<<16) != 0 {
|
||
|
return 16
|
||
|
} else if x[0]&(1<<17) != 0 {
|
||
|
return 17
|
||
|
} else if x[0]&(1<<18) != 0 {
|
||
|
return 18
|
||
|
} else if x[0]&(1<<19) != 0 {
|
||
|
return 19
|
||
|
} else if x[0]&(1<<20) != 0 {
|
||
|
return 20
|
||
|
} else if x[0]&(1<<21) != 0 {
|
||
|
return 21
|
||
|
} else if x[0]&(1<<22) != 0 {
|
||
|
return 22
|
||
|
} else if x[0]&(1<<23) != 0 {
|
||
|
return 23
|
||
|
} else if x[0]&(1<<24) != 0 {
|
||
|
return 24
|
||
|
} else if x[0]&(1<<25) != 0 {
|
||
|
return 25
|
||
|
} else if x[0]&(1<<26) != 0 {
|
||
|
return 26
|
||
|
} else if x[0]&(1<<27) != 0 {
|
||
|
return 27
|
||
|
} else if x[0]&(1<<28) != 0 {
|
||
|
return 28
|
||
|
} else if x[0]&(1<<29) != 0 {
|
||
|
return 29
|
||
|
} else if x[0]&(1<<30) != 0 {
|
||
|
return 30
|
||
|
} else if x[0]&(1<<31) != 0 {
|
||
|
return 31
|
||
|
} else if x[0]&(1<<32) != 0 {
|
||
|
return 32
|
||
|
} else if x[0]&(1<<33) != 0 {
|
||
|
return 33
|
||
|
} else if x[0]&(1<<34) != 0 {
|
||
|
return 34
|
||
|
} else if x[0]&(1<<35) != 0 {
|
||
|
return 35
|
||
|
} else if x[0]&(1<<36) != 0 {
|
||
|
return 36
|
||
|
} else if x[0]&(1<<37) != 0 {
|
||
|
return 37
|
||
|
} else if x[0]&(1<<38) != 0 {
|
||
|
return 38
|
||
|
} else if x[0]&(1<<39) != 0 {
|
||
|
return 39
|
||
|
} else if x[0]&(1<<40) != 0 {
|
||
|
return 40
|
||
|
} else if x[0]&(1<<41) != 0 {
|
||
|
return 41
|
||
|
} else if x[0]&(1<<42) != 0 {
|
||
|
return 42
|
||
|
} else if x[0]&(1<<43) != 0 {
|
||
|
return 43
|
||
|
} else if x[0]&(1<<44) != 0 {
|
||
|
return 44
|
||
|
} else if x[0]&(1<<45) != 0 {
|
||
|
return 45
|
||
|
} else if x[0]&(1<<46) != 0 {
|
||
|
return 46
|
||
|
} else if x[0]&(1<<47) != 0 {
|
||
|
return 47
|
||
|
} else if x[0]&(1<<48) != 0 {
|
||
|
return 48
|
||
|
} else if x[0]&(1<<49) != 0 {
|
||
|
return 49
|
||
|
} else if x[0]&(1<<50) != 0 {
|
||
|
return 50
|
||
|
} else if x[0]&(1<<51) != 0 {
|
||
|
return 51
|
||
|
} else if x[0]&(1<<52) != 0 {
|
||
|
return 52
|
||
|
} else if x[0]&(1<<53) != 0 {
|
||
|
return 53
|
||
|
} else if x[0]&(1<<54) != 0 {
|
||
|
return 54
|
||
|
} else if x[0]&(1<<55) != 0 {
|
||
|
return 55
|
||
|
} else if x[0]&(1<<56) != 0 {
|
||
|
return 56
|
||
|
} else if x[0]&(1<<57) != 0 {
|
||
|
return 57
|
||
|
} else if x[0]&(1<<58) != 0 {
|
||
|
return 58
|
||
|
} else if x[0]&(1<<59) != 0 {
|
||
|
return 59
|
||
|
} else if x[0]&(1<<60) != 0 {
|
||
|
return 60
|
||
|
} else if x[0]&(1<<61) != 0 {
|
||
|
return 61
|
||
|
} else if x[0]&(1<<62) != 0 {
|
||
|
return 62
|
||
|
} else if x[0]&(1<<63) != 0 {
|
||
|
return 63
|
||
|
} else if x[1]&(1<<0) != 0 {
|
||
|
return 64
|
||
|
} else if x[1]&(1<<1) != 0 {
|
||
|
return 65
|
||
|
} else if x[1]&(1<<2) != 0 {
|
||
|
return 66
|
||
|
} else if x[1]&(1<<3) != 0 {
|
||
|
return 67
|
||
|
} else if x[1]&(1<<4) != 0 {
|
||
|
return 68
|
||
|
} else if x[1]&(1<<5) != 0 {
|
||
|
return 69
|
||
|
} else if x[1]&(1<<6) != 0 {
|
||
|
return 70
|
||
|
} else if x[1]&(1<<7) != 0 {
|
||
|
return 71
|
||
|
} else if x[1]&(1<<8) != 0 {
|
||
|
return 72
|
||
|
} else if x[1]&(1<<9) != 0 {
|
||
|
return 73
|
||
|
} else if x[1]&(1<<10) != 0 {
|
||
|
return 74
|
||
|
} else if x[1]&(1<<11) != 0 {
|
||
|
return 75
|
||
|
} else if x[1]&(1<<12) != 0 {
|
||
|
return 76
|
||
|
} else if x[1]&(1<<13) != 0 {
|
||
|
return 77
|
||
|
} else if x[1]&(1<<14) != 0 {
|
||
|
return 78
|
||
|
} else if x[1]&(1<<15) != 0 {
|
||
|
return 79
|
||
|
} else if x[1]&(1<<16) != 0 {
|
||
|
return 80
|
||
|
} else if x[1]&(1<<17) != 0 {
|
||
|
return 81
|
||
|
} else if x[1]&(1<<18) != 0 {
|
||
|
return 82
|
||
|
} else if x[1]&(1<<19) != 0 {
|
||
|
return 83
|
||
|
} else if x[1]&(1<<20) != 0 {
|
||
|
return 84
|
||
|
} else if x[1]&(1<<21) != 0 {
|
||
|
return 85
|
||
|
} else if x[1]&(1<<22) != 0 {
|
||
|
return 86
|
||
|
} else if x[1]&(1<<23) != 0 {
|
||
|
return 87
|
||
|
} else if x[1]&(1<<24) != 0 {
|
||
|
return 88
|
||
|
} else if x[1]&(1<<25) != 0 {
|
||
|
return 89
|
||
|
} else if x[1]&(1<<26) != 0 {
|
||
|
return 90
|
||
|
} else if x[1]&(1<<27) != 0 {
|
||
|
return 91
|
||
|
} else if x[1]&(1<<28) != 0 {
|
||
|
return 92
|
||
|
} else if x[1]&(1<<29) != 0 {
|
||
|
return 93
|
||
|
} else if x[1]&(1<<30) != 0 {
|
||
|
return 94
|
||
|
} else if x[1]&(1<<31) != 0 {
|
||
|
return 95
|
||
|
} else if x[1]&(1<<32) != 0 {
|
||
|
return 96
|
||
|
} else if x[1]&(1<<33) != 0 {
|
||
|
return 97
|
||
|
} else if x[1]&(1<<34) != 0 {
|
||
|
return 98
|
||
|
} else if x[1]&(1<<35) != 0 {
|
||
|
return 99
|
||
|
} else if x[1]&(1<<36) != 0 {
|
||
|
return 100
|
||
|
} else if x[1]&(1<<37) != 0 {
|
||
|
return 101
|
||
|
} else if x[1]&(1<<38) != 0 {
|
||
|
return 102
|
||
|
} else if x[1]&(1<<39) != 0 {
|
||
|
return 103
|
||
|
} else if x[1]&(1<<40) != 0 {
|
||
|
return 104
|
||
|
} else if x[1]&(1<<41) != 0 {
|
||
|
return 105
|
||
|
} else if x[1]&(1<<42) != 0 {
|
||
|
return 106
|
||
|
} else if x[1]&(1<<43) != 0 {
|
||
|
return 107
|
||
|
} else if x[1]&(1<<44) != 0 {
|
||
|
return 108
|
||
|
} else if x[1]&(1<<45) != 0 {
|
||
|
return 109
|
||
|
} else if x[1]&(1<<46) != 0 {
|
||
|
return 110
|
||
|
} else if x[1]&(1<<47) != 0 {
|
||
|
return 111
|
||
|
} else if x[1]&(1<<48) != 0 {
|
||
|
return 112
|
||
|
} else if x[1]&(1<<49) != 0 {
|
||
|
return 113
|
||
|
} else if x[1]&(1<<50) != 0 {
|
||
|
return 114
|
||
|
} else if x[1]&(1<<51) != 0 {
|
||
|
return 115
|
||
|
} else if x[1]&(1<<52) != 0 {
|
||
|
return 116
|
||
|
} else if x[1]&(1<<53) != 0 {
|
||
|
return 117
|
||
|
} else if x[1]&(1<<54) != 0 {
|
||
|
return 118
|
||
|
} else if x[1]&(1<<55) != 0 {
|
||
|
return 119
|
||
|
} else if x[1]&(1<<56) != 0 {
|
||
|
return 120
|
||
|
} else if x[1]&(1<<57) != 0 {
|
||
|
return 121
|
||
|
} else if x[1]&(1<<58) != 0 {
|
||
|
return 122
|
||
|
} else if x[1]&(1<<59) != 0 {
|
||
|
return 123
|
||
|
} else if x[1]&(1<<60) != 0 {
|
||
|
return 124
|
||
|
} else if x[1]&(1<<61) != 0 {
|
||
|
return 125
|
||
|
} else if x[1]&(1<<62) != 0 {
|
||
|
return 126
|
||
|
} else if x[1]&(1<<63) != 0 {
|
||
|
return 127
|
||
|
} else if x[2]&(1<<0) != 0 {
|
||
|
return 128
|
||
|
} else if x[2]&(1<<1) != 0 {
|
||
|
return 129
|
||
|
} else if x[2]&(1<<2) != 0 {
|
||
|
return 130
|
||
|
} else if x[2]&(1<<3) != 0 {
|
||
|
return 131
|
||
|
} else if x[2]&(1<<4) != 0 {
|
||
|
return 132
|
||
|
} else if x[2]&(1<<5) != 0 {
|
||
|
return 133
|
||
|
} else if x[2]&(1<<6) != 0 {
|
||
|
return 134
|
||
|
} else if x[2]&(1<<7) != 0 {
|
||
|
return 135
|
||
|
} else if x[2]&(1<<8) != 0 {
|
||
|
return 136
|
||
|
} else if x[2]&(1<<9) != 0 {
|
||
|
return 137
|
||
|
} else if x[2]&(1<<10) != 0 {
|
||
|
return 138
|
||
|
} else if x[2]&(1<<11) != 0 {
|
||
|
return 139
|
||
|
} else if x[2]&(1<<12) != 0 {
|
||
|
return 140
|
||
|
} else if x[2]&(1<<13) != 0 {
|
||
|
return 141
|
||
|
} else if x[2]&(1<<14) != 0 {
|
||
|
return 142
|
||
|
} else if x[2]&(1<<15) != 0 {
|
||
|
return 143
|
||
|
} else if x[2]&(1<<16) != 0 {
|
||
|
return 144
|
||
|
} else if x[2]&(1<<17) != 0 {
|
||
|
return 145
|
||
|
} else if x[2]&(1<<18) != 0 {
|
||
|
return 146
|
||
|
} else if x[2]&(1<<19) != 0 {
|
||
|
return 147
|
||
|
} else if x[2]&(1<<20) != 0 {
|
||
|
return 148
|
||
|
} else if x[2]&(1<<21) != 0 {
|
||
|
return 149
|
||
|
} else if x[2]&(1<<22) != 0 {
|
||
|
return 150
|
||
|
} else if x[2]&(1<<23) != 0 {
|
||
|
return 151
|
||
|
} else if x[2]&(1<<24) != 0 {
|
||
|
return 152
|
||
|
} else if x[2]&(1<<25) != 0 {
|
||
|
return 153
|
||
|
} else if x[2]&(1<<26) != 0 {
|
||
|
return 154
|
||
|
} else if x[2]&(1<<27) != 0 {
|
||
|
return 155
|
||
|
} else if x[2]&(1<<28) != 0 {
|
||
|
return 156
|
||
|
} else if x[2]&(1<<29) != 0 {
|
||
|
return 157
|
||
|
} else if x[2]&(1<<30) != 0 {
|
||
|
return 158
|
||
|
} else if x[2]&(1<<31) != 0 {
|
||
|
return 159
|
||
|
} else if x[2]&(1<<32) != 0 {
|
||
|
return 160
|
||
|
} else if x[2]&(1<<33) != 0 {
|
||
|
return 161
|
||
|
} else if x[2]&(1<<34) != 0 {
|
||
|
return 162
|
||
|
} else if x[2]&(1<<35) != 0 {
|
||
|
return 163
|
||
|
} else if x[2]&(1<<36) != 0 {
|
||
|
return 164
|
||
|
} else if x[2]&(1<<37) != 0 {
|
||
|
return 165
|
||
|
} else if x[2]&(1<<38) != 0 {
|
||
|
return 166
|
||
|
} else if x[2]&(1<<39) != 0 {
|
||
|
return 167
|
||
|
} else if x[2]&(1<<40) != 0 {
|
||
|
return 168
|
||
|
} else if x[2]&(1<<41) != 0 {
|
||
|
return 169
|
||
|
} else if x[2]&(1<<42) != 0 {
|
||
|
return 170
|
||
|
} else if x[2]&(1<<43) != 0 {
|
||
|
return 171
|
||
|
} else if x[2]&(1<<44) != 0 {
|
||
|
return 172
|
||
|
} else if x[2]&(1<<45) != 0 {
|
||
|
return 173
|
||
|
} else if x[2]&(1<<46) != 0 {
|
||
|
return 174
|
||
|
} else if x[2]&(1<<47) != 0 {
|
||
|
return 175
|
||
|
} else if x[2]&(1<<48) != 0 {
|
||
|
return 176
|
||
|
} else if x[2]&(1<<49) != 0 {
|
||
|
return 177
|
||
|
} else if x[2]&(1<<50) != 0 {
|
||
|
return 178
|
||
|
} else if x[2]&(1<<51) != 0 {
|
||
|
return 179
|
||
|
} else if x[2]&(1<<52) != 0 {
|
||
|
return 180
|
||
|
} else if x[2]&(1<<53) != 0 {
|
||
|
return 181
|
||
|
} else if x[2]&(1<<54) != 0 {
|
||
|
return 182
|
||
|
} else if x[2]&(1<<55) != 0 {
|
||
|
return 183
|
||
|
} else if x[2]&(1<<56) != 0 {
|
||
|
return 184
|
||
|
} else if x[2]&(1<<57) != 0 {
|
||
|
return 185
|
||
|
} else if x[2]&(1<<58) != 0 {
|
||
|
return 186
|
||
|
} else if x[2]&(1<<59) != 0 {
|
||
|
return 187
|
||
|
} else if x[2]&(1<<60) != 0 {
|
||
|
return 188
|
||
|
} else if x[2]&(1<<61) != 0 {
|
||
|
return 189
|
||
|
} else if x[2]&(1<<62) != 0 {
|
||
|
return 190
|
||
|
} else if x[2]&(1<<63) != 0 {
|
||
|
return 191
|
||
|
} else if x[3]&(1<<0) != 0 {
|
||
|
return 192
|
||
|
} else if x[3]&(1<<1) != 0 {
|
||
|
return 193
|
||
|
} else if x[3]&(1<<2) != 0 {
|
||
|
return 194
|
||
|
} else if x[3]&(1<<3) != 0 {
|
||
|
return 195
|
||
|
} else if x[3]&(1<<4) != 0 {
|
||
|
return 196
|
||
|
} else if x[3]&(1<<5) != 0 {
|
||
|
return 197
|
||
|
} else if x[3]&(1<<6) != 0 {
|
||
|
return 198
|
||
|
} else if x[3]&(1<<7) != 0 {
|
||
|
return 199
|
||
|
} else if x[3]&(1<<8) != 0 {
|
||
|
return 200
|
||
|
} else if x[3]&(1<<9) != 0 {
|
||
|
return 201
|
||
|
} else if x[3]&(1<<10) != 0 {
|
||
|
return 202
|
||
|
} else if x[3]&(1<<11) != 0 {
|
||
|
return 203
|
||
|
} else if x[3]&(1<<12) != 0 {
|
||
|
return 204
|
||
|
} else if x[3]&(1<<13) != 0 {
|
||
|
return 205
|
||
|
} else if x[3]&(1<<14) != 0 {
|
||
|
return 206
|
||
|
} else if x[3]&(1<<15) != 0 {
|
||
|
return 207
|
||
|
} else if x[3]&(1<<16) != 0 {
|
||
|
return 208
|
||
|
} else if x[3]&(1<<17) != 0 {
|
||
|
return 209
|
||
|
} else if x[3]&(1<<18) != 0 {
|
||
|
return 210
|
||
|
} else if x[3]&(1<<19) != 0 {
|
||
|
return 211
|
||
|
} else if x[3]&(1<<20) != 0 {
|
||
|
return 212
|
||
|
} else if x[3]&(1<<21) != 0 {
|
||
|
return 213
|
||
|
} else if x[3]&(1<<22) != 0 {
|
||
|
return 214
|
||
|
} else if x[3]&(1<<23) != 0 {
|
||
|
return 215
|
||
|
} else if x[3]&(1<<24) != 0 {
|
||
|
return 216
|
||
|
} else if x[3]&(1<<25) != 0 {
|
||
|
return 217
|
||
|
} else if x[3]&(1<<26) != 0 {
|
||
|
return 218
|
||
|
} else if x[3]&(1<<27) != 0 {
|
||
|
return 219
|
||
|
} else if x[3]&(1<<28) != 0 {
|
||
|
return 220
|
||
|
} else if x[3]&(1<<29) != 0 {
|
||
|
return 221
|
||
|
} else if x[3]&(1<<30) != 0 {
|
||
|
return 222
|
||
|
} else if x[3]&(1<<31) != 0 {
|
||
|
return 223
|
||
|
} else if x[3]&(1<<32) != 0 {
|
||
|
return 224
|
||
|
} else if x[3]&(1<<33) != 0 {
|
||
|
return 225
|
||
|
} else if x[3]&(1<<34) != 0 {
|
||
|
return 226
|
||
|
} else if x[3]&(1<<35) != 0 {
|
||
|
return 227
|
||
|
} else if x[3]&(1<<36) != 0 {
|
||
|
return 228
|
||
|
} else if x[3]&(1<<37) != 0 {
|
||
|
return 229
|
||
|
} else if x[3]&(1<<38) != 0 {
|
||
|
return 230
|
||
|
} else if x[3]&(1<<39) != 0 {
|
||
|
return 231
|
||
|
} else if x[3]&(1<<40) != 0 {
|
||
|
return 232
|
||
|
} else if x[3]&(1<<41) != 0 {
|
||
|
return 233
|
||
|
} else if x[3]&(1<<42) != 0 {
|
||
|
return 234
|
||
|
} else if x[3]&(1<<43) != 0 {
|
||
|
return 235
|
||
|
} else if x[3]&(1<<44) != 0 {
|
||
|
return 236
|
||
|
} else if x[3]&(1<<45) != 0 {
|
||
|
return 237
|
||
|
} else if x[3]&(1<<46) != 0 {
|
||
|
return 238
|
||
|
} else if x[3]&(1<<47) != 0 {
|
||
|
return 239
|
||
|
} else if x[3]&(1<<48) != 0 {
|
||
|
return 240
|
||
|
} else if x[3]&(1<<49) != 0 {
|
||
|
return 241
|
||
|
} else if x[3]&(1<<50) != 0 {
|
||
|
return 242
|
||
|
} else if x[3]&(1<<51) != 0 {
|
||
|
return 243
|
||
|
} else if x[3]&(1<<52) != 0 {
|
||
|
return 244
|
||
|
} else if x[3]&(1<<53) != 0 {
|
||
|
return 245
|
||
|
} else if x[3]&(1<<54) != 0 {
|
||
|
return 246
|
||
|
} else if x[3]&(1<<55) != 0 {
|
||
|
return 247
|
||
|
} else if x[3]&(1<<56) != 0 {
|
||
|
return 248
|
||
|
} else if x[3]&(1<<57) != 0 {
|
||
|
return 249
|
||
|
} else if x[3]&(1<<58) != 0 {
|
||
|
return 250
|
||
|
} else if x[3]&(1<<59) != 0 {
|
||
|
return 251
|
||
|
} else if x[3]&(1<<60) != 0 {
|
||
|
return 252
|
||
|
} else if x[3]&(1<<61) != 0 {
|
||
|
return 253
|
||
|
} else if x[3]&(1<<62) != 0 {
|
||
|
return 254
|
||
|
} else if x[3]&(1<<63) != 0 {
|
||
|
return 255
|
||
|
}
|
||
|
return -1
|
||
|
}
|
||
|
|
||
|
func main() {
|
||
|
const ones = ^uint64(0)
|
||
|
for i := 0; i < 256; i++ {
|
||
|
bits := [4]uint64{ones, ones, ones, ones}
|
||
|
|
||
|
// clear bottom i bits
|
||
|
bits[i/64] ^= 1<<(uint(i)&63) - 1
|
||
|
for j := i/64 - 1; j >= 0; j-- {
|
||
|
bits[j] = 0
|
||
|
}
|
||
|
|
||
|
k := test(bits)
|
||
|
if k != i {
|
||
|
print("test(bits)=", k, " want ", i, "\n")
|
||
|
panic("failed")
|
||
|
}
|
||
|
}
|
||
|
}
|