136 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright (c) 2013-2014, Jeffrey Wilcke. All rights reserved.
 | 
						|
//
 | 
						|
// This library is free software; you can redistribute it and/or
 | 
						|
// modify it under the terms of the GNU General Public
 | 
						|
// License as published by the Free Software Foundation; either
 | 
						|
// version 2.1 of the License, or (at your option) any later version.
 | 
						|
//
 | 
						|
// This library is distributed in the hope that it will be useful,
 | 
						|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
						|
// General Public License for more details.
 | 
						|
//
 | 
						|
// You should have received a copy of the GNU General Public License
 | 
						|
// along with this library; if not, write to the Free Software
 | 
						|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 | 
						|
// MA 02110-1301  USA
 | 
						|
 | 
						|
package main
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"os"
 | 
						|
	"runtime"
 | 
						|
 | 
						|
	"github.com/ethereum/go-ethereum/cmd/utils"
 | 
						|
	"github.com/ethereum/go-ethereum/core/types"
 | 
						|
	"github.com/ethereum/go-ethereum/ethutil"
 | 
						|
	"github.com/ethereum/go-ethereum/logger"
 | 
						|
)
 | 
						|
 | 
						|
const (
 | 
						|
	ClientIdentifier = "Ethereum(G)"
 | 
						|
	Version          = "0.7.9"
 | 
						|
)
 | 
						|
 | 
						|
var clilogger = logger.NewLogger("CLI")
 | 
						|
 | 
						|
func main() {
 | 
						|
	runtime.GOMAXPROCS(runtime.NumCPU())
 | 
						|
 | 
						|
	utils.HandleInterrupt()
 | 
						|
 | 
						|
	// precedence: code-internal flag default < config file < environment variables < command line
 | 
						|
	Init() // parsing command line
 | 
						|
 | 
						|
	// If the difftool option is selected ignore all other log output
 | 
						|
	if DiffTool || Dump {
 | 
						|
		LogLevel = 0
 | 
						|
	}
 | 
						|
 | 
						|
	utils.InitConfig(VmType, ConfigFile, Datadir, "ETH")
 | 
						|
	ethutil.Config.Diff = DiffTool
 | 
						|
	ethutil.Config.DiffType = DiffType
 | 
						|
 | 
						|
	utils.InitDataDir(Datadir)
 | 
						|
 | 
						|
	utils.InitLogging(Datadir, LogFile, LogLevel, DebugFile)
 | 
						|
 | 
						|
	db := utils.NewDatabase()
 | 
						|
	err := utils.DBSanityCheck(db)
 | 
						|
	if err != nil {
 | 
						|
		fmt.Println(err)
 | 
						|
 | 
						|
		os.Exit(1)
 | 
						|
	}
 | 
						|
 | 
						|
	keyManager := utils.NewKeyManager(KeyStore, Datadir, db)
 | 
						|
 | 
						|
	// create, import, export keys
 | 
						|
	utils.KeyTasks(keyManager, KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive)
 | 
						|
 | 
						|
	clientIdentity := utils.NewClientIdentity(ClientIdentifier, Version, Identifier)
 | 
						|
 | 
						|
	ethereum := utils.NewEthereum(db, clientIdentity, keyManager, UseUPnP, OutboundPort, MaxPeer)
 | 
						|
 | 
						|
	if Dump {
 | 
						|
		var block *types.Block
 | 
						|
 | 
						|
		if len(DumpHash) == 0 && DumpNumber == -1 {
 | 
						|
			block = ethereum.ChainManager().CurrentBlock
 | 
						|
		} else if len(DumpHash) > 0 {
 | 
						|
			block = ethereum.ChainManager().GetBlock(ethutil.Hex2Bytes(DumpHash))
 | 
						|
		} else {
 | 
						|
			block = ethereum.ChainManager().GetBlockByNumber(uint64(DumpNumber))
 | 
						|
		}
 | 
						|
 | 
						|
		if block == nil {
 | 
						|
			fmt.Fprintln(os.Stderr, "block not found")
 | 
						|
 | 
						|
			// We want to output valid JSON
 | 
						|
			fmt.Println("{}")
 | 
						|
 | 
						|
			os.Exit(1)
 | 
						|
		}
 | 
						|
 | 
						|
		// block.GetRoot() does not exist
 | 
						|
		//fmt.Printf("RLP: %x\nstate: %x\nhash: %x\n", ethutil.Rlp(block), block.GetRoot(), block.Hash())
 | 
						|
 | 
						|
		// Leave the Println. This needs clean output for piping
 | 
						|
		fmt.Printf("%s\n", block.State().Dump())
 | 
						|
 | 
						|
		fmt.Println(block)
 | 
						|
 | 
						|
		os.Exit(0)
 | 
						|
	}
 | 
						|
 | 
						|
	if ShowGenesis {
 | 
						|
		utils.ShowGenesis(ethereum)
 | 
						|
	}
 | 
						|
 | 
						|
	if StartMining {
 | 
						|
		utils.StartMining(ethereum)
 | 
						|
	}
 | 
						|
 | 
						|
	// better reworked as cases
 | 
						|
	if StartJsConsole {
 | 
						|
		InitJsConsole(ethereum)
 | 
						|
	} else if len(InputFile) > 0 {
 | 
						|
		ExecJsFile(ethereum, InputFile)
 | 
						|
	}
 | 
						|
 | 
						|
	if StartRpc {
 | 
						|
		utils.StartRpc(ethereum, RpcPort)
 | 
						|
	}
 | 
						|
 | 
						|
	if StartWebSockets {
 | 
						|
		utils.StartWebSockets(ethereum)
 | 
						|
	}
 | 
						|
 | 
						|
	utils.StartEthereum(ethereum, UseSeed)
 | 
						|
 | 
						|
	// this blocks the thread
 | 
						|
	ethereum.WaitForShutdown()
 | 
						|
	logger.Flush()
 | 
						|
}
 |