go/test/fixedbugs/bug281.go
Brad Fitzpatrick 2ae77376f7 all: link to https instead of http
The one in misc/makerelease/makerelease.go is particularly bad and
probably warrants rotating our keys.

I didn't update old weekly notes, and reverted some changes involving
test code for now, since we're late in the Go 1.5 freeze. Otherwise,
the rest are all auto-generated changes, and all manually reviewed.

Change-Id: Ia2753576ab5d64826a167d259f48a2f50508792d
Reviewed-on: https://go-review.googlesource.com/12048
Reviewed-by: Rob Pike <r@golang.org>
2015-07-11 14:36:33 +00:00

56 lines
905 B
Go

// run
// 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.
// https://golang.org/issue/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)
}
}