diff options
author | Maran <maran.hidskes@gmail.com> | 2014-05-22 16:26:39 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-05-22 16:26:39 +0800 |
commit | 8419ba0ec068779dd72dc67cce44a30f9ed2873f (patch) | |
tree | 6f7af48b7711aa9648e0a0b9d8b91918b3e07c41 /ethereum/repl_darwin.go | |
parent | 93d79babc9fb1e1c66e6c108f1925212d394db06 (diff) | |
parent | 01b833146f3afa214586a1ffb710546a5e4cc90a (diff) | |
download | go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar.gz go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar.bz2 go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar.lz go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar.xz go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.tar.zst go-tangerine-8419ba0ec068779dd72dc67cce44a30f9ed2873f.zip |
Fix merge conflicts
Diffstat (limited to 'ethereum/repl_darwin.go')
-rw-r--r-- | ethereum/repl_darwin.go | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/ethereum/repl_darwin.go b/ethereum/repl_darwin.go index 1b98c2150..fa36b0d52 100644 --- a/ethereum/repl_darwin.go +++ b/ethereum/repl_darwin.go @@ -1,17 +1,42 @@ package main +// #cgo darwin CFLAGS: -I/usr/local/opt/readline/include +// #cgo darwin LDFLAGS: -L/usr/local/opt/readline/lib // #cgo LDFLAGS: -lreadline // #include <stdio.h> // #include <stdlib.h> // #include <readline/readline.h> // #include <readline/history.h> import "C" - import ( + "os" + "os/signal" "strings" + "syscall" "unsafe" ) +func initReadLine() { + C.rl_catch_sigwinch = 0 + C.rl_catch_signals = 0 + c := make(chan os.Signal, 1) + signal.Notify(c, syscall.SIGWINCH) + signal.Notify(c, os.Interrupt) + go func() { + for sig := range c { + switch sig { + case syscall.SIGWINCH: + C.rl_resize_terminal() + + case os.Interrupt: + C.rl_cleanup_after_signal() + default: + + } + } + }() +} + func readLine(prompt *string) *string { var p *C.char @@ -59,6 +84,7 @@ func (self *JSRepl) setIndent() { } func (self *JSRepl) read() { + initReadLine() L: for { switch result := readLine(&self.prompt); true { |