changed logger API, functions that allow Gui to implement ethlog.LogSystem for gui logging
This commit is contained in:
parent
7bcf875c57
commit
d060ae6a36
@ -8,6 +8,7 @@ import (
|
|||||||
"github.com/ethereum/eth-go/ethdb"
|
"github.com/ethereum/eth-go/ethdb"
|
||||||
"github.com/ethereum/eth-go/ethpub"
|
"github.com/ethereum/eth-go/ethpub"
|
||||||
"github.com/ethereum/eth-go/ethutil"
|
"github.com/ethereum/eth-go/ethutil"
|
||||||
|
"github.com/ethereum/eth-go/ethlog"
|
||||||
"github.com/ethereum/go-ethereum/utils"
|
"github.com/ethereum/go-ethereum/utils"
|
||||||
"github.com/go-qml/qml"
|
"github.com/go-qml/qml"
|
||||||
"math/big"
|
"math/big"
|
||||||
@ -15,6 +16,8 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var logger = ethlog.NewLogger("GUI")
|
||||||
|
|
||||||
type Gui struct {
|
type Gui struct {
|
||||||
// The main application window
|
// The main application window
|
||||||
win *qml.Window
|
win *qml.Window
|
||||||
@ -33,10 +36,11 @@ type Gui struct {
|
|||||||
addr []byte
|
addr []byte
|
||||||
|
|
||||||
pub *ethpub.PEthereum
|
pub *ethpub.PEthereum
|
||||||
|
logLevel ethlog.LogLevel
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create GUI, but doesn't start it
|
// Create GUI, but doesn't start it
|
||||||
func New(ethereum *eth.Ethereum) *Gui {
|
func New(ethereum *eth.Ethereum, logLevel ethlog.LogLevel) *Gui {
|
||||||
lib := &EthLib{stateManager: ethereum.StateManager(), blockChain: ethereum.BlockChain(), txPool: ethereum.TxPool()}
|
lib := &EthLib{stateManager: ethereum.StateManager(), blockChain: ethereum.BlockChain(), txPool: ethereum.TxPool()}
|
||||||
db, err := ethdb.NewLDBDatabase("tx_database")
|
db, err := ethdb.NewLDBDatabase("tx_database")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -52,7 +56,7 @@ func New(ethereum *eth.Ethereum) *Gui {
|
|||||||
|
|
||||||
pub := ethpub.NewPEthereum(ethereum)
|
pub := ethpub.NewPEthereum(ethereum)
|
||||||
|
|
||||||
return &Gui{eth: ethereum, lib: lib, txDb: db, addr: addr, pub: pub}
|
return &Gui{eth: ethereum, lib: lib, txDb: db, addr: addr, pub: pub, logLevel: logLevel}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (gui *Gui) Start(assetPath string) {
|
func (gui *Gui) Start(assetPath string) {
|
||||||
@ -90,16 +94,15 @@ func (gui *Gui) Start(assetPath string) {
|
|||||||
win, err = gui.showKeyImport(context)
|
win, err = gui.showKeyImport(context)
|
||||||
} else {
|
} else {
|
||||||
win, err = gui.showWallet(context)
|
win, err = gui.showWallet(context)
|
||||||
|
ethlog.AddLogSystem(gui)
|
||||||
ethutil.Config.Log.AddLogSystem(gui)
|
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ethutil.Config.Log.Infoln("FATAL: asset not found: you can set an alternative asset path on on the command line using option 'asset_path'", err)
|
logger.Errorln("asset not found: you can set an alternative asset path on the command line using option 'asset_path'", err)
|
||||||
|
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
ethutil.Config.Log.Infoln("[GUI] Starting GUI")
|
logger.Infoln("Starting GUI")
|
||||||
|
|
||||||
win.Show()
|
win.Show()
|
||||||
win.Wait()
|
win.Wait()
|
||||||
@ -315,22 +318,6 @@ func (gui *Gui) setPeerInfo() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Logging functions that log directly to the GUI interface
|
|
||||||
func (gui *Gui) Println(v ...interface{}) {
|
|
||||||
str := strings.TrimRight(fmt.Sprintln(v...), "\n")
|
|
||||||
lines := strings.Split(str, "\n")
|
|
||||||
for _, line := range lines {
|
|
||||||
gui.win.Root().Call("addLog", line)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) Printf(format string, v ...interface{}) {
|
|
||||||
str := strings.TrimRight(fmt.Sprintf(format, v...), "\n")
|
|
||||||
lines := strings.Split(str, "\n")
|
|
||||||
for _, line := range lines {
|
|
||||||
gui.win.Root().Call("addLog", line)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
func (gui *Gui) RegisterName(name string) {
|
func (gui *Gui) RegisterName(name string) {
|
||||||
keyPair := ethutil.GetKeyRing().Get(0)
|
keyPair := ethutil.GetKeyRing().Get(0)
|
||||||
name = fmt.Sprintf("\"%s\"\n1", name)
|
name = fmt.Sprintf("\"%s\"\n1", name)
|
||||||
@ -357,6 +344,28 @@ func (gui *Gui) ClientId() string {
|
|||||||
return ethutil.Config.Identifier
|
return ethutil.Config.Identifier
|
||||||
}
|
}
|
||||||
|
|
||||||
func (gui *Gui) SetLogLevel(level int) {
|
// functions that allow Gui to implement interface ethlog.LogSystem
|
||||||
ethutil.Config.Log.SetLevel(level)
|
func (gui *Gui) SetLogLevel(level ethlog.LogLevel) {
|
||||||
|
gui.logLevel = level
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) GetLogLevel() ethlog.LogLevel {
|
||||||
|
return gui.logLevel
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) Println(v ...interface{}) {
|
||||||
|
gui.printLog(fmt.Sprintln(v...))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) Printf(format string, v ...interface{}) {
|
||||||
|
gui.printLog(fmt.Sprintf(format, v...))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Print function that logs directly to the GUI
|
||||||
|
func (gui *Gui) printLog(s string) {
|
||||||
|
str := strings.TrimRight(s, "\n")
|
||||||
|
lines := strings.Split(str, "\n")
|
||||||
|
for _, line := range lines {
|
||||||
|
gui.win.Root().Call("addLog", line)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,11 +96,11 @@ func (app *HtmlApplication) NewWatcher(quitChan chan bool) {
|
|||||||
app.watcher.Close()
|
app.watcher.Close()
|
||||||
break out
|
break out
|
||||||
case <-app.watcher.Event:
|
case <-app.watcher.Event:
|
||||||
//ethutil.Config.Log.Debugln("Got event:", ev)
|
//logger.Debugln("Got event:", ev)
|
||||||
app.webView.Call("reload")
|
app.webView.Call("reload")
|
||||||
case err := <-app.watcher.Error:
|
case err := <-app.watcher.Error:
|
||||||
// TODO: Do something here
|
// TODO: Do something here
|
||||||
ethutil.Config.Log.Infoln("Watcher error:", err)
|
logger.Infoln("Watcher error:", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
@ -40,7 +40,7 @@ func NewUiLib(engine *qml.Engine, eth *eth.Ethereum, assetPath string) *UiLib {
|
|||||||
func (ui *UiLib) Open(path string) {
|
func (ui *UiLib) Open(path string) {
|
||||||
component, err := ui.engine.LoadFile(path[7:])
|
component, err := ui.engine.LoadFile(path[7:])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ethutil.Config.Log.Debugln(err)
|
logger.Debugln(err)
|
||||||
}
|
}
|
||||||
win := component.CreateWindow(nil)
|
win := component.CreateWindow(nil)
|
||||||
|
|
||||||
@ -60,7 +60,7 @@ func (ui *UiLib) OpenHtml(path string) {
|
|||||||
func (ui *UiLib) Muted(content string) {
|
func (ui *UiLib) Muted(content string) {
|
||||||
component, err := ui.engine.LoadFile(ui.AssetPath("qml/muted.qml"))
|
component, err := ui.engine.LoadFile(ui.AssetPath("qml/muted.qml"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ethutil.Config.Log.Debugln(err)
|
logger.Debugln(err)
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -144,7 +144,7 @@ func (ui *UiLib) DebugTx(recipient, valueStr, gasStr, gasPriceStr, data string)
|
|||||||
|
|
||||||
script, err := ethutil.Compile(data)
|
script, err := ethutil.Compile(data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ethutil.Config.Log.Debugln(err)
|
logger.Debugln(err)
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user