/*****************************************************************************

 JEP 2.4.1, Extensions 1.1.1
      April 30 2007
      (c) Copyright 2007, Nathan Funk and Richard Morris
      See LICENSE-*.txt for license information.

*****************************************************************************/
package org.nfunk.jep.function;

import java.util.*;
import org.nfunk.jep.*;
import org.nfunk.jep.type.*;

public class Subtract extends PostfixMathCommand
{
	public Subtract()
	{
		numberOfParameters = 2;
	}
	
	@Override
	public void run(Stack inStack)
		throws ParseException 
	{
		checkStack(inStack); // check the stack
		
		Object param2 = inStack.pop();
		Object param1 = inStack.pop();
		
		inStack.push(sub(param1, param2));

		return;
	}
	
	public Object sub(Object param1, Object param2)
		throws ParseException
	{
		if (param1 instanceof Complex)
		{
			if (param2 instanceof Complex)
			{
				return sub((Complex)param1, (Complex)param2);
			}
			else if( param2 instanceof Number)
			{
				return sub((Complex)param1, (Number)param2);
			}
		}
		else if (param1 instanceof Number)
		{
			if (param2 instanceof Complex)
			{
				return sub((Number)param1, (Complex)param2);
			}
			else if (param2 instanceof Number)
			{
				return sub((Number)param1, (Number)param2);
			}
		} 
		throw new ParseException("Invalid parameter type");
	}
	

	public Double sub(Number d1, Number d2)
	{
		return new Double(d1.doubleValue() - d2.doubleValue());
	}
	
	public Complex sub(Complex c1, Complex c2)
	{
		return new Complex(c1.re() - c2.re(), c1.im() - c2.im());
	}
	
	public Complex sub(Complex c, Number d)
	{
		return new Complex(c.re() - d.doubleValue(), c.im());
	}

	public Complex sub(Number d, Complex c)
	{
		return new Complex(d.doubleValue() - c.re(), -c.im());
	}
}
