]> Cypherpunks repositories - gostls13.git/log
gostls13.git
13 years agocmd/[568]g: header cleanup.
Rémy Oudompheng [Thu, 27 Sep 2012 06:34:00 +0000 (08:34 +0200)]
cmd/[568]g: header cleanup.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6573059

13 years agobufio: Implement io.WriterTo for (*Reader)
Michael Chaten [Thu, 27 Sep 2012 06:31:03 +0000 (16:31 +1000)]
bufio: Implement io.WriterTo for (*Reader)

This is part 1 of 2 for issue 4028

benchmark                       old ns/op    new ns/op    delta
BenchmarkReaderCopyOptimal          33495         9849  -70.60%
BenchmarkReaderCopyUnoptimal        70631        27041  -61.72%
BenchmarkReaderCopyOldImpl          51407        52970   +3.04%

Update #4028

R=dave, nigeltao, rsc, bradfitz, rogpeppe
CC=golang-dev
https://golang.org/cl/6548047

13 years agotext/template: fix typo of errorf as error in comment.
Josh Holland [Thu, 27 Sep 2012 05:47:54 +0000 (15:47 +1000)]
text/template: fix typo of errorf as error in comment.

R=r, minux.ma
CC=gobot, golang-dev
https://golang.org/cl/6506120

13 years agoCLA: Josh Holland <jrh@joshh.co.uk> individual contributor
Rob Pike [Thu, 27 Sep 2012 05:47:18 +0000 (15:47 +1000)]
CLA: Josh Holland <jrh@joshh.co.uk> individual contributor

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/6568059

13 years agocmd/api: delete redundant text from deletion message
Rob Pike [Thu, 27 Sep 2012 05:39:56 +0000 (15:39 +1000)]
cmd/api: delete redundant text from deletion message

R=bradfitz, minux.ma, rsc
CC=golang-dev
https://golang.org/cl/6543064

13 years agolzw: fix Write returning the wrong number of bytes written.
Nigel Tao [Thu, 27 Sep 2012 03:29:39 +0000 (13:29 +1000)]
lzw: fix Write returning the wrong number of bytes written.

Fixes #4160.

R=rsc, r
CC=golang-dev
https://golang.org/cl/6564060

13 years agofmt: allow # and x together for strings
Rob Pike [Wed, 26 Sep 2012 20:21:38 +0000 (06:21 +1000)]
fmt: allow # and x together for strings
Silly and small but easy to be consistent.
To make it worthwhile, I eliminated an allocation when using
%x on a byte slice.

Fixes #4149.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6574046

13 years agonet: spread fd over several pollservers.
Sébastien Paolacci [Wed, 26 Sep 2012 19:32:59 +0000 (15:32 -0400)]
net: spread fd over several pollservers.

Lighten contention without preventing further improvements on pollservers.
Connections are spread over Min(GOMAXPROCS, NumCPU, 8) pollserver instances.

Median of 10 runs, 4 cores @ 3.4GHz, amd/linux-3.2:

BenchmarkTCPOneShot                171917 ns/op   175194 ns/op      1.91%
BenchmarkTCPOneShot-2              101413 ns/op   109462 ns/op      7.94%
BenchmarkTCPOneShot-4               91796 ns/op    35712 ns/op    -61.10%
BenchmarkTCPOneShot-6               90938 ns/op    30607 ns/op    -66.34%
BenchmarkTCPOneShot-8               90374 ns/op    29150 ns/op    -67.75%
BenchmarkTCPOneShot-16             101089 ns/op   111526 ns/op     10.32%

BenchmarkTCPOneShotTimeout         174986 ns/op   178606 ns/op      2.07%
BenchmarkTCPOneShotTimeout-2       101585 ns/op   110678 ns/op      8.95%
BenchmarkTCPOneShotTimeout-4        91547 ns/op    35931 ns/op    -60.75%
BenchmarkTCPOneShotTimeout-6        91496 ns/op    31019 ns/op    -66.10%
BenchmarkTCPOneShotTimeout-8        90670 ns/op    29531 ns/op    -67.43%
BenchmarkTCPOneShotTimeout-16      101013 ns/op   106026 ns/op      4.96%

BenchmarkTCPPersistent              51731 ns/op    53324 ns/op      3.08%
BenchmarkTCPPersistent-2            32888 ns/op    30678 ns/op     -6.72%
BenchmarkTCPPersistent-4            25751 ns/op    15595 ns/op    -39.44%
BenchmarkTCPPersistent-6            26737 ns/op     9805 ns/op    -63.33%
BenchmarkTCPPersistent-8            26850 ns/op     9730 ns/op    -63.76%
BenchmarkTCPPersistent-16          104449 ns/op   102838 ns/op     -1.54%

BenchmarkTCPPersistentTimeout       51806 ns/op    53281 ns/op      2.85%
BenchmarkTCPPersistentTimeout-2     32956 ns/op    30895 ns/op     -6.25%
BenchmarkTCPPersistentTimeout-4     25994 ns/op    18111 ns/op    -30.33%
BenchmarkTCPPersistentTimeout-6     26679 ns/op     9846 ns/op    -63.09%
BenchmarkTCPPersistentTimeout-8     26810 ns/op     9727 ns/op    -63.72%
BenchmarkTCPPersistentTimeout-16   101652 ns/op   104410 ns/op      2.71%

R=rsc, dvyukov, dave, mikioh.mikioh, bradfitz, remyoudompheng
CC=golang-dev
https://golang.org/cl/6496054

13 years agocmd/6g, cmd/8g: fix two "out of fixed registers" cases.
Rémy Oudompheng [Wed, 26 Sep 2012 19:17:11 +0000 (21:17 +0200)]
cmd/6g, cmd/8g: fix two "out of fixed registers" cases.

In two cases, registers were allocated too early resulting
in exhausting of available registers when nesting these
operations.

The case of method calls was due to missing cases in igen,
which only makes calls but doesn't allocate a register for
the result.

The case of 8-bit multiplication was due to a wrong order
in register allocation when Ullman numbers were bigger on the
RHS.

Fixes #3907.
Fixes #4156.

R=rsc
CC=golang-dev, remy
https://golang.org/cl/6560054

13 years agocmd/gc: Don't calculate second value in range if it is blank.
Daniel Morsing [Wed, 26 Sep 2012 19:10:29 +0000 (21:10 +0200)]
cmd/gc: Don't calculate second value in range if it is blank.

