aboutsummaryrefslogtreecommitdiffstats
path: root/ethereum/repl.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-06-27 01:52:23 +0800
committerobscuren <geffobscura@gmail.com>2014-06-27 01:52:23 +0800
commit91bdf9e8012cb396f5fa08765190d76e758fb6a0 (patch)
tree2f2ee4a263377ecff2c9b2958f7d007a534280d0 /ethereum/repl.go
parent8100903d922dbced4f03db18ff766f28bdd2f706 (diff)
parentae5ace16190d48bfe7a0364fdb0b51644518ec42 (diff)
downloaddexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar.gz
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar.bz2
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar.lz
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar.xz
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.tar.zst
dexon-91bdf9e8012cb396f5fa08765190d76e758fb6a0.zip
Merge branch 'ethersphere-feature/logging' into develop
Diffstat (limited to 'ethereum/repl.go')
-rw-r--r--ethereum/repl.go36
1 files changed, 23 insertions, 13 deletions
diff --git a/ethereum/repl.go b/ethereum/repl.go
index dd8d08179..34380a06f 100644
--- a/ethereum/repl.go
+++ b/ethereum/repl.go
@@ -23,6 +23,8 @@ type JSRepl struct {
prompt string
history *os.File
+
+ running bool
}
func NewJSRepl(ethereum *eth.Ethereum) *JSRepl {
@@ -35,24 +37,32 @@ func NewJSRepl(ethereum *eth.Ethereum) *JSRepl {
}
func (self *JSRepl) Start() {
- 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
+ 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])
}
-
- addHistory(line[:len(line)-1])
+ self.read()
}
- self.read()
}
func (self *JSRepl) Stop() {
- self.re.Stop()
- self.history.Close()
+ if self.running {
+ self.running = false
+ self.re.Stop()
+ logger.Infoln("exit JS Console")
+ self.history.Close()
+ }
}
func (self *JSRepl) parseInput(code string) {