]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.spreadsheet.graph/src/org/simantics/spreadsheet/graph/formula/SumFormulaFunction.java
SpreadsheetCells with Circular References support iterations.
[simantics/platform.git] / bundles / org.simantics.spreadsheet.graph / src / org / simantics / spreadsheet / graph / formula / SumFormulaFunction.java
1 package org.simantics.spreadsheet.graph.formula;\r
2 \r
3 import org.simantics.spreadsheet.graph.CellFormulaFunction;\r
4 import org.simantics.spreadsheet.graph.CellValueVisitor;\r
5 import org.simantics.spreadsheet.graph.SpreadsheetGraphUtils;\r
6 import org.simantics.spreadsheet.graph.SpreadsheetMatrix;\r
7 import org.simantics.spreadsheet.graph.parser.ast.AstArgList;\r
8 import org.simantics.spreadsheet.graph.parser.ast.AstValue;\r
9 \r
10 class SumFormulaFunction implements CellFormulaFunction<Object> {\r
11 \r
12     @Override\r
13     public Object evaluate(CellValueVisitor visitor, AstArgList args) {\r
14         Double sum = 0.0;\r
15         for (AstValue value : args.values) {\r
16             Object result = value.accept(visitor);\r
17             \r
18             if (result instanceof SpreadsheetMatrix) {\r
19                 Object value2 = ((SpreadsheetMatrix) result).sumWithFormulaError();\r
20                 if(value2 instanceof String) return value2; //means sumWithFormulaError returned an Error message.\r
21                 sum += ((Number)value2).doubleValue();\r
22             } else if(result instanceof String && !result.equals("")){\r
23                 FormulaError2 error = FormulaError2.forString(result.toString());\r
24                 if(error!=null) return error.getString();\r
25                 Double v = SpreadsheetGraphUtils.asDoubleWhereEmptyStringIsZero(result);\r
26                 if(v!=null)\r
27                         sum += v;\r
28             } else if(result instanceof Number){\r
29                 sum += ((Number)result).doubleValue();\r
30             } else {\r
31                 sum += SpreadsheetGraphUtils.asNumber(result);\r
32             }\r
33         }\r
34         return sum;\r
35     }\r
36 }