mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-24 09:24:36 +00:00
parent
acb25fb880
commit
778d29f543
2 changed files with 32 additions and 20 deletions
|
@ -25,7 +25,7 @@ A complete toolkit for the NEO blockchain, including:
|
||||||
- [RPC node & client](https://github.com/nspcc-dev/neo-go/tree/master/pkg/rpc/README.md)
|
- [RPC node & client](https://github.com/nspcc-dev/neo-go/tree/master/pkg/rpc/README.md)
|
||||||
- [RPC client](https://github.com/nspcc-dev/neo-go/blob/master/pkg/rpc/README.md)
|
- [RPC client](https://github.com/nspcc-dev/neo-go/blob/master/pkg/rpc/README.md)
|
||||||
- [CLI tool](https://github.com/nspcc-dev/neo-go/blob/master/docs/cli.md)
|
- [CLI tool](https://github.com/nspcc-dev/neo-go/blob/master/docs/cli.md)
|
||||||
- [Smart contract compiler](https://github.com/nspcc-dev/neo-go/blob/master/pkg/vm/compiler/README.md)
|
- [Smart contract compiler](https://github.com/nspcc-dev/neo-go/blob/master/docs/compiler.md)
|
||||||
- [NEO virtual machine](https://github.com/nspcc-dev/neo-go/blob/master/pkg/vm/README.md)
|
- [NEO virtual machine](https://github.com/nspcc-dev/neo-go/blob/master/pkg/vm/README.md)
|
||||||
|
|
||||||
# Getting started
|
# Getting started
|
||||||
|
|
|
@ -23,32 +23,41 @@ The neo-go compiler compiles Go programs to bytecode that the NEO virtual machin
|
||||||
- append
|
- append
|
||||||
|
|
||||||
### VM API (interop layer)
|
### VM API (interop layer)
|
||||||
- storage
|
Compiler translates interop function calls into NEO VM syscalls or (for custom
|
||||||
- runtime
|
functions) into NEO VM instructions. [Refer to GoDoc](https://godoc.org/github.com/nspcc-dev/neo-go/pkg/interop) for full API documentation.
|
||||||
- block
|
|
||||||
- header
|
#### Standard NEO Smart Contract API
|
||||||
- transaction
|
- account
|
||||||
- asset
|
- asset
|
||||||
|
- attribute
|
||||||
|
- block
|
||||||
- blockchain
|
- blockchain
|
||||||
|
- contract
|
||||||
|
- engine
|
||||||
|
- header
|
||||||
|
- input
|
||||||
|
- iterator
|
||||||
|
- output
|
||||||
|
- runtime
|
||||||
|
- storage
|
||||||
|
- transaction
|
||||||
|
|
||||||
### VM utility helper functions
|
#### Custom VM utility helper functions
|
||||||
- SHA1
|
- crypto:
|
||||||
- SHA256
|
- `SHA1`
|
||||||
- Hash256
|
- `SHA256`
|
||||||
- Hash160
|
- `Hash256`
|
||||||
- other..
|
- `Hash160`
|
||||||
|
- enumerator
|
||||||
### Custom utility functions
|
- util:
|
||||||
- `FromAddress(address string) []byte`
|
- `Equals` (to emit `EQUALS` opcode, not needed usually)
|
||||||
|
- `FromAddress(address string) []byte`
|
||||||
## Not yet implemented
|
|
||||||
- very small part of the interop layer (VM API)
|
|
||||||
|
|
||||||
## Not supported
|
## Not supported
|
||||||
Due to the limitations of the NEO virtual machine, features listed below will not be supported.
|
Due to the limitations of the NEO virtual machine, features listed below will not be supported.
|
||||||
- channels
|
- channels
|
||||||
- goroutines
|
- goroutines
|
||||||
- multiple returns
|
- returning multiple values from functions
|
||||||
|
|
||||||
## Quick start
|
## Quick start
|
||||||
|
|
||||||
|
@ -125,8 +134,12 @@ Will output something like:
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
At the moment this is implemented via RPC call to the remote server.
|
||||||
|
|
||||||
## Smart contract examples
|
## Smart contract examples
|
||||||
|
|
||||||
|
Some examples are provided in the [examples directory](https://github.com/nspcc-dev/neo-go/tree/master/examples).
|
||||||
|
|
||||||
### Check if the invoker of the contract is the owning address
|
### Check if the invoker of the contract is the owning address
|
||||||
|
|
||||||
```Golang
|
```Golang
|
||||||
|
@ -214,4 +227,3 @@ func Main(operation string, args []interface{}) bool {
|
||||||
2. Create an issue on Github
|
2. Create an issue on Github
|
||||||
3. Make a PR with a reference to the created issue, containing the testcase that proves the bug
|
3. Make a PR with a reference to the created issue, containing the testcase that proves the bug
|
||||||
4. Either you fix the bug yourself or wait for patch that solves the problem
|
4. Either you fix the bug yourself or wait for patch that solves the problem
|
||||||
|
|
Loading…
Reference in a new issue