Low hanging fruit optimization. Will remove an expensive copy if the range variable is an array.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6564052

13 years agocrypto/x509: add Plan 9 root certificate location
David du Colombier [Wed, 26 Sep 2012 18:47:47 +0000 (14:47 -0400)]
crypto/x509: add Plan 9 root certificate location

R=golang-dev
CC=golang-dev, rsc
https://golang.org/cl/6571056

13 years agodoc: add important info for would-be go contributors.
Jonathan Feinberg [Wed, 26 Sep 2012 18:39:31 +0000 (14:39 -0400)]
doc: add important info for would-be go contributors.

Link to the "installing from source" docs instead of the "installing" docs.

Remind would-be hacker to switch to the default branch from the release branch.

R=rsc
CC=golang-dev
https://golang.org/cl/6559043

13 years agocrypto/aes: speed up using AES-NI on amd64
Shenghou Ma [Wed, 26 Sep 2012 17:54:10 +0000 (01:54 +0800)]
crypto/aes: speed up using AES-NI on amd64

This CL requires CL 5970055.

benchmark           old ns/op    new ns/op    delta
BenchmarkEncrypt          161           23  -85.71%
BenchmarkDecrypt          158           24  -84.24%
BenchmarkExpand           526           62  -88.21%

benchmark            old MB/s     new MB/s  speedup
BenchmarkEncrypt        99.32       696.19    7.01x
BenchmarkDecrypt       100.93       641.56    6.36x

R=golang-dev, bradfitz, dave, rsc
CC=golang-dev
https://golang.org/cl/6549055

13 years agocmd/6a, cmd/6l: add support for AES-NI instrutions and PSHUFD
Shenghou Ma [Wed, 26 Sep 2012 17:53:08 +0000 (01:53 +0800)]
cmd/6a, cmd/6l: add support for AES-NI instrutions and PSHUFD
This CL adds support for the these 7 new instructions to 6a/6l in
preparation of the upcoming CL for AES-NI accelerated crypto/aes:
AESENC, AESENCLAST, AESDEC, AESDECLAST, AESIMC, AESKEYGENASSIST,
and PSHUFD.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/5970055

13 years agocodereview: use subprocess.call() instead of os.spawnvp() for portability
Shivakumar GN [Wed, 26 Sep 2012 17:50:59 +0000 (01:50 +0800)]
codereview: use subprocess.call() instead of os.spawnvp() for portability

Fixes #4121.

R=golang-dev, minux.ma, dave, r
CC=golang-dev
https://golang.org/cl/6555049

13 years agospec: permit trailing comma in conversions
Robert Griesemer [Wed, 26 Sep 2012 17:31:57 +0000 (10:31 -0700)]
spec: permit trailing comma in conversions

Also: Adjust prose in Conversions section
to be consistent.

This is a backward-compatible syntax change.
For a discussion see issue 2568.

Fixes #2568.
Fixes #4123.

R=golang-dev, r, iant, rsc
CC=golang-dev
https://golang.org/cl/6572049

13 years agodoc/go1.1: fix metadata json format
Francisco Souza [Wed, 26 Sep 2012 15:49:36 +0000 (08:49 -0700)]
doc/go1.1: fix metadata json format

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6570054

13 years agocmd/go, cmd/ld: fix libgcc order and add __image_base__ symbol for windows
Shenghou Ma [Wed, 26 Sep 2012 14:34:25 +0000 (22:34 +0800)]
cmd/go, cmd/ld: fix libgcc order and add __image_base__ symbol for windows
        Fixes #4063.

R=alex.brainman, rsc
CC=golang-dev
https://golang.org/cl/6543066

13 years agocmd/go: assume that code in $GOROOT is up to date
Joel Sing [Wed, 26 Sep 2012 14:00:50 +0000 (00:00 +1000)]
cmd/go: assume that code in $GOROOT is up to date

Do not check compiler/linker timestamps for packages that are in the
$GOROOT. Avoids trying to rebuild non-writable standard packages when
timestamps have not been retained on the Go binaries.

Fixes #4106.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6533053

13 years agoreflect.DeepEqual: rewrite clarification about nil and empty slice.
Rob Pike [Wed, 26 Sep 2012 10:46:49 +0000 (20:46 +1000)]
reflect.DeepEqual: rewrite clarification about nil and empty slice.
The previous version was created by an idiot. This time, Rog Peppe
wrote the text. Thanks, Rog.
(== doesn't work on slices in general, so it makes no sense to
talk about in the context of DeepEqual.)

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/6566054

13 years agonet: fix plan 9 build
Mikio Hara [Wed, 26 Sep 2012 07:11:49 +0000 (16:11 +0900)]
net: fix plan 9 build

R=golang-dev, lucio.dere, fshahriar
CC=golang-dev
https://golang.org/cl/6562046

13 years agoreflect.DeepEqual: document that empty and nil are unequal for slices
Rob Pike [Wed, 26 Sep 2012 05:21:07 +0000 (15:21 +1000)]
reflect.DeepEqual: document that empty and nil are unequal for slices

Update #4133.
Added a sentence of documentation to call out the behavior.

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/6572051

13 years agoexp/types/staging: updated gcimporter
Robert Griesemer [Wed, 26 Sep 2012 00:39:02 +0000 (17:39 -0700)]
exp/types/staging: updated gcimporter

Mostly minor changes to match the new
definitions in types.go and const.go.

R=rsc, r
CC=golang-dev
https://golang.org/cl/6506101

13 years agoexp/types/staging: support for typechecking (most) builtins
Robert Griesemer [Wed, 26 Sep 2012 00:38:43 +0000 (17:38 -0700)]
exp/types/staging: support for typechecking (most) builtins

This code relies on some functions that are not yet in staging,
but it get's harder to keep all this in sync in a piece-meal
fashion.

R=rsc
CC=golang-dev
https://golang.org/cl/6492124

13 years agoexp/types/staging: operands, constants, and error handling
Robert Griesemer [Wed, 26 Sep 2012 00:38:22 +0000 (17:38 -0700)]
exp/types/staging: operands, constants, and error handling

More pieces of the typechecker code:

- Operands are temporary objects representing an expressions's
type and value (for constants). An operand is the equivalent of
an "attribute" in attribute grammars except that it's not stored
but only passed around during type checking.

