blob: 821b0282550efc73bc666130a52b901566170958 (
plain)
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
|
// $G $D/$F.go && $L $F.$A && ./$A.out
// Copyright 2010 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.
// http://code.google.com/p/go/issues/detail?id=807
package main
type Point struct {
X, Y int64
}
type Rect struct {
Min, Max Point
}
func (p Point) Sub(q Point) Point {
return Point{p.X-q.X, p.Y-q.Y}
}
type Obj struct {
bbox Rect
}
func (o *Obj) Bbox() Rect {
return o.bbox
}
func (o *Obj) Points() [2]Point{
return [2]Point{o.bbox.Min, o.bbox.Max}
}
var x = 0
func main() {
o := &Obj{Rect{Point{800, 0}, Point{}}}
p := Point{800, 300}
q := p.Sub(o.Bbox().Min)
if q.X != 0 || q.Y != 300 {
println("BUG dot: ", q.X, q.Y)
return
}
q = p.Sub(o.Points()[0])
if q.X != 0 || q.Y != 300 {
println("BUG index const: ", q.X, q.Y)
}
q = p.Sub(o.Points()[x])
if q.X != 0 || q.Y != 300 {
println("BUG index var: ", q.X, q.Y)
}
}
|