1
0
mirror of https://github.com/golang/go synced 2024-11-25 01:08:02 -07:00
The Go programming language
Go to file
Russ Cox 196b663075 gc: implement == on structs and arrays
To allow these types as map keys, we must fill in
equal and hash functions in their algorithm tables.
Structs or arrays that are "just memory", like [2]int,
can and do continue to use the AMEM algorithm.
Structs or arrays that contain special values like
strings or interface values use generated functions
for both equal and hash.

The runtime helper func runtime.equal(t, x, y) bool handles
the general equality case for x == y and calls out to
the equal implementation in the algorithm table.

For short values (<= 4 struct fields or array elements),
the sequence of elementwise comparisons is inlined
instead of calling runtime.equal.

R=ken, mpimenov
CC=golang-dev
https://golang.org/cl/5451105
2011-12-12 22:22:09 -05:00
doc spec: allow comparison of structs, arrays containing comparable values 2011-12-12 22:21:46 -05:00
include lib9: add ctime 2011-11-07 13:15:16 -05:00
lib godoc: added an opensearch description document. 2011-12-12 18:01:06 -05:00
misc misc/cgo/test: fix after latest time changes 2011-12-13 10:46:58 +11:00
src gc: implement == on structs and arrays 2011-12-12 22:22:09 -05:00
test gc: implement == on structs and arrays 2011-12-12 22:22:09 -05:00
.hgignore build: update .hgignore 2011-12-02 16:24:12 +11:00
.hgtags tag weekly.2011-12-06 2011-12-07 13:38:12 +11:00
AUTHORS A+C: add Christoph Hack (individual CLA) 2011-12-12 18:01:02 -05:00
CONTRIBUTORS A+C: add Christoph Hack (individual CLA) 2011-12-12 18:01:02 -05:00
favicon.ico add a favicon plus a couple of hi-res versions of gordon 2009-10-26 10:13:07 -07:00
LICENSE LICENSE: separate, change PATENTS text 2010-12-06 16:31:59 -05:00
PATENTS LICENSE: separate, change PATENTS text 2010-12-06 16:31:59 -05:00
README build: update, streamline documentation for new $GOBIN 2010-08-24 20:00:50 -04:00
robots.txt godoc: serve robots.txt raw 2011-02-19 05:46:20 +11:00

This is the source code repository for the Go programming language.  

For documentation about how to install and use Go,
visit http://golang.org/ or load doc/install.html in your web browser.

After installing Go, you can view a nicely formatted
doc/install.html by running godoc --http=:6060
and then visiting http://localhost:6060/doc/install.html.

Unless otherwise noted, the Go source files are distributed
under the BSD-style license found in the LICENSE file.

--

Binary Distribution Notes

If you have just untarred a binary Go distribution, you need to set
the environment variable $GOROOT to the full path of the go
directory (the one containing this README).  You can omit the
variable if you unpack it into /usr/local/go, or if you rebuild
from sources by running all.bash (see doc/install.html).
You should also add the Go binary directory $GOROOT/bin
to your shell's path.

For example, if you extracted the tar file into $HOME/go, you might
put the following in your .profile:

    export GOROOT=$HOME/go
    export PATH=$PATH:$GOROOT/bin

See doc/install.html for more details.