- Constant operations are implemented in const.go. Constants are
represented as bool (booleans), int64 and *big.Int (integers),
*big.Rat (floats), complex (complex numbers), and string (strings).

- Error reporting is consolidated in errors.go. Only the first
dozen of lines is new code, the rest of the file contains the
exprString and typeString functions formerly in two separate
files (which have been removed).

This is a replacement CL for 6492101 (which was created without
proper use of hg).

R=rsc, r
CC=golang-dev
https://golang.org/cl/6500114

13 years agonet/http: use tls host instead of proxy, when checking against a certificate
Christian Himpel [Tue, 25 Sep 2012 16:22:13 +0000 (09:22 -0700)]
net/http: use tls host instead of proxy, when checking against a certificate

Fixes #4152.

R=bradfitz
CC=golang-dev
https://golang.org/cl/6570045

13 years agosyscall: do not use int to test network syscall results (on windows)
Alex Brainman [Tue, 25 Sep 2012 07:06:39 +0000 (17:06 +1000)]
syscall: do not use int to test network syscall results (on windows)

Fixes #4147.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6569050

13 years agocmd/5c: fix dataflag annotation
Shenghou Ma [Tue, 25 Sep 2012 06:42:44 +0000 (14:42 +0800)]
cmd/5c: fix dataflag annotation

file        old_size     new_size    base@c1ce95068533
bin/go      14717392     6287824     5918236

this huge size difference is due to GC data for runtime.mheap
(NOPTR dataflag is not obeyed).

R=rsc, dave
CC=golang-dev
https://golang.org/cl/6547051

13 years agotest/bench/shootout: new data after 64-bit ints for amd64
Rob Pike [Tue, 25 Sep 2012 04:14:26 +0000 (14:14 +1000)]
test/bench/shootout: new data after 64-bit ints for amd64

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/6564046

13 years agocmd/dist: new version for string for development branch
Russ Cox [Tue, 25 Sep 2012 01:35:20 +0000 (21:35 -0400)]
cmd/dist: new version for string for development branch

Remove VERSION, which was forcing version to 'devel'.

Old:
$ go version
go version devel

New:
$ go version
go version devel +0a3866d6cc6b Mon Sep 24 20:08:05 2012 -0400

The date and time (and time zone) is that of the most recent commit,
not the time of the build itself. With some effort we could normalize
the zone, but I don't think it's worth the effort (more C coding,
since Mercurial is unhelpful).

R=r, dsymonds
CC=golang-dev
https://golang.org/cl/6569049

13 years agobuild: make int 64 bits on amd64
Russ Cox [Tue, 25 Sep 2012 00:57:01 +0000 (20:57 -0400)]
build: make int 64 bits on amd64

The assembly offsets were converted mechanically using
code.google.com/p/rsc/cmd/asmlint. The instruction
changes were done by hand.

Fixes #2188.

R=iant, r, bradfitz, remyoudompheng
CC=golang-dev
https://golang.org/cl/6550058

13 years agoruntime: add types to MSpan
Jan Ziak [Tue, 25 Sep 2012 00:08:05 +0000 (20:08 -0400)]
runtime: add types to MSpan

R=rsc
CC=golang-dev
https://golang.org/cl/6554060

13 years agoreflect: add MakeFunc (API CHANGE)
Russ Cox [Tue, 25 Sep 2012 00:06:32 +0000 (20:06 -0400)]
reflect: add MakeFunc (API CHANGE)

Fixes #1765.

R=iant, r, daniel.morsing, minux.ma, bradfitz, rogpeppe, remyoudompheng
CC=golang-dev
https://golang.org/cl/6554067

13 years agonet: add read, write message methods to IPConn, UDPConn
Mikio Hara [Mon, 24 Sep 2012 21:57:32 +0000 (06:57 +0900)]
net: add read, write message methods to IPConn, UDPConn

Both methods allow to access the IP ancillary data through
socket control messages.

This CL is required for CL 6482044; go.net/ipv4: new package.

R=rsc, r, dave
CC=golang-dev
https://golang.org/cl/6426047

13 years agocmd/{5g,6g,8g,6c}: remove unused macro, use %E to print etype.
Rémy Oudompheng [Mon, 24 Sep 2012 21:44:00 +0000 (23:44 +0200)]
cmd/{5g,6g,8g,6c}: remove unused macro, use %E to print etype.

R=golang-dev, rsc, dave
CC=golang-dev
https://golang.org/cl/6569044

13 years agocmd/6g, cmd/8g: add OINDREG, ODOT, ODOTPTR cases to igen.
Rémy Oudompheng [Mon, 24 Sep 2012 21:07:44 +0000 (23:07 +0200)]
cmd/6g, cmd/8g: add OINDREG, ODOT, ODOTPTR cases to igen.

Apart from reducing the number of LEAL/LEAQ instructions by about
30%, it gives 8g easier registerization in several cases,
for example in strconv. Performance with 6g is not affected.

Before (386):
src/pkg/strconv/decimal.go:22   TEXT  (*decimal).String+0(SB),$240-12
src/pkg/strconv/extfloat.go:540 TEXT  (*extFloat).ShortestDecimal+0(SB),$584-20

After (386):
src/pkg/strconv/decimal.go:22   TEXT  (*decimal).String+0(SB),$196-12
src/pkg/strconv/extfloat.go:540 TEXT  (*extFloat).ShortestDecimal+0(SB),$420-20

Benchmarks with GOARCH=386 (on a Core 2).

benchmark                 old ns/op    new ns/op    delta
BenchmarkBinaryTree17    7110191000   7079644000   -0.43%
BenchmarkFannkuch11      7769274000   7766514000   -0.04%
BenchmarkGobDecode         33454820     34755400   +3.89%
BenchmarkGobEncode         11675710     11007050   -5.73%
BenchmarkGzip            2013519000   1593855000  -20.84%
BenchmarkGunzip           253368200    242667600   -4.22%
BenchmarkJSONEncode       152443900    120763400  -20.78%
BenchmarkJSONDecode       304112800    247461800  -18.63%
BenchmarkMandelbrot200     29245520     29240490   -0.02%
BenchmarkParse              8484105      8088660   -4.66%
BenchmarkRevcomp         2695688000   2841263000   +5.40%
BenchmarkTemplate         363759800    277271200  -23.78%

