Go Node and SDK for the NEO blockchain
Find a file
Evgenii Stratonikov b461a6ab63 compiler: do not short-circuit in complex conditions
Current implementation of short-circuting is just plain wrong
as it uses `last` or `before-last` labels which meaning depend
on context. It doesn't even handle simple assignements like
`a := x == 1 && y == 2`.

This commit makes all jumps in such conditions local
and adds tests.

Closes #699, #700.
2020-02-28 17:44:46 +03:00
.circleci circleci: get submodules on checkout, fix failing tests 2019-12-04 20:36:51 +03:00
.docker Add possibility to import different dump of chains 2020-01-28 13:29:13 +03:00
.github add new neo logo with gopher 2019-10-22 19:48:22 +03:00
cli rpc/client: only return the Result from calls, handle Error internally 2020-02-21 15:23:11 +03:00
config core: implement basic policying support, fix #370 2020-02-19 12:19:02 +03:00
docs rpc: implement getblocksysfee RPC 2020-02-21 18:45:52 +03:00
examples examples: remove underscores from package names 2019-09-03 18:00:10 +03:00
integration rpc: move functions for Tx building in request package/ 2020-02-21 15:12:04 +03:00
pkg compiler: do not short-circuit in complex conditions 2020-02-28 17:44:46 +03:00
scripts cli: add script for comparing storage dumps 2020-02-12 12:16:31 +03:00
.dockerignore Fix build node and docker-image 2019-08-26 19:32:09 +03:00
.gitignore compiler: move it up from vm 2019-12-03 18:23:46 +03:00
.gitmodules vm: implement json tests from neoVM 2019-11-06 16:22:56 +03:00
.travis.yml update minimum supported version of Go to 1.12 2019-09-10 20:30:54 +03:00
CHANGELOG.md CHANGELOG: fix typo 2020-02-19 17:26:10 +03:00
CONTRIBUTING.md CONTRIBUTING: adapt to new reality a bit 2019-08-20 19:07:58 +03:00
Dockerfile Add single node chain dump to image 2020-01-28 13:04:13 +03:00
go.mod go.mod: update dbft with nspcc-dev/dbft#26 2020-02-19 14:46:51 +03:00
go.sum go.mod: update dbft with nspcc-dev/dbft#26 2020-02-19 14:46:51 +03:00
LICENSE.md LICENSE.md: rename from LICENCE.md 2019-08-20 18:47:08 +03:00
Makefile Update command to build and publish images 2020-01-28 13:03:18 +03:00
neo-go.service.template service file templating 2019-11-13 15:05:13 +03:00
README.md README: update contacts 2020-02-11 19:06:19 +03:00
ROADMAP.md update CHANGELOG and ROADMAP, release 0.72.0 2020-02-06 21:35:43 +03:00

logo

Go Node and SDK for the NEO blockchain.


codecov CircleCI Report GoDoc GitHub release (latest SemVer) License

Overview

This project aims to be a full port of the original C# NEO project. A complete toolkit for the NEO blockchain, including:

Getting started

Installation

Go: 1.12+

Install dependencies.

neo-go uses GoModules as dependency manager:

make deps

How to setup a node

Docker

Each tagged build is built to docker hub and the :latest tag pointing at the latest tagged build.

By default the CMD is set to run a node on testnet, so to do this simply run:

 docker run -d --name neo-go -p 20332:20332 -p 20333:20333 cityofzion/neo-go

Which will start a node on testnet and expose the nodes port 20333 and 20332 for the JSON-RPC server.

Building

Build the neo-go CLI:

make build

Quick start a NEO node on the private network. This requires the neo-privatenet Docker image running on your machine.

make run

To run the binary directly:

./bin/neo-go node

By default the node will run on the private network, to change his:

./bin/neo-go node --mainnet

Available network flags:

  • --mainnet, -m
  • --privnet, -p
  • --testnet, -t

#Developer notes Nodes have such features as Prometheus and Pprof in order to have additional information about them for debugging.

How to configure Prometheus or Pprof: In config/protocol.*.yml there is

  Prometheus:
    Enabled: true
    Port: 2112

where you can switch on/off and define port. Prometheus is enabled and Pprof is disabled by default.

Contributing

Feel free to contribute to this project after reading the contributing guidelines.

Before starting to work on a certain topic, create an new issue first, describing the feature/topic you are going to implement.

Contact

License

  • Open-source MIT