package vm

import "math/big"

type jumpSeg struct {
	pos uint64
	err error
	gas *big.Int
}

func (j jumpSeg) do(program *Program, pc *uint64, env Environment, contract *Contract, memory *Memory, stack *stack) ([]byte, error) {
	if !contract.UseGas(j.gas) {
		return nil, OutOfGasError
	}
	if j.err != nil {
		return nil, j.err
	}
	*pc = j.pos
	return nil, nil
}
func (s jumpSeg) halts() bool { return false }
func (s jumpSeg) Op() OpCode  { return 0 }

type pushSeg struct {
	data []*big.Int
	gas  *big.Int
}

func (s pushSeg) do(program *Program, pc *uint64, env Environment, contract *Contract, memory *Memory, stack *stack) ([]byte, error) {
	// Use the calculated gas. When insufficient gas is present, use all gas and return an
	// Out Of Gas error
	if !contract.UseGas(s.gas) {
		return nil, OutOfGasError
	}

	for _, d := range s.data {
		stack.push(new(big.Int).Set(d))
	}
	*pc += uint64(len(s.data))
	return nil, nil
}

func (s pushSeg) halts() bool { return false }
func (s pushSeg) Op() OpCode  { return 0 }