benchmark                       old ns/op    new ns/op    delta
BenchmarkAtof64Decimal                127          129   +1.57%
BenchmarkAtof64Float                  166          164   -1.20%
BenchmarkAtof64FloatExp               308          300   -2.60%
BenchmarkAtof64Big                    584          571   -2.23%
BenchmarkAppendFloatDecimal           440          430   -2.27%
BenchmarkAppendFloat                  995          776  -22.01%
BenchmarkAppendFloatExp               897          746  -16.83%
BenchmarkAppendFloatNegExp            900          752  -16.44%
BenchmarkAppendFloatBig              1528         1228  -19.63%
BenchmarkAppendFloat32Integer         443          453   +2.26%
BenchmarkAppendFloat32ExactFraction   812          661  -18.60%
BenchmarkAppendFloat32Point          1002          773  -22.85%
BenchmarkAppendFloat32Exp             858          725  -15.50%
BenchmarkAppendFloat32NegExp          848          728  -14.15%
BenchmarkAppendFloat64Fixed1          447          431   -3.58%
BenchmarkAppendFloat64Fixed2          480          462   -3.75%
BenchmarkAppendFloat64Fixed3          461          457   -0.87%
BenchmarkAppendFloat64Fixed4          509          484   -4.91%

Update #1914.

R=rsc, nigeltao
CC=golang-dev, remy
https://golang.org/cl/6494107

13 years agocrypto/tls: support session ticket resumption.
Adam Langley [Mon, 24 Sep 2012 20:52:43 +0000 (16:52 -0400)]
crypto/tls: support session ticket resumption.

Session resumption saves a round trip and removes the need to perform
the public-key operations of a TLS handshake when both the client and
server support it (which is true of Firefox and Chrome, at least).

R=golang-dev, bradfitz, rsc
CC=golang-dev
https://golang.org/cl/6555051

13 years agotesting: document -test.bench flag
Francesc Campoy [Mon, 24 Sep 2012 20:05:47 +0000 (13:05 -0700)]
testing: document -test.bench flag

Fixes #4080.

R=rsc, adg
CC=golang-dev
https://golang.org/cl/6553068

13 years agocmd/gc: fix escape analysis bug
Russ Cox [Mon, 24 Sep 2012 19:53:12 +0000 (15:53 -0400)]
cmd/gc: fix escape analysis bug

Was not handling &x.y[0] and &x.y.z correctly where
y is an array or struct-valued field (not a pointer).

R=ken2
CC=golang-dev
https://golang.org/cl/6551059

13 years agoregexp/syntax: define accepted syntax
Russ Cox [Mon, 24 Sep 2012 19:33:53 +0000 (15:33 -0400)]
regexp/syntax: define accepted syntax

Update #3953.

R=bradfitz, campoy
CC=golang-dev
https://golang.org/cl/6543068

13 years agocmd/8g: don't create redundant temporaries in bgen.
Rémy Oudompheng [Mon, 24 Sep 2012 19:29:24 +0000 (21:29 +0200)]
cmd/8g: don't create redundant temporaries in bgen.

Comparisons used to create temporaries for arguments
even if they were already variables or addressable.
Removing the extra ones reduces pressure on regopt.

benchmark                 old ns/op    new ns/op    delta
BenchmarkGobDecode         50787620     49908980   -1.73%
BenchmarkGobEncode         19870190     19473030   -2.00%
BenchmarkGzip            3214321000   3067929000   -4.55%
BenchmarkGunzip           496792800    465828600   -6.23%
BenchmarkJSONEncode       232524800    263864400  +13.48%
BenchmarkJSONDecode       622038400    506600600  -18.56%
BenchmarkMandelbrot200     23937310     45913060  +91.81%
BenchmarkParse             14364450     13997010   -2.56%
BenchmarkRevcomp         6919028000   6480009000   -6.35%
BenchmarkTemplate         594458800    539528200   -9.24%

benchmark                  old MB/s     new MB/s  speedup
BenchmarkGobDecode            15.11        15.38    1.02x
BenchmarkGobEncode            38.63        39.42    1.02x
BenchmarkGzip                  6.04         6.33    1.05x
BenchmarkGunzip               39.06        41.66    1.07x
BenchmarkJSONEncode            8.35         7.35    0.88x
BenchmarkJSONDecode            3.12         3.83    1.23x
BenchmarkParse                 4.03         4.14    1.03x
BenchmarkRevcomp              36.73        39.22    1.07x
BenchmarkTemplate              3.26         3.60    1.10x

R=mtj, daniel.morsing, rsc
CC=golang-dev
https://golang.org/cl/6547064

13 years agotesting: add memory allocation stats to benchmark
Eric Roshan-Eisner [Mon, 24 Sep 2012 19:03:16 +0000 (15:03 -0400)]
testing: add memory allocation stats to benchmark

R=rsc, nigeltao, dave, bradfitz, r, rogpeppe
CC=golang-dev
https://golang.org/cl/6497084

13 years agocmd/gc: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 18:59:44 +0000 (14:59 -0400)]
cmd/gc: prepare for 64-bit ints

This CL makes the compiler understand that the type of
the len or cap of a map, slice, or string is 'int', not 'int32'.
It does not change the meaning of int, but it should make
the eventual change of the meaning of int in 6g a bit smoother.

Update #2188.

R=ken, dave, remyoudompheng
CC=golang-dev
https://golang.org/cl/6542059

13 years agocmd/ld: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 18:59:09 +0000 (14:59 -0400)]
cmd/ld: prepare for 64-bit ints

Use explicit IntSize constant instead of 4.

This CL does not change the meaning of int, but it should make
the eventual change of the meaning of int on amd64 a bit
smoother.

Update #2188.

R=ken, dave
CC=golang-dev
https://golang.org/cl/6554076

13 years agocmd/cgo: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 18:58:57 +0000 (14:58 -0400)]
cmd/cgo: prepare for 64-bit ints

This CL makes the size of an int controlled by a variable
in cgo instead of hard-coding 4 (or 32 bits) in various places.

Update #2188.

R=iant, r, dave
CC=golang-dev
https://golang.org/cl/6548061

13 years agomisc/cgo: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 18:58:45 +0000 (14:58 -0400)]
misc/cgo: prepare for 64-bit ints

In a few places, the existing cgo tests assume that a
Go int is the same as a C int. Making int 64 bits wide
on 64-bit platforms violates this assumption.
Change that code to assume that Go int32 and C int
are the same instead. That's still not great, but it's better,
and I am unaware of any systems we run on where it is not true.

Update #2188.

