good morning!!!!

Skip to content
Snippets Groups Projects
README.md 5.31 KiB
Newer Older
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Ethereum Go Client © 2014 Jeffrey Wilcke.

Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
          | Linux   | OSX | Windows | Tests
----------|---------|-----|---------|------
develop   | [![Build+Status](https://build.ethdev.com/buildstatusimage?builder=Linux%20Go%20develop%20branch)](https://build.ethdev.com/builders/Linux%20Go%20develop%20branch/builds/-1) | [![Build+Status](https://build.ethdev.com/buildstatusimage?builder=Linux%20Go%20develop%20branch)](https://build.ethdev.com/builders/OSX%20Go%20develop%20branch/builds/-1) | N/A | [![Buildr+Status](https://travis-ci.org/ethereum/go-ethereum.svg?branch=develop)](https://travis-ci.org/ethereum/go-ethereum)
master    | [![Build+Status](https://build.ethdev.com/buildstatusimage?builder=Linux%20Go%20master%20branch)](https://build.ethdev.com/builders/Linux%20Go%20master%20branch/builds/-1) | [![Build+Status](https://build.ethdev.com/buildstatusimage?builder=OSX%20Go%20master%20branch)](https://build.ethdev.com/builders/OSX%20Go%20master%20branch/builds/-1) | N/A | [![Buildr+Status](https://travis-ci.org/ethereum/go-ethereum.svg?branch=master)](https://travis-ci.org/ethereum/go-ethereum)
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
[![Bugs](https://badge.waffle.io/ethereum/go-ethereum.png?label=bug&title=Bugs)](https://waffle.io/ethereum/go-ethereum)
[![Stories in Ready](https://badge.waffle.io/ethereum/go-ethereum.png?label=ready&title=Ready)](https://waffle.io/ethereum/go-ethereum)
[![Stories in Progress](https://badge.waffle.io/ethereum/go-ethereum.svg?label=in%20progress&title=In Progress)](http://waffle.io/ethereum/go-ethereum)
[![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ethereum/go-ethereum?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
Build
=====

Mist (GUI):
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

`go get github.com/ethereum/go-ethereum/cmd/mist`

Ethereum (CLI):
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

`go get github.com/ethereum/go-ethereum/cmd/ethereum`

Viktor Trón's avatar
Viktor Trón committed
As of POC-8, go-ethereum uses [Godep](https://github.com/tools/godep) to manage dependencies. Assuming you have [your environment all set up](https://github.com/ethereum/go-ethereum/wiki/Building-Ethereum(Go)), switch to the go-ethereum repository root folder, and build/install the executable you need:

Mist (GUI):

```
godep go build -v ./cmd/mist
```

Ethereum (CLI):

```
godep go build -v ./cmd/ethereum
```

Instead of `build`, you can use `install` which will also install the resulting binary.

For prerequisites and detailed build instructions please see the [Wiki](https://github.com/ethereum/go-ethereum/wiki/Building-Ethereum(Go))

If you intend to develop on go-ethereum, check the [Developers' Guide](https://github.com/ethereum/go-ethereum/wiki/Developers'-Guide)
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
Automated (dev) builds
======================

Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
* [Docker](https://registry.hub.docker.com/u/ethereum/client-go/)
* [OS X](http://build.ethdev.com/builds/OSX%20Go%20develop%20branch/Mist-OSX-latest.dmg)
* Ubuntu
  [Trusty](https://build.ethdev.com/builds/Linux%20Go%20develop%20deb%20i386-trusty/latest/ethereum-cli_0.9.0%2B192SNAPSHOT20150314224122trusty-0ubuntu1_i386.deb) |
  [utopic](https://build.ethdev.com/builds/Linux%20Go%20develop%20deb%20i386-utopic/latest/ethereum-cli_0.9.0%2B194SNAPSHOT20150314224124utopic-0ubuntu1_i386.deb)
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
* [Windows] Coming soon™
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Viktor Trón's avatar
Viktor Trón committed
Executables
===========
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Viktor Trón's avatar
Viktor Trón committed
Go Ethereum comes with several wrappers/executables found in 
[the `cmd` directory](https://github.com/ethereum/go-ethereum/tree/develop/cmd):
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Viktor Trón's avatar
Viktor Trón committed
* `mist` Official Ethereum Browser (ethereum GUI client)
* `ethereum` Ethereum CLI (ethereum command line interface client)
* `bootnode` runs a bootstrap node for the Discovery Protocol
* `ethtest` test tool which runs with the [tests](https://github.com/ethereum/testes) suite: 
  `cat file | ethtest`.
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
* `evm` is a generic Ethereum Virtual Machine: `evm -code 60ff60ff -gas
  10000 -price 0 -dump`. See `-h` for a detailed description.
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
* `disasm` disassembles EVM code: `echo "6001" | disasm`
Viktor Trón's avatar
Viktor Trón committed
* `rlpdump` converts a rlp stream to `interface{}`.
Viktor Trón's avatar
Viktor Trón committed
Command line options
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
============================
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed

Viktor Trón's avatar
Viktor Trón committed
Both `mist` and `ethereum` can be configured via command line options, environment variables and config files.

To get the options available:

Viktor Trón's avatar
Viktor Trón committed
ethereum -help
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
```

Viktor Trón's avatar
Viktor Trón committed
For further details on options, see the [wiki](https://github.com/ethereum/go-ethereum/wiki/Command-Line-Options)

Contribution
============

Viktor Trón's avatar
Viktor Trón committed
If you'd like to contribute to go-ethereum please fork, fix, commit and
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
send a pull request. Commits who do not comply with the coding standards
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed
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.
Viktor Trón's avatar
Viktor Trón committed
For dependency management, we use [godep](https://github.com/tools/godep). After installing with `go get github.com/tools/godep`, run `godep restore` to ensure that changes to other repositories do not break the build. To update a dependency version (for example, to include a new upstream fix), run `go get -u <foo/bar>` then `godep update <foo/...>`. To track a new dependency, add it to the project as normal than run `godep save ./...`. Changes to the [Godeps folder](https://github.com/ethereum/go-ethereum/tree/develop/Godeps): should be manually verified then commited.

To make life easier try [git flow](http://nvie.com/posts/a-successful-git-branching-model/) it sets this all up and streamlines your work flow.
Viktor Trón's avatar
Viktor Trón committed
See [Developers' Guide](https://github.com/ethereum/go-ethereum/wiki/Developers'-Guide)
Jeffrey Wilcke's avatar
Jeffrey Wilcke committed