summaryrefslogtreecommitdiff
path: root/trunk/users/metalab/AoI/plugins/CSGEvaluator/src/org/cheffo/jeplite/ASTFunNode.java
blob: a14f642154f4fdf252de9c12341797d1b0836ac5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*****************************************************************************
JEP - Java Expression Parser
    JEP is a Java package for parsing and evaluating mathematical
	expressions. It currently supports user defined variables,
	constant, and functions. A number of common mathematical
	functions and constants are included.
  JEPLite is a simplified version of JEP.
JEP Author: Nathan Funk
JEPLite Author: Stephen "Cheffo" Kolaroff
JEP Copyright (C) 2001 Nathan Funk
JEPLite Copyright (C) 2002 Stefan  Kolarov
    JEPLite 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 of the License, or
    (at your option) any later version.

    JEPLite 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 JEPLite; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*****************************************************************************/
package org.cheffo.jeplite;

import org.cheffo.jeplite.function.*;
import org.cheffo.jeplite.util.*;
import java.util.*;

public class ASTFunNode extends SimpleNode {
  private PostfixMathCommand pfmc;

  public ASTFunNode(int id) {
    super(id);
  }

  public ASTFunNode(Parser p, int id) {
    super(p, id);
  }

  public Object jjtAccept(ParserVisitor visitor, Object data) {
    return visitor.visit(this, data);
  }

  public void setFunction(String name_in, PostfixMathCommand pfmc_in)
  {
  	name = name_in;
    pfmc = pfmc_in;
  }

  public String toString()
  {
    if (name!=null)
    {
    	try {
      		return "Function \"" + name + "\" = " + getValue();
      	} catch (Exception e) {
      		return "Function \"" + name + "\"";
      	}
    }
    else
    {
      return "Function: no function class set";
    }
  }

	public double getValue() throws ParseException
	{
		double value = 0;
		DoubleStack tempStack = new DoubleStack();
    getValue(tempStack);
		return tempStack.pop();
	}

	public final void getValue(DoubleStack tempStack) throws ParseException {
	  double value = 0;
	  for (int i=0; i < jjtGetNumChildren(); i++)
	  {
		  children[i].getValue(tempStack);
	  }
	  if (pfmc!=null)
	  {
		  try {
			  pfmc.run(tempStack);
		  } catch (ParseException e)
		  {
			  String errorStr = "Error in \"" + name + "\" function: ";
			  errorStr += e.getErrorInfo();
			  throw new ParseException(errorStr);
		  }
	  }
	}
}