R=iant, r
CC=golang-dev
https://golang.org/cl/6552064

13 years agoruntime: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 18:58:34 +0000 (14:58 -0400)]
runtime: prepare for 64-bit ints

This CL makes the runtime understand that the type of
the len or cap of a map, slice, or string is 'int', not 'int32',
and it is also careful to distinguish between function arguments
and results of type 'int' vs type 'int32'.

In the runtime, the new typedefs 'intgo' and 'uintgo' refer
to Go int and uint. The C types int and uint continue to be
unavailable (cause intentional compile errors).

This CL does not change the meaning of int, but it should make
the eventual change of the meaning of int on amd64 a bit
smoother.

Update #2188.

R=iant, r, dave, remyoudompheng
CC=golang-dev
https://golang.org/cl/6551067

13 years agocmd/[568]g: explain the purpose of various Reg fields.
Rémy Oudompheng [Mon, 24 Sep 2012 18:55:11 +0000 (20:55 +0200)]
cmd/[568]g: explain the purpose of various Reg fields.

R=golang-dev, rsc
CC=golang-dev, remy
https://golang.org/cl/6554062

13 years agoCONTRIBUTORS: add Jonathan Feinberg (Google CLA)
Russ Cox [Mon, 24 Sep 2012 18:36:07 +0000 (14:36 -0400)]
CONTRIBUTORS: add Jonathan Feinberg (Google CLA)

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6553067

13 years agotag go1.0.3
Andrew Gerrand [Mon, 24 Sep 2012 18:15:33 +0000 (13:15 -0500)]
tag go1.0.3

R=rsc
CC=golang-dev
https://golang.org/cl/6543069

13 years agolib9/fmt: do not put a main symbol into lib9.a
Russ Cox [Mon, 24 Sep 2012 16:57:05 +0000 (12:57 -0400)]
lib9/fmt: do not put a main symbol into lib9.a

Fixes #4143.

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6541064

13 years agoA+C: Add Shivakumar GN (Individual CLA)
Brad Fitzpatrick [Mon, 24 Sep 2012 16:49:31 +0000 (09:49 -0700)]
A+C: Add Shivakumar GN (Individual CLA)

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6541062

13 years agocmd/gc: fix comment for caninl
Russ Cox [Mon, 24 Sep 2012 16:30:32 +0000 (12:30 -0400)]
cmd/gc: fix comment for caninl

Was describing an old implementation.

R=ken2
CC=golang-dev
https://golang.org/cl/6553066

13 years agocmd/dist, pkg/runtime: Plan 9, 64-bit: Get PID from TLS; remove use of `_tos'.
Akshat Kumar [Mon, 24 Sep 2012 16:24:45 +0000 (12:24 -0400)]
cmd/dist, pkg/runtime: Plan 9, 64-bit: Get PID from TLS; remove use of `_tos'.

Using offsets from Tos is cumbersome and we've had problems
in the past. Since it's only being used to grab the PID, we'll just
get that from the default TLS instead.

R=rsc, rminnich, npe
CC=golang-dev
https://golang.org/cl/6543049

13 years agoreflect: fix mistake in error message
Russ Cox [Mon, 24 Sep 2012 15:47:27 +0000 (11:47 -0400)]
reflect: fix mistake in error message

Pointed out by James Chalfant after submit of CL 6500065.

TBR=golang-dev
CC=golang-dev
https://golang.org/cl/6543067

13 years agoencoding/asn1: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 14:30:37 +0000 (10:30 -0400)]
encoding/asn1: prepare for 64-bit ints

The code was assuming that int = 32 bits. Don't.

Update #2188.

R=agl
CC=golang-dev
https://golang.org/cl/6543063

13 years agocompress/flate: move the history buffer out of the decompressor struct.
Nigel Tao [Mon, 24 Sep 2012 07:58:08 +0000 (17:58 +1000)]
compress/flate: move the history buffer out of the decompressor struct.

I'm not exactly sure why there's a performance gain, but it seems like
an easy win. Maybe it's a cache line thing. Maybe it's that
unsafe.Sizeof(decompressor{}) drops to below unmappedzero, so that
checkref/checkoffset don't need to insert TESTB instructions. Maybe
it's less noise for the conservative garbage collector. Maybe it's
something else.

compress/flate benchmarks:
BenchmarkDecodeDigitsSpeed1e4          378628       349906   -7.59%
BenchmarkDecodeDigitsSpeed1e5         3481976      3204898   -7.96%
BenchmarkDecodeDigitsSpeed1e6        34419500     31750660   -7.75%
BenchmarkDecodeDigitsDefault1e4        362317       335562   -7.38%
BenchmarkDecodeDigitsDefault1e5       3290032      3107624   -5.54%
BenchmarkDecodeDigitsDefault1e6      30542540     28937480   -5.26%
BenchmarkDecodeDigitsCompress1e4       362803       335158   -7.62%
BenchmarkDecodeDigitsCompress1e5      3294512      3114526   -5.46%
BenchmarkDecodeDigitsCompress1e6     30514940     28927090   -5.20%
BenchmarkDecodeTwainSpeed1e4           412818       389521   -5.64%
BenchmarkDecodeTwainSpeed1e5          3475780      3288908   -5.38%
BenchmarkDecodeTwainSpeed1e6         33629640     31931420   -5.05%
BenchmarkDecodeTwainDefault1e4         369736       348850   -5.65%
BenchmarkDecodeTwainDefault1e5        2861050      2721383   -4.88%
BenchmarkDecodeTwainDefault1e6       27120120     25862050   -4.64%
BenchmarkDecodeTwainCompress1e4        372057       350822   -5.71%
BenchmarkDecodeTwainCompress1e5       2855109      2718664   -4.78%
BenchmarkDecodeTwainCompress1e6      26987010     26336030   -2.41%

image/png benchmarks:
BenchmarkDecodeGray               1841839      1802251   -2.15%
BenchmarkDecodeNRGBAGradient      7115318      6933280   -2.56%
BenchmarkDecodeNRGBAOpaque        6135892      6013284   -2.00%
BenchmarkDecodePaletted           1153313      1114302   -3.38%
BenchmarkDecodeRGB                5619404      5511190   -1.93%

R=rsc, r
CC=golang-dev
https://golang.org/cl/6533048

