aboutsummaryrefslogtreecommitdiffstats
path: root/internal/ethapi/api.go
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2016-08-22 17:31:47 +0800
committerGitHub <noreply@github.com>2016-08-22 17:31:47 +0800
commitf81cff539a966bd0d5f86798fec16e8a279f380a (patch)
treef96bd925f4d55680d98e6236d3bdbd9ab2fadd9f /internal/ethapi/api.go
parent37bda7e029c160cdfa277fc4689fb58bc8d6a9df (diff)
parent781915f183c6e09474c6192d1aaba8e99c4990de (diff)
downloadgo-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar.gz
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar.bz2
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar.lz
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar.xz
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.tar.zst
go-tangerine-f81cff539a966bd0d5f86798fec16e8a279f380a.zip
Merge pull request #2923 from Arachnid/tracing
core: Refactor tracing to make Tracer the main interface
Diffstat (limited to 'internal/ethapi/api.go')
-rw-r--r--internal/ethapi/api.go54
1 files changed, 0 insertions, 54 deletions
diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go
index ca825ad89..135f9f8e8 100644
--- a/internal/ethapi/api.go
+++ b/internal/ethapi/api.go
@@ -584,60 +584,6 @@ func FormatLogs(structLogs []vm.StructLog) []StructLogRes {
return formattedStructLogs
}
-// TraceCall executes a call and returns the amount of gas, created logs and optionally returned values.
-func (s *PublicBlockChainAPI) TraceCall(ctx context.Context, args CallArgs, blockNr rpc.BlockNumber) (*ExecutionResult, error) {
- state, header, err := s.b.StateAndHeaderByNumber(blockNr)
- if state == nil || err != nil {
- return nil, err
- }
-
- var addr common.Address
- if args.From == (common.Address{}) {
- accounts := s.b.AccountManager().Accounts()
- if len(accounts) == 0 {
- addr = common.Address{}
- } else {
- addr = accounts[0].Address
- }
- } else {
- addr = args.From
- }
-
- // Assemble the CALL invocation
- msg := callmsg{
- addr: addr,
- to: args.To,
- gas: args.Gas.BigInt(),
- gasPrice: args.GasPrice.BigInt(),
- value: args.Value.BigInt(),
- data: common.FromHex(args.Data),
- }
-
- if msg.gas.Cmp(common.Big0) == 0 {
- msg.gas = big.NewInt(50000000)
- }
-
- if msg.gasPrice.Cmp(common.Big0) == 0 {
- msg.gasPrice = new(big.Int).Mul(big.NewInt(50), common.Shannon)
- }
-
- // Execute the call and return
- vmenv, vmError, err := s.b.GetVMEnv(ctx, msg, state, header)
- if err != nil {
- return nil, err
- }
- gp := new(core.GasPool).AddGas(common.MaxBig)
- ret, gas, err := core.ApplyMessage(vmenv, msg, gp)
- if err := vmError(); err != nil {
- return nil, err
- }
- return &ExecutionResult{
- Gas: gas,
- ReturnValue: fmt.Sprintf("%x", ret),
- StructLogs: FormatLogs(vmenv.StructLogs()),
- }, nil
-}
-
// rpcOutputBlock converts the given block to the RPC output which depends on fullTx. If inclTx is true transactions are
// returned. When fullTx is true the returned block contains full transaction details, otherwise it will only contain
// transaction hashes.