diff options
author | obscuren <geffobscura@gmail.com> | 2014-06-27 01:54:09 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-06-27 01:54:09 +0800 |
commit | 3777ead25e1acedc0571a48a485976eb5c36fb30 (patch) | |
tree | 38419590b42a20a51773e178acbbb3178ee89bf2 /ethereum/repl.go | |
parent | cba47963113d8041281278d75ee0dad046798e82 (diff) | |
parent | a68bfd215f7b1859c1b14b0df59f3260b35df828 (diff) | |
download | go-tangerine-0.5.15.tar go-tangerine-0.5.15.tar.gz go-tangerine-0.5.15.tar.bz2 go-tangerine-0.5.15.tar.lz go-tangerine-0.5.15.tar.xz go-tangerine-0.5.15.tar.zst go-tangerine-0.5.15.zip |
Merge branch 'release/0.5.15'0.5.15
Diffstat (limited to 'ethereum/repl.go')
-rw-r--r-- | ethereum/repl.go | 41 |
1 files changed, 38 insertions, 3 deletions
diff --git a/ethereum/repl.go b/ethereum/repl.go index 0208459ad..34380a06f 100644 --- a/ethereum/repl.go +++ b/ethereum/repl.go @@ -1,10 +1,15 @@ package main import ( + "bufio" "fmt" "github.com/ethereum/eth-go" "github.com/ethereum/eth-go/ethpub" + "github.com/ethereum/eth-go/ethutil" "github.com/obscuren/otto" + "io" + "os" + "path" ) type Repl interface { @@ -16,18 +21,48 @@ type JSRepl struct { re *JSRE prompt string + + history *os.File + + running bool } func NewJSRepl(ethereum *eth.Ethereum) *JSRepl { - return &JSRepl{re: NewJSRE(ethereum), prompt: "> "} + hist, err := os.OpenFile(path.Join(ethutil.Config.ExecPath, "history"), os.O_RDWR|os.O_CREATE, os.ModePerm) + if err != nil { + panic(err) + } + + return &JSRepl{re: NewJSRE(ethereum), prompt: "> ", history: hist} } func (self *JSRepl) Start() { - self.read() + if !self.running { + self.running = true + logger.Infoln("init JS Console") + reader := bufio.NewReader(self.history) + for { + line, err := reader.ReadString('\n') + if err != nil && err == io.EOF { + break + } else if err != nil { + fmt.Println("error reading history", err) + break + } + + addHistory(line[:len(line)-1]) + } + self.read() + } } func (self *JSRepl) Stop() { - self.re.Stop() + if self.running { + self.running = false + self.re.Stop() + logger.Infoln("exit JS Console") + self.history.Close() + } } func (self *JSRepl) parseInput(code string) { |