13 years agoexp/locale/collate/tools/colcmp: implementation of colcmp tool used for comparing
Marcel van Lohuizen [Mon, 24 Sep 2012 04:22:03 +0000 (13:22 +0900)]
exp/locale/collate/tools/colcmp: implementation of colcmp tool used for comparing
various implementation of collation.  The tool provides commands for soring,
regressing one implementation against another, and benchmarking.
Currently it includes collation implementations for the Go collator, ICU,
and one using Darwin's CoreFoundation framework.
To avoid building this tool in the default build, the colcmp tag has been
added to all files. This allows other tools/colcmp in this directory (e.g. it may make
sense to move maketables here) to be put in this directory as well.

R=r, rsc, mpvl
CC=golang-dev
https://golang.org/cl/6496118

13 years agotest: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 04:06:41 +0000 (00:06 -0400)]
test: prepare for 64-bit ints

Minor tweaks to avoid assuming that int is always 32 bits.

Update #2188.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6553062

13 years agotest: minor fixes in run and testlib
Russ Cox [Mon, 24 Sep 2012 04:06:31 +0000 (00:06 -0400)]
test: minor fixes in run and testlib

Can tell this doesn't get run very often, but it is still important
for when you've broken everything else.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6547065

13 years agosyscall: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 04:06:22 +0000 (00:06 -0400)]
syscall: prepare for 64-bit ints

This CL fixes code that incorrectly assumes that int is 32 bits wide.
Specifically, the socketpair system call expects a pointer to a pair
of int32s, not a pair of ints. Fix this inside the wrappers without
changing the APIs.

Update #2188.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6552063

13 years agotext/template: allow .Field access to parenthesized expressions
Rob Pike [Mon, 24 Sep 2012 03:23:15 +0000 (13:23 +1000)]
text/template: allow .Field access to parenthesized expressions

Change the grammar so that field access is a proper operator.
This introduces a new node, ChainNode, into the public (but
actually internal) API of text/template/parse. For
compatibility, we only use the new node type for the specific
construct, which was not parseable before. Therefore this
should be backward-compatible.

Before, .X.Y was a token in the lexer; this CL breaks it out
into .Y applied to .X. But for compatibility we mush them
back together before delivering. One day we might remove
that hack; it's the simple TODO in parse.go/operand.

This change also provides grammatical distinction between
        f
and
        (f)
which might permit function values later, but not now.

Fixes #3999.

R=golang-dev, dsymonds, gri, rsc, mikesamuel
CC=golang-dev
https://golang.org/cl/6494119

13 years agotime: prepare for 64-bit ints
Russ Cox [Mon, 24 Sep 2012 03:04:28 +0000 (23:04 -0400)]
time: prepare for 64-bit ints

The code was trying to interpret a uint32 n as a signed quantity
and then store it in an int. For this, int(n) currently works, but when
int becomes 64 bits one must write int(int32(n)) instead, to get
the 32-bit sign extension.

Update #2188.

R=golang-dev, nigeltao
CC=golang-dev
https://golang.org/cl/6551068

13 years agonet/http: use r.Body.Close to close connection during TestServeFileFromCWD
Alex Brainman [Mon, 24 Sep 2012 02:48:19 +0000 (12:48 +1000)]
net/http: use r.Body.Close to close connection during TestServeFileFromCWD

Fixes #3917.

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6553061

13 years agopkg/go/ast: Avoid doing zero-length writes to the fd.
Akshat Kumar [Sun, 23 Sep 2012 22:30:28 +0000 (08:30 +1000)]
pkg/go/ast: Avoid doing zero-length writes to the fd.

After each line, ast.Print would do a zero-length write,
which would hit the boundary condition on Plan 9 when
reading over pipes (since message boundaries are
preserved). This change makes sure we only do positive-
length writes.

R=rsc, rminnich, dave, r
CC=golang-dev
https://golang.org/cl/6558046

13 years agodoc: Remove obsolete references to weekly releases.
Uriel Mangado [Sun, 23 Sep 2012 21:18:19 +0000 (16:18 -0500)]
doc: Remove obsolete references to weekly releases.

This was misleading and often confusing for new users.

Leaving the actual weekly release history page for historical reference.

R=golang-dev, rsc, adg
CC=golang-dev
https://golang.org/cl/6555053

13 years agotest: expand run.go's errorcheck, make clear which bugs run
Russ Cox [Sun, 23 Sep 2012 17:16:14 +0000 (13:16 -0400)]
test: expand run.go's errorcheck, make clear which bugs run

Today, if run.go doesn't understand a test header line it just ignores
the test, making it too easy to write or edit tests that are not actually
being run.

- expand errorcheck to accept flags, so that bounds.go and escape*.go can run.
- create a whitelist of skippable tests in run.go; skipping others is an error.
- mark all skipped tests at top of file.

Update #4139.

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6549054

13 years agocmd/6g: fix internal error with SSE registers.
Rémy Oudompheng [Sun, 23 Sep 2012 16:22:03 +0000 (18:22 +0200)]
cmd/6g: fix internal error with SSE registers.

Revision 63f7abcae015 introduced a bug caused by
code assuming registers started at X5, not X0.

Fixes #4138.

R=rsc
CC=golang-dev, remy
https://golang.org/cl/6558043

13 years agocmd/5g: fix build
Shenghou Ma [Sun, 23 Sep 2012 07:05:44 +0000 (15:05 +0800)]
cmd/5g: fix build

R=rsc, r
CC=golang-dev
https://golang.org/cl/6552061

13 years agoeffective_go: s/usr/home/ in example
Rob Pike [Sun, 23 Sep 2012 00:44:56 +0000 (10:44 +1000)]
effective_go: s/usr/home/ in example
When I was a lad (and well past), users were in /usr;
now they're somewhere else, I'm told.
Kids today.

Fixes #4122.

R=golang-dev, dsymonds, rsc
CC=golang-dev
https://golang.org/cl/6552060

13 years agocmd/gc: fix use of nil interface, slice
Russ Cox [Sun, 23 Sep 2012 00:42:11 +0000 (20:42 -0400)]
cmd/gc: fix use of nil interface, slice

Fixes #3670.

R=ken2
CC=golang-dev
https://golang.org/cl/6542058

13 years agospec: a couple of minor tweaks to the wording of the import section
Rob Pike [Sat, 22 Sep 2012 19:03:43 +0000 (05:03 +1000)]
spec: a couple of minor tweaks to the wording of the import section
- remove ambiguous 'it'
- use a lower-case PackageName in the example

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/6552057

