Official Go implementation of the Ethereum protocol
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Felix Lange d04a2e7557 all: update license information 9 years ago
.github templates: added issue template 9 years ago
Godeps Godeps: add github.com/rjeczalik/notify 9 years ago
_data Chain tests 10 years ago
accounts all: update license information 9 years ago
build build: tweak update-license.go 9 years ago
cmd all: update license information 9 years ago
common all: update license information 9 years ago
compression/rle all: Rename crypto.Sha3{,Hash}() to crypto.Keccak256{,Hash}() 9 years ago
containers Added Vagrantfile so that developers can spin up a VM to build geth 9 years ago
core all: update license information 9 years ago
crypto accounts, crypto: move keystore to package accounts 9 years ago
errs all: fix license headers one more time 9 years ago
eth all: update license information 9 years ago
ethdb cmd, eth, ethdb, node: prioritise chaindata for resources, bump cache 9 years ago
event event/filter: fix data race in the test 9 years ago
generators generators: Don't generate params/protocol_params.go with +x bit 9 years ago
internal/debug internal/debug: add memStats and gcStats to API 9 years ago
jsre all: update license information 9 years ago
light all: update license information 9 years ago
logger logger/glog: clean up flag getters 9 years ago
metrics eth, metrics, p2p: prepare metrics and net packets to eth/62 9 years ago
miner accounts: streamline API 9 years ago
node all: update license information 9 years ago
p2p p2p: enable EIP-8 handshake sending 9 years ago
params core: added basic chain configuration 9 years ago
pow all: Add GPU mining, disabled by default 9 years ago
rlp all: update license information 9 years ago
rpc all: update license information 9 years ago
tests all: update license information 9 years ago
trie all: update license information 9 years ago
whisper all: update license information 9 years ago
.gitattributes .gitattributes: add 9 years ago
.gitignore Added Vagrantfile so that developers can spin up a VM to build geth 9 years ago
.gitmodules cmd/geth, jsre: updated ethereum.js => web3.js 10 years ago
.mailmap all: update license information 9 years ago
.travis.yml crypto/secp256k1: remove dependency on libgmp 9 years ago
AUTHORS all: update license information 9 years ago
COPYING all: update license information 10 years ago
COPYING.LESSER all: update license information 10 years ago
Makefile Makefile, cmd/geth: support building Android archives 9 years ago
README.md crypto/secp256k1: remove dependency on libgmp 9 years ago
VERSION VERSION, cmd/geth: bumped version 1.4.0 9 years ago

README.md

Ethereum Go

Official golang implementation of the Ethereum protocol

      | Linux   | OSX | ARM | Windows | Tests

----------|---------|-----|-----|---------|------ develop | Build+Status | Build+Status | Build+Status | Build+Status | Buildr+Status codecov.io master | Build+Status | Build+Status | Build+Status | Build+Status | Buildr+Status codecov.io

API Reference Gitter

Automated development builds

The following builds are build automatically by our build servers after each push to the develop branch.

Building the source

For prerequisites and detailed build instructions please read the Installation Instructions on the wiki.

Building geth requires both a Go and a C compiler. You can install them using your favourite package manager. Once the dependencies are installed, run

make geth

Executables

Go Ethereum comes with several wrappers/executables found in the cmd directory:

Command
geth Ethereum CLI (ethereum command line interface client)
bootnode runs a bootstrap node for the Discovery Protocol
ethtest test tool which runs with the tests suite: /path/to/test.json > ethtest --test BlockTests --stdin.
evm is a generic Ethereum Virtual Machine: evm -code 60ff60ff -gas 10000 -price 0 -dump. See -h for a detailed description.
disasm disassembles EVM code: `echo "6001"
rlpdump prints RLP structures

Command line options

geth can be configured via command line options, environment variables and config files.

To get the options available:

geth help

For further details on options, see the wiki

Contribution

If you'd like to contribute to go-ethereum please fork, fix, commit and send a pull request. Commits who do not comply with the coding standards are ignored (use gofmt!). If you send pull requests make absolute sure that you commit on the develop branch and that you do not merge to master. Commits that are directly based on master are simply ignored.

See Developers' Guide for more details on configuring your environment, testing, and dependency management.