Skip to content
Aleth – Ethereum C++ client, tools and libraries
C++ CMake Shell Assembly Python C Other
Branch: master
Clone or download

Latest commit


Type Name Latest commit message Commit time
Failed to load latest commit information.
aleth-bootnode Add aleth-bootnode readme Dec 11, 2019
aleth-key fix typo Jan 29, 2020
aleth-vm Minor improvements Nov 27, 2019
aleth Fix database rebuild functionality Nov 15, 2019
cmake Fix Windows build error in libscrypt Dec 3, 2019
doc Remove precompile lists from configs in unit tests and docs Nov 26, 2019
evmc @ 1de7833 Upgrade EVMC to 7.1.0 Dec 6, 2019
homebrew Shorten the header license comment in source files Sep 23, 2019
libaleth-interpreter Merge branch 'release/1.7' Nov 12, 2019
libdevcore ClientTest::importRawBlock throws exception with a nested detailed error Dec 12, 2019
libdevcrypto Merge pull request #5737 from Patil2099/First Sep 23, 2019
libethashseal Activate Muir Glacier form on Mainnet and Ropsten Dec 3, 2019
libethcore EIP-2384 Difficulty Bomb Delay / Muir Glacier fork (#5859) Dec 13, 2019
libethereum Add nested detailed error to importRawBlock when full validation fails Dec 16, 2019
libevm Make EVMC options parameter to EVMC class instead of using global list Dec 23, 2019
libp2p Revert "Aleth waits for 2 seconds after sending disconnect to peer be… Nov 22, 2019
libweb3jsonrpc rebase on top of nested exception pr Dec 20, 2019
libwebthree Change client version string to better follow format of other clients Oct 30, 2019
rlp Add the year a file was created to the copyright notice Sep 23, 2019
scripts docker: Add all tools to aleth docker image Nov 22, 2019
test testeth treat null rlp as invalid Feb 29, 2020
utils/json_spirit Add the year a file was created to the copyright notice Sep 23, 2019
.bumpversion.cfg Aleth 1.8.0 Dec 16, 2019
.clang-format clang-format: Add include group for third party libraries Feb 1, 2019
.dockerignore dockerfile for testeth Nov 14, 2018
.editorconfig Add .editorconfig file Dec 19, 2017
.gitignore Improve gitignore of jetbrains stuff Dec 6, 2018
.gitmodules Use dopple instead of jsonrpcproxy Dec 12, 2018
.travis.yml Add the year a file was created to the copyright notice Sep 23, 2019 Add YCM config Dec 10, 2017 Order changelog items Mar 2, 2020
CMakeLists.txt Aleth 1.8.0 Dec 16, 2019 Replace "C++ Ethereum" with "Aleth" in doc title Sep 23, 2018 Changed "latest version" -> "unreleased version" Jun 21, 2019
LICENSE Added missing GPLv3 LICENSE file. Aug 7, 2016 Mention rlp and testeth tools in Readme Dec 11, 2019
appveyor.yml ci: Enable deps build change on AppVeyor Oct 3, 2019
circle.yml Reduce parallel building threads to 2 for gcc-6 Sep 12, 2019
codecov.yml Codecov: Change branch to master Aug 14, 2018
refilltests refill tests Jan 4, 2017
sanitizer-blacklist.txt Added stray and sanitizizer-blacklist.txt files. Aug 12, 2016
snapcraft.yaml Removed libleveldb-dev dependency from snapcraft.yaml Nov 6, 2018

Aleth – Ethereum C++ client, tools and libraries

The collection of C++ libraries and tools for Ethereum, formerly known as cpp-ethereum project. This includes the full Ethereum client aleth.


Gitter GitHub Issues


The Ethereum Documentation site hosts the aleth homepage, which has a Quick Start section.

Operating system Status
Ubuntu and macOS TravisCI
Windows AppVeyor


Download release binaries

Using docker images


docker run ethereum/aleth --help


docker run ethereum/testeth --help

Building from source

Get the source code

Git and GitHub are used to maintain the source code. Clone the repository by:

git clone --recursive
cd aleth

The --recursive option is important. It orders git to clone additional submodules to build the project. If you missed --recursive option, you are able to correct your mistake with command git submodule update --init.

Install CMake

CMake is used to control the build configuration of the project. Latest version of CMake is required (at the time of writing 3.9.3 is the minimum). We strongly recommend you to install CMake by downloading and unpacking the binary distribution of the latest version available on the CMake download page.

The CMake package available in your operating system can also be installed and used if it meets the minimum version requirement.

Alternative method

The repository contains the scripts/ script that downloads a fixed version of CMake and unpacks it to the given directory prefix. Example usage: scripts/ --prefix /usr/local.


Configure the project build with the following command to create the build directory with the configuration.

mkdir build; cd build  # Create a build directory.
cmake ..               # Configure the project.
cmake --build .        # Build all default targets.

On Windows we support Visual Studio 2017, and 2019. You should generate a Visual Studio solution file (.sln) for the 64-bit architecture via the following command:

  • Visual Studio 2017: cmake .. -G "Visual Studio 15 2017 Win64"
  • Visual Studio 2019: cmake .. -G "Visual Studio 16 2019" -A x64

After the necessary dependencies have been downloaded and built and the solution has been generated, aleth.sln can be found in the build directory.

Common Issues Building on Windows

LINK : fatal error LNK1158: cannot run 'rc.exe'

Rc.exe is the Microsoft Resource Compiler. It's distributed with the Windows SDK and is required for generating the Visual Studio solution file. It can be found in the following directory: %ProgramFiles(x86)%\Windows Kits\<OS major version>\bin\<OS full version>\<arch>\

If you hit this error, adding the directory to your path (and launching a new command prompt) should fix the issue.


Contributors Gitter up-for-grabs

The current codebase is the work of many, many hands, with over 100 individual contributors over the course of its development.

Our day-to-day development chat happens on the aleth Gitter channel.

All contributions are welcome! We try to keep a list of tasks that are suitable for newcomers under the tag help wanted. If you have any questions, please do not hesitate to ask us about more information.

Please read CONTRIBUTING and CODING_STYLE thoroughly before making alterations to the code base.

All development goes in develop branch.


Note: The following is the output of ./aleth -h [--help] on Linux

   aleth 1.7.2
   aleth [options]

   account list                                List all keys available in wallet
   account new                                 Create a new key and add it to wallet
   account update [<uuid>|<address> , ... ]    Decrypt and re-encrypt keys
   account import [<uuid>|<file>|<secret-hex>] Import keys from given source and place in wallet
   wallet import <file>                        Import a presale wallet

CLIENT MODE (default):
  --mainnet                               Use the main network protocol
  --ropsten                               Use the Ropsten testnet
  --test                                  Testing mode; disable PoW and provide test rpc interface
  --config <file>                         Configure specialised blockchain using given JSON information

  --ipc                                   Enable IPC server (default: on)
  --ipcpath <path>                        Set .ipc socket path (default: data directory)
  --no-ipc                                Disable IPC server
  --admin <password>                      Specify admin session key for JSON-RPC (default: auto-generated and printed at start-up)
  -K [ --kill ]                           Kill the blockchain first
  -R [ --rebuild ]                        Rebuild the blockchain from the existing database
  --rescue                                Attempt to rescue a corrupt database

  --import-presale <file>                 Import a pre-sale key; you'll need to specify the password to this key
  -s [ --import-secret ] <secret>         Import a secret key into the key store
  -S [ --import-session-secret ] <secret> Import a secret session into the key store
  --master <password>                     Give the master password for the key store; use --master "" to show a prompt
  --password <password>                   Give a password for a private key

  --ask <wei>            Set the minimum ask gas price under which no transaction will be mined (default: 20000000000)
  --bid <wei>            Set the bid gas price to pay for transactions (default: 20000000000)
  --unsafe-transactions  Allow all transactions to proceed without verification; EXTREMELY UNSAFE

  -b [ --bootstrap ]              Connect to the default Ethereum peer servers (default unless --no-discovery used)
  --no-bootstrap                  Do not connect to the default Ethereum peer servers (default only when --no-discovery is used)
  -x [ --peers ] <number>         Attempt to connect to a given number of peers (default: 11)
  --peer-stretch <number>         Give the accepted connection multiplier (default: 7)
  --public-ip <ip>                Force advertised public IP to the given IP (default: auto)
  --listen-ip <ip>(:<port>)       Listen on the given IP for incoming connections (default:
  --listen <port>                 Listen on the given port for incoming connections (default: 30303)
  -r [ --remote ] <host>(:<port>) Connect to the given remote host (default: none)
  --port <port>                   Connect to the given remote port (default: 30303)
  --network-id <n>                Only connect to other hosts with this network id
  --allow-local-discovery         Include local addresses in the discovery process. Used for testing purposes.
  --peerset <list>                Comma delimited list of peers; element format: type:enode://publickey@ipAddress[:port[?discport=port]]
                                          default     Attempt connection when no other peers are available and pinning is disabled
                                          required    Keep connected at all times

                                          The first port argument is the tcp port used for direct communication among peers. If the second port
                                          argument isn't supplied, the first port argument will also be the udp port used for node discovery.
                                          If neither the first nor second port arguments are supplied, a default port of 30303 will be used for
                                          both peer communication and node discovery.
  --no-discovery                  Disable node discovery; implies --no-bootstrap
  --pin                           Only accept or connect to trusted peers

  -a [ --address ] <addr>         Set the author (mining payout) address (default: auto)
  -m [ --mining ] <on/off/number> Enable mining; optionally for a specified number of blocks (default: off)
  --extra-data arg                Set extra data for the sealed blocks

  -M [ --benchmark ]           Benchmark for mining and exit
  --benchmark-warmup <seconds> Set the duration of warmup for the benchmark tests (default: 3)
  --benchmark-trial <seconds>  Set the duration for each trial for the benchmark tests (default: 3)
  --benchmark-trials <n>       Set the number of trials for the benchmark tests (default: 5)

  -C [ --cpu ]                 When mining, use the CPU
  -t [ --mining-threads ] <n>  Limit number of CPU/GPU miners to n (default: use everything available on selected platform)
  --current-block <n>          Let the miner know the current block number at configuration time. Will help determine DAG size and required GPU memory
  --disable-submit-hashrate    When mining, don't submit hashrate to node

  -I [ --import ] <file>      Import blocks from file
  -E [ --export ] <file>      Export blocks to file
  --from <n>                  Export only from block n; n may be a decimal, a '0x' prefixed hash, or 'latest'
  --to <n>                    Export only to block n (inclusive); n may be a decimal, a '0x' prefixed hash, or 'latest'
  --only <n>                  Equivalent to --export-from n --export-to n
  --format <binary/hex/human> Set export format
  --dont-check                Prevent checking some block aspects. Faster importing, but to apply only when the data is known to be valid
  --download-snapshot <path>  Download Parity Warp Sync snapshot data to the specified path
  --import-snapshot <path>    Import blockchain and state data from the Parity Warp Sync snapshot

  --db <name> (=leveldb)      Select database implementation. Available options are: leveldb, memorydb.
  --db-path <path> (=$HOME/.ethereum) Database path (for non-memory database options)

  --vm <name>|<path> (=legacy) Select VM implementation. Available options are: interpreter, legacy.
  --evmc  <option>=<value>     EVMC option

  -v [ --log-verbosity ] <0 - 4>        Set the log verbosity from 0 to 4 (default: 2).
  --log-channels <channel_list>         Space-separated list of the log channels to show (default: show all channels).
                                        Channels: block blockhdr bq chain client debug discov error ethcap exec host impolite info net overlaydb p2pcap peer
                                        rlpx rpc snap statedb sync timer tq trace vmtrace warn warpcap watch
  --log-exclude-channels <channel_list> Space-separated list of the log channels to hide.

  --log-vmtrace                         Enable VM trace log (requires log-verbosity 4).

  -d [ --data-dir ] <path> Load configuration files and keystore from path (default: $HOME/.ethereum)
  -V [ --version ]         Show the version and exit
  -h [ --help ]            Show this help message and exit


The Aleth project includes the following tools in addition to the Aleth client:

  • aleth-bootnode: A C++ Ethereum discovery bootnode implementation
  • aleth-key: A rudimentary wallet
  • aleth-vm: An EVM bytecode runner tool
  • rlp: A RLP encoder/decoder tool
  • testeth: A consensus test generator/runner tool


This project is not suitable for Ethereum mining because the support for GPU mining has been dropped some time ago including the ethminer tool. Use the ethminer tool from


Details on how to run and debug the tests can be found here




All contributions are made under the GNU General Public License v3. See LICENSE.

You can’t perform that action at this time.