- 18 Apr, 2011 10 commits
-
-
Russ Cox authored
Don't assume that localhost == 127.0.0.1. It might be ::1. R=bradfitzgo CC=golang-dev https://golang.org/cl/4430055
-
Russ Cox authored
R=golang-dev, r CC=golang-dev https://golang.org/cl/4423043
-
Russ Cox authored
* Reduces malloc counts during gob encoder/decoder test from 6/6 to 3/5. The current reflect uses Set to mean two subtly different things. (1) If you have a reflect.Value v, it might just represent itself (as in v = reflect.NewValue(42)), in which case calling v.Set only changed v, not any other data in the program. (2) If you have a reflect Value v derived from a pointer or a slice (as in x := []int{42}; v = reflect.NewValue(x).Index(0)), v represents the value held there. Changing x[0] affects the value returned by v.Int(), and calling v.Set affects x[0]. This was not really by design; it just happened that way. The motivation for the new reflect implementation was to remove mallocs. The use case (1) has an implicit malloc inside it. If you can do: v := reflect.NewValue(0) v.Set(42) i := v.Int() // i = 42 then that implies that v is referring to some underlying chunk of memory in order to remember the 42; that is, NewValue must have allocated some memory. Almost all the time you are using reflect the goal is to inspect or to change other data, not to manipulate data stored solely inside a reflect.Value. This CL removes use case (1), so that an assignable reflect.Value must always refer to some other piece of data in the program. Put another way, removing this case would make v := reflect.NewValue(0) v.Set(42) as illegal as 0 = 42. It would also make this illegal: x := 0 v := reflect.NewValue(x) v.Set(42) for the same reason. (Note that right now, v.Set(42) "succeeds" but does not change the value of x.) If you really wanted to make v refer to x, you'd start with &x and dereference it: x := 0 v := reflect.NewValue(&x).Elem() // v = *&x v.Set(42) It's pretty rare, except in tests, to want to use NewValue and then call Set to change the Value itself instead of some other piece of data in the program. I haven't seen it happen once yet while making the tree build with this change. For the same reasons, reflect.Zero (formerly reflect.MakeZero) would also return an unassignable, unaddressable value. This invalidates the (awkward) idiom: pv := ... some Ptr Value we have ... v := reflect.Zero(pv.Type().Elem()) pv.PointTo(v) which, when the API changed, turned into: pv := ... some Ptr Value we have ... v := reflect.Zero(pv.Type().Elem()) pv.Set(v.Addr()) In both, it is far from clear what the code is trying to do. Now that it is possible, this CL adds reflect.New(Type) Value that does the obvious thing (same as Go's new), so this code would be replaced by: pv := ... some Ptr Value we have ... pv.Set(reflect.New(pv.Type().Elem())) The changes just described can be confusing to think about, but I believe it is because the old API was confusing - it was conflating two different kinds of Values - and that the new API by itself is pretty simple: you can only Set (or call Addr on) a Value if it actually addresses some real piece of data; that is, only if it is the result of dereferencing a Ptr or indexing a Slice. If you really want the old behavior, you'd get it by translating: v := reflect.NewValue(x) into v := reflect.New(reflect.Typeof(x)).Elem() v.Set(reflect.NewValue(x)) Gofix will not be able to help with this, because whether and how to change the code depends on whether the original code meant use (1) or use (2), so the developer has to read and think about the code. You can see the effect on packages in the tree in https://golang.org/cl/4423043/. R=r CC=golang-dev https://golang.org/cl/4435042
-
Brad Fitzpatrick authored
R=r, rsc1 CC=golang-dev https://golang.org/cl/4440054
-
Brad Fitzpatrick authored
Fixes #1119. R=rsc, r CC=golang-dev https://golang.org/cl/4437052
-
Rob Pike authored
R=golang-dev, iant CC=golang-dev https://golang.org/cl/4446053
-
Russ Cox authored
R=ken2 CC=golang-dev https://golang.org/cl/4443047
-
Rob Pike authored
Interesting comparisons between old and new machine, and relationship between gccgo and gc. R=golang-dev, rsc1 CC=golang-dev https://golang.org/cl/4430045
-
Quan Yong Zhai authored
~$ nslookup www.google.com Server: 8.8.8.8 cannonical name = www-g-com-chn.l.google.com. R=adg, rsc CC=golang-dev https://golang.org/cl/4445045
-
Nigel Tao authored
R=adg CC=golang-dev, raph https://golang.org/cl/4443046
-
- 17 Apr, 2011 3 commits
-
-
Russ Cox authored
R=dfc, ken2, rsc CC=golang-dev https://golang.org/cl/4446043
-
Russ Cox authored
R=adg, r CC=golang-dev https://golang.org/cl/4423045
-
Dave Cheney authored
Possibly fixes issue 1694. R=bradfitzgo CC=golang-dev https://golang.org/cl/4427049
-
- 16 Apr, 2011 1 commit
-
-
Dmitry Chestnykh authored
Fixes #1633. R=adg, dsymonds CC=golang-dev https://golang.org/cl/4439042
-
- 15 Apr, 2011 26 commits
-
-
Brad Fitzpatrick authored
Working towards issue 1119 Using test data from http://greenbytes.de/tech/tc2231/ R=r CC=golang-dev https://golang.org/cl/4430049
-
Russ Cox authored
cannot use regalloc with floating point on 386. will redo some other way. R=ken2 CC=golang-dev https://golang.org/cl/4439045
-
Ross Light authored
R=bradfitzgo, rsc, bradfitzwork CC=golang-dev https://golang.org/cl/4406046
-
Russ Cox authored
R=ken2 CC=golang-dev https://golang.org/cl/4439044
-
Russ Cox authored
Got lost when I introduced TUNSAFEPTR. R=ken2 CC=golang-dev https://golang.org/cl/4442046
-
Ian Lance Taylor authored
Found by gcc 4.5.2 -Werror build reported on IRC by niemeyer. R=ken2, rsc, r2 CC=golang-dev https://golang.org/cl/4438042
-
Brad Fitzpatrick authored
Fixes #213 R=r, rsc CC=golang-dev https://golang.org/cl/4432043
-
Dmitry Chestnykh authored
Uses placeholder attribute instead of changing the value of search field on browsers that support it. On other browsers, the fake placeholder text is restored when the empty box loses focus. R=golang-dev, gri CC=golang-dev https://golang.org/cl/4441041
-
Rob Pike authored
R=rsc CC=golang-dev https://golang.org/cl/4433042
-
Russ Cox authored
R=golang-dev, r2 CC=golang-dev https://golang.org/cl/4442042
-
Brad Fitzpatrick authored
R=rsc CC=golang-dev https://golang.org/cl/4430043
-
Brad Fitzpatrick authored
R=rsc, petar-m CC=golang-dev https://golang.org/cl/4428041
-
Russ Cox authored
R=ken2 CC=golang-dev https://golang.org/cl/4429043
-
Ian Lance Taylor authored
R=r, r2 CC=golang-dev https://golang.org/cl/4430042
-
Lorenzo Stoakes authored
Trivial patch to stop intermediate rm'ing of binaries stopping build. R=rsc1, bradfitzgo, rsc CC=golang-dev https://golang.org/cl/4412045
-
Russ Cox authored
Don't use external network during all.bash. R=r, r2, rh, ality CC=golang-dev https://golang.org/cl/4429041
-
David Symonds authored
Remove {Float,Int,String}Func, which are now redundant. Fixes #1684. R=rsc, r, r2 CC=golang-dev https://golang.org/cl/4410041
-
Russ Cox authored
R=iant, r2 CC=golang-dev https://golang.org/cl/4427042
-
Dave Cheney authored
Fixes #1706. R=adg, rsc CC=golang-dev https://golang.org/cl/4413051
-
Quan Yong Zhai authored
Fixes #1695. R=golang-dev, rsc CC=golang-dev, r https://golang.org/cl/4418042
-
Russ Cox authored
R=golang-dev, r2 CC=golang-dev https://golang.org/cl/4405045
-
Brad Fitzpatrick authored
NewRequest will save a lot of boilerplate code. This also updates some docs on Request.Write and adds some tests. R=rsc, petar-m, r CC=golang-dev https://golang.org/cl/4406047
-
Russ Cox authored
When prefix doesn't match, was deleting entire .6 file. R=dsymonds CC=golang-dev https://golang.org/cl/4427041
-
Dave Cheney authored
R=adg CC=golang-dev https://golang.org/cl/4426041
-
Andrew Gerrand authored
R=dfc CC=golang-dev https://golang.org/cl/4416044
-
Rob Pike authored
The previous code was just wrong. Let's not talk about it. Passes iant's new test. R=rsc, iant, iant2 CC=golang-dev https://golang.org/cl/4396053
-