mirror of https://github.com/ethereum/go-ethereum
parent
e64f727529
commit
b67ded9f27
@ -0,0 +1,69 @@ |
||||
package natspec |
||||
|
||||
import ( |
||||
// "encoding/json"
|
||||
// "fmt"
|
||||
"github.com/ethereum/go-ethereum/eth" |
||||
"github.com/ethereum/go-ethereum/javascript" |
||||
"io/ioutil" |
||||
) |
||||
|
||||
type NatSpec struct { |
||||
jsre *javascript.JSRE |
||||
} |
||||
|
||||
func NewNATSpec(ethereum *eth.Ethereum, transaction string) (self *NatSpec, err error) { |
||||
|
||||
self = new(NatSpec) |
||||
self.jsre = javascript.NewJSRE(ethereum) |
||||
//self.jsre.LoadExtFile("/home/fefe/go-ethereum/ethutil/natspec/natspec.js")
|
||||
code, err := ioutil.ReadFile("natspec.js") |
||||
if err != nil { |
||||
return |
||||
} |
||||
|
||||
_, err = self.jsre.Run(string(code)) |
||||
if err != nil { |
||||
return |
||||
} |
||||
_, err = self.jsre.Run("var natspec = require('natspec');") |
||||
if err != nil { |
||||
return |
||||
} |
||||
|
||||
self.jsre.Run("var transaction = " + transaction + ";") |
||||
|
||||
return |
||||
} |
||||
|
||||
func (self *NatSpec) SetDescription(desc string) (err error) { |
||||
|
||||
_, err = self.jsre.Run("var expression = \"" + desc + "\";") |
||||
return |
||||
|
||||
} |
||||
|
||||
func (self *NatSpec) SetABI(abi string) (err error) { |
||||
|
||||
_, err = self.jsre.Run("var abi = " + abi + ";") |
||||
return |
||||
|
||||
} |
||||
|
||||
func (self *NatSpec) SetMethod(method string) (err error) { |
||||
|
||||
_, err = self.jsre.Run("var method = '" + method + "';") |
||||
return |
||||
|
||||
} |
||||
|
||||
func (self *NatSpec) Parse() string { |
||||
|
||||
self.jsre.Run("var call = {method: method,abi: abi,transaction: transaction};") |
||||
value, err := self.jsre.Run("natspec.evaluateExpression(expression, call);") |
||||
if err != nil { |
||||
return err.Error() |
||||
} |
||||
return value.String() |
||||
|
||||
} |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,163 @@ |
||||
package natspec |
||||
|
||||
import ( |
||||
"flag" |
||||
// "crypto/rand"
|
||||
// "io/ioutil"
|
||||
"github.com/ethereum/go-ethereum/cmd/utils" |
||||
"github.com/ethereum/go-ethereum/eth" |
||||
"testing" |
||||
) |
||||
|
||||
const ( |
||||
ClientIdentifier = "Ethereum(G)" |
||||
Version = "0.8.1" |
||||
) |
||||
|
||||
var ( |
||||
Identifier string |
||||
KeyRing string |
||||
DiffTool bool |
||||
DiffType string |
||||
KeyStore string |
||||
StartRpc bool |
||||
StartWebSockets bool |
||||
RpcPort int |
||||
NatType string |
||||
PMPGateway string |
||||
OutboundPort string |
||||
ShowGenesis bool |
||||
AddPeer string |
||||
MaxPeer int |
||||
GenAddr bool |
||||
UseSeed bool |
||||
SecretFile string |
||||
ExportDir string |
||||
NonInteractive bool |
||||
Datadir string |
||||
LogFile string |
||||
ConfigFile string |
||||
DebugFile string |
||||
LogLevel int |
||||
Dump bool |
||||
DumpHash string |
||||
DumpNumber int |
||||
VmType int |
||||
ImportChain string |
||||
SHH bool |
||||
Dial bool |
||||
PrintVersion bool |
||||
) |
||||
|
||||
func Init() { |
||||
/* flag.Usage = func() { |
||||
fmt.Fprintf(os.Stderr, "%s [options] [filename]:\noptions precedence: default < config file < environment variables < command line\n", os.Args[0]) |
||||
flag.PrintDefaults() |
||||
}*/ |
||||
|
||||
flag.IntVar(&VmType, "vm", 0, "Virtual Machine type: 0-1: standard, debug") |
||||
flag.StringVar(&Identifier, "id", "", "Custom client identifier") |
||||
flag.StringVar(&KeyRing, "keyring", "", "identifier for keyring to use") |
||||
flag.StringVar(&KeyStore, "keystore", "db", "system to store keyrings: db|file (db)") |
||||
flag.StringVar(&OutboundPort, "port", "30303", "listening port") |
||||
flag.StringVar(&NatType, "nat", "", "NAT support (UPNP|PMP) (none)") |
||||
flag.StringVar(&PMPGateway, "pmp", "", "Gateway IP for PMP") |
||||
flag.IntVar(&MaxPeer, "maxpeer", 30, "maximum desired peers") |
||||
flag.IntVar(&RpcPort, "rpcport", 8080, "port to start json-rpc server on") |
||||
flag.BoolVar(&StartRpc, "rpc", false, "start rpc server") |
||||
flag.BoolVar(&StartWebSockets, "ws", false, "start websocket server") |
||||
flag.BoolVar(&NonInteractive, "y", false, "non-interactive mode (say yes to confirmations)") |
||||
flag.BoolVar(&UseSeed, "seed", true, "seed peers") |
||||
flag.BoolVar(&SHH, "shh", true, "whisper protocol (on)") |
||||
flag.BoolVar(&Dial, "dial", true, "dial out connections (on)") |
||||
flag.BoolVar(&GenAddr, "genaddr", false, "create a new priv/pub key") |
||||
flag.StringVar(&SecretFile, "import", "", "imports the file given (hex or mnemonic formats)") |
||||
flag.StringVar(&ExportDir, "export", "", "exports the session keyring to files in the directory given") |
||||
flag.StringVar(&LogFile, "logfile", "", "log file (defaults to standard output)") |
||||
flag.StringVar(&Datadir, "datadir", "", "specifies the datadir to use") |
||||
flag.StringVar(&ConfigFile, "conf", "", "config file") |
||||
flag.StringVar(&DebugFile, "debug", "", "debug file (no debugging if not set)") |
||||
flag.IntVar(&LogLevel, "loglevel", 0, "loglevel: 0-5: silent,error,warn,info,debug,debug detail)") |
||||
flag.BoolVar(&DiffTool, "difftool", false, "creates output for diff'ing. Sets LogLevel=0") |
||||
flag.StringVar(&DiffType, "diff", "all", "sets the level of diff output [vm, all]. Has no effect if difftool=false") |
||||
flag.BoolVar(&ShowGenesis, "genesis", false, "Dump the genesis block") |
||||
flag.StringVar(&ImportChain, "chain", "", "Imports given chain") |
||||
|
||||
flag.BoolVar(&Dump, "dump", false, "output the ethereum state in JSON format. Sub args [number, hash]") |
||||
flag.StringVar(&DumpHash, "hash", "", "specify arg in hex") |
||||
flag.IntVar(&DumpNumber, "number", -1, "specify arg in number") |
||||
|
||||
/* flag.BoolVar(&StartMining, "mine", false, "start dagger mining") |
||||
flag.BoolVar(&StartJsConsole, "js", false, "launches javascript console") |
||||
flag.BoolVar(&PrintVersion, "version", false, "prints version number")*/ |
||||
|
||||
flag.Parse() |
||||
|
||||
} |
||||
|
||||
func TestNotice(t *testing.T) { |
||||
|
||||
Init() |
||||
|
||||
utils.InitConfig(VmType, ConfigFile, Datadir, "ETH") |
||||
|
||||
ethereum, _ := eth.New(ð.Config{ |
||||
Name: ClientIdentifier, |
||||
Version: Version, |
||||
KeyStore: KeyStore, |
||||
DataDir: Datadir, |
||||
LogFile: LogFile, |
||||
LogLevel: LogLevel, |
||||
Identifier: Identifier, |
||||
MaxPeers: MaxPeer, |
||||
Port: OutboundPort, |
||||
NATType: PMPGateway, |
||||
PMPGateway: PMPGateway, |
||||
KeyRing: KeyRing, |
||||
Shh: SHH, |
||||
Dial: Dial, |
||||
}) |
||||
|
||||
ns, err := NewNATSpec(ethereum, ` |
||||
{ |
||||
"jsonrpc": "2.0", |
||||
"method": "eth_call", |
||||
"params": [{ |
||||
"to": "0x8521742d3f456bd237e312d6e30724960f72517a", |
||||
"data": "0xc6888fa1000000000000000000000000000000000000000000000000000000000000007a" |
||||
}], |
||||
"id": 6 |
||||
} |
||||
`) |
||||
|
||||
if err != nil { |
||||
t.Errorf("NewNATSpec error %v", err) |
||||
} |
||||
|
||||
ns.SetABI(` |
||||
[{ |
||||
"name": "multiply", |
||||
"constant": false, |
||||
"type": "function", |
||||
"inputs": [{ |
||||
"name": "a", |
||||
"type": "uint256" |
||||
}], |
||||
"outputs": [{ |
||||
"name": "d", |
||||
"type": "uint256" |
||||
}] |
||||
}] |
||||
`) |
||||
ns.SetDescription("Will multiply `a` by 7 and return `a * 7`.") |
||||
ns.SetMethod("multiply") |
||||
|
||||
notice := ns.Parse() |
||||
|
||||
expected := "Will multiply 122 by 7 and return 854." |
||||
if notice != expected { |
||||
t.Errorf("incorrect notice. expected %v, got %v", expected, notice) |
||||
} else { |
||||
t.Logf("returned notice \"%v\"", notice) |
||||
} |
||||
} |
Loading…
Reference in new issue