13 years agocmd/5g: fix register opt bug
Russ Cox [Sat, 22 Sep 2012 14:01:35 +0000 (10:01 -0400)]
cmd/5g: fix register opt bug

The width was not being set on the address, which meant
that the optimizer could not find variables that overlapped
with it and mark them as having had their address taken.
This let to the compiler believing variables had been set
but never used and then optimizing away the set.

Fixes #4129.

R=ken2
CC=golang-dev
https://golang.org/cl/6552059

13 years agoreflect: add Type.ConvertibleTo, Value.Convert (API CHANGE)
Russ Cox [Sat, 22 Sep 2012 12:52:27 +0000 (08:52 -0400)]
reflect: add Type.ConvertibleTo, Value.Convert (API CHANGE)

Fixes #4047.

R=iant, r
CC=golang-dev
https://golang.org/cl/6500065

13 years agocmd/cgo: use debug data for enums on windows
Joel Sing [Sat, 22 Sep 2012 07:57:54 +0000 (17:57 +1000)]
cmd/cgo: use debug data for enums on windows

Use the debug data for enums on windows.

Fixes #4120.

R=alex.brainman
CC=golang-dev
https://golang.org/cl/6545047

13 years agodebug/pe: add symbol support
Joel Sing [Sat, 22 Sep 2012 07:56:49 +0000 (17:56 +1000)]
debug/pe: add symbol support

Add support for processing the COFF symbol table.

R=alex.brainman
CC=golang-dev
https://golang.org/cl/6551045

13 years agocmd/gc: fix a spurious -u compile error
Russ Cox [Sat, 22 Sep 2012 01:12:41 +0000 (21:12 -0400)]
cmd/gc: fix a spurious -u compile error

Fixes #4082.

R=dsymonds
CC=golang-dev
https://golang.org/cl/6545055

13 years agocgo: set alignment to 1 for unions and classes; avoids crash from divide-by-zero
Rob Pike [Fri, 21 Sep 2012 21:25:41 +0000 (07:25 +1000)]
cgo: set alignment to 1 for unions and classes; avoids crash from divide-by-zero
Fixes #4114.

R=golang-dev, iant, rsc, iant, devon.odell
CC=golang-dev
https://golang.org/cl/6553050

13 years agodoc: document go1.0.3
Andrew Gerrand [Fri, 21 Sep 2012 19:50:38 +0000 (14:50 -0500)]
doc: document go1.0.3

R=rsc, r
CC=gobot, golang-dev
https://golang.org/cl/6532049

13 years agodoc/talks: remove talks, refer to talks.golang.org instead
Andrew Gerrand [Fri, 21 Sep 2012 19:38:22 +0000 (14:38 -0500)]
doc/talks: remove talks, refer to talks.golang.org instead

These talks have been moved to the go.talks sub-repository:
        https://code.google.com/p/go.talks

R=rsc, r
CC=gobot, golang-dev
https://golang.org/cl/6529052

13 years agocmd/6g: cosmetic improvements to regopt debugging.
Rémy Oudompheng [Fri, 21 Sep 2012 18:20:26 +0000 (20:20 +0200)]
cmd/6g: cosmetic improvements to regopt debugging.

R=rsc, golang-dev
CC=golang-dev
https://golang.org/cl/6528044

13 years agocmd/6g: use all 16 float registers, optimize float moves
Russ Cox [Fri, 21 Sep 2012 17:39:09 +0000 (13:39 -0400)]
cmd/6g: use all 16 float registers, optimize float moves

Fixes #2446.

R=ken2
CC=golang-dev
https://golang.org/cl/6557044

13 years agoruntime: fix typos in comments
Jan Ziak [Fri, 21 Sep 2012 16:25:55 +0000 (12:25 -0400)]
runtime: fix typos in comments

R=rsc
CC=golang-dev
https://golang.org/cl/6554043

13 years agoruntime: fix mmap comments
Shenghou Ma [Fri, 21 Sep 2012 05:50:02 +0000 (13:50 +0800)]
runtime: fix mmap comments
We only pass lower 32 bits of file offset to asm routine.

R=r, dave, rsc
CC=golang-dev
https://golang.org/cl/6499118

13 years agoall: match asm variable names to Go func declarations
Russ Cox [Fri, 21 Sep 2012 04:35:56 +0000 (00:35 -0400)]
all: match asm variable names to Go func declarations

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6548046

13 years agounicode: performance improvements (API change)
Russ Cox [Fri, 21 Sep 2012 04:35:25 +0000 (00:35 -0400)]
unicode: performance improvements (API change)

*** There is an API change here: the introduction of the
LatinOffset int in the RangeTable struct. ***

* Avoid checking Latin range multiple times for non-Latin runes.
* Use linear search when it is faster than binary search.

go test -calibrate runs the calibration for where the linear/binary
crossover should be.

benchmark                       old MB/s     new MB/s  speedup
BenchmarkFields            36.27        41.43    1.14x
BenchmarkFieldsFunc        36.23        41.38    1.14x

The speedup here is evenly split between the linear scans
and the LatinOffset change. Both are about 1.07x.

R=r
CC=bradfitz, gobot, golang-dev
https://golang.org/cl/6526048

13 years agocmd/{ld,5l,6l,8l}: add support for OpenBSD ELF signatures
Joel Sing [Fri, 21 Sep 2012 02:51:39 +0000 (12:51 +1000)]
cmd/{ld,5l,6l,8l}: add support for OpenBSD ELF signatures

OpenBSD now requires ELF binaries to have a PT_NOTE that identifies
it as an OpenBSD binary. Refactor the existing NetBSD ELF signature
code and implement support for OpenBSD ELF signatures.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6489131

13 years agonet: fix comment
Mikio Hara [Thu, 20 Sep 2012 22:13:36 +0000 (07:13 +0900)]
net: fix comment

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6546044

13 years agosync: add Once test with panic
Dmitriy Vyukov [Thu, 20 Sep 2012 19:29:29 +0000 (23:29 +0400)]
sync: add Once test with panic
Tests behavior of Once when initialization function panics.

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/6554047

13 years agocmd/ld: remove unused assignment
Lucio De Re [Thu, 20 Sep 2012 18:58:33 +0000 (14:58 -0400)]
cmd/ld: remove unused assignment

The calculation of datsize is redundant.

R=golang-dev, seed, rsc
CC=golang-dev
https://golang.org/cl/6503122

13 years agoruntime: reset parfor stats
Dmitriy Vyukov [Thu, 20 Sep 2012 18:46:24 +0000 (22:46 +0400)]
runtime: reset parfor stats
Otherwise they sum up between GCs.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/6535048

13 years agocrypto/x509: Use ExtKeyUsage and UnknownExtKeyUsage fields from template in CreateCer...
Andrew Harding [Thu, 20 Sep 2012 16:36:37 +0000 (12:36 -0400)]
crypto/x509: Use ExtKeyUsage and UnknownExtKeyUsage fields from template in CreateCertificate

R=golang-dev, agl
CC=golang-dev
https://golang.org/cl/6535057

13 years agocrypto/x509: ignore non-critical email constraints
Adam Langley [Thu, 20 Sep 2012 16:30:56 +0000 (12:30 -0400)]
crypto/x509: ignore non-critical email constraints

Previously we tried to parse email constraints as the maximum base
distance (which is unused and must be omitted according to RFC 5280)
because they share the same tag number. Rather than complicate the
code further, this CL just ignores the unused values.

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6552044

13 years agoA+C: Add Andrew Harding (Individual CLA)
Adam Langley [Thu, 20 Sep 2012 16:24:36 +0000 (12:24 -0400)]
A+C: Add Andrew Harding  (Individual CLA)

R=golang-dev, iant
CC=golang-dev
https://golang.org/cl/6544044

13 years agocgo: process DWARF info even when debug data is used for value
Joel Sing [Thu, 20 Sep 2012 03:20:33 +0000 (13:20 +1000)]
cgo: process DWARF info even when debug data is used for value

Always process the DWARF info, even when the const value is determined
using the debug data block. This ensures that the injected enum is
removed and future loads of the same constant do not trigger
inconsistent definitions.

Add tests for issues 2470 and 4054.
Fixes #4054.

R=golang-dev, fullung, dave, rsc, minux.ma
CC=golang-dev
https://golang.org/cl/6501101

13 years agomisc/cgo/test: do not run wasteCPU during TestParallelSleep unless on arm
Alex Brainman [Thu, 20 Sep 2012 02:06:08 +0000 (12:06 +1000)]
misc/cgo/test: do not run wasteCPU during TestParallelSleep unless on arm

R=golang-dev, r, minux.ma, dave, bradfitz
CC=golang-dev
https://golang.org/cl/6532052

13 years agovet: fix rangeloop.
David Symonds [Wed, 19 Sep 2012 22:12:47 +0000 (08:12 +1000)]
vet: fix rangeloop.

In a range loop, the presence of a value implies the presence of a key.
However, the presence of a value as an *ast.Ident does not imply that
the key is also an *ast.Ident, thus leading to a panic any time the
two argument form is used where the key is not an identifier.

R=golang-dev, adg, r
CC=golang-dev
https://golang.org/cl/6540045

13 years agomisc/vim: fix Drop for imports after the first group.
David Symonds [Wed, 19 Sep 2012 22:11:07 +0000 (08:11 +1000)]
misc/vim: fix Drop for imports after the first group.

Previously, an import block such as
import (
         "net"

                "stack"
        )
would not permit ":Drop stack" to work because we were aborting
the scan early, which is only correct when Import is in operation.

R=golang-dev, franciscossouza
CC=golang-dev
https://golang.org/cl/6532053

13 years agogofmt: added testcase for files containing \r\n line endings
Robert Griesemer [Wed, 19 Sep 2012 21:14:21 +0000 (14:14 -0700)]
gofmt: added testcase for files containing \r\n line endings
(see also issue 3961).

hexdump -c testdata/crlf.input
0000000   /   *  \r  \n  \t   S   o   u   r   c   e       c   o   n   t
0000010   a   i   n   i   n   g       C   R   /   L   F       l   i   n
0000020   e       e   n   d   i   n   g   s   .  \r  \n  \t   T   h   e
0000030       g   o   f   m   t   '   e   d       o   u   t   p   u   t
0000040       m   u   s   t       o   n   l   y       h   a   v   e
0000050   L   F  \r  \n  \t   l   i   n   e       e   n   d   i   n   g
0000060   s   .  \r  \n   *   /  \r  \n   p   a   c   k   a   g   e
0000070   m   a   i   n  \r  \n  \r  \n   f   u   n   c       m   a   i
0000080   n   (   )       {  \r  \n  \t   /   /       l   i   n   e
0000090   c   o   m   m   e   n   t  \r  \n  \t   p   r   i   n   t   l
00000a0   n   (   "   h   e   l   l   o   ,       w   o   r   l   d   !
00000b0   "   )       /   /       a   n   o   t   h   e   r       l   i
00000c0   n   e       c   o   m   m   e   n   t  \r  \n  \t   p   r   i
00000d0   n   t   l   n   (   )  \r  \n   }  \r  \n
00000db

hexdump -c testdata/crlf.golden
0000000   /   *  \n  \t   S   o   u   r   c   e       c   o   n   t   a
0000010   i   n   i   n   g       C   R   /   L   F       l   i   n   e
0000020       e   n   d   i   n   g   s   .  \n  \t   T   h   e       g
0000030   o   f   m   t   '   e   d       o   u   t   p   u   t       m
0000040   u   s   t       o   n   l   y       h   a   v   e       L   F
0000050  \n  \t   l   i   n   e       e   n   d   i   n   g   s   .  \n
0000060   *   /  \n   p   a   c   k   a   g   e       m   a   i   n  \n
0000070  \n   f   u   n   c       m   a   i   n   (   )       {  \n  \t
0000080   /   /       l   i   n   e       c   o   m   m   e   n   t  \n
0000090  \t   p   r   i   n   t   l   n   (   "   h   e   l   l   o   ,
00000a0       w   o   r   l   d   !   "   )       /   /       a   n   o
00000b0   t   h   e   r       l   i   n   e       c   o   m   m   e   n
00000c0   t  \n  \t   p   r   i   n   t   l   n   (   )  \n   }  \n
00000cf

R=rsc
CC=golang-dev
https://golang.org/cl/6526052

13 years agoencoding/gob: fix comment
Robert Griesemer [Wed, 19 Sep 2012 17:11:24 +0000 (10:11 -0700)]
encoding/gob: fix comment

Fixes #4100.

R=adg, r, dave
CC=golang-dev
https://golang.org/cl/6535055