2016-03-15 04:40:57 +00:00
|
|
|
package com.bytezone.diskbrowser.visicalc;
|
|
|
|
|
2017-02-18 09:54:24 +00:00
|
|
|
public class Npv extends Function
|
2016-03-15 04:40:57 +00:00
|
|
|
{
|
2016-07-31 23:52:47 +00:00
|
|
|
// private final String valueText;
|
|
|
|
// private final String rangeText;
|
|
|
|
//
|
|
|
|
// private final Expression valueExp;
|
2017-02-18 09:54:24 +00:00
|
|
|
private final Range range;
|
2016-03-15 04:40:57 +00:00
|
|
|
|
|
|
|
Npv (Sheet parent, String text)
|
|
|
|
{
|
|
|
|
super (parent, text);
|
2017-03-03 10:24:23 +00:00
|
|
|
range = new Range (parent, text);
|
2016-03-15 04:40:57 +00:00
|
|
|
|
2016-07-31 23:52:47 +00:00
|
|
|
// int pos = text.indexOf (',');
|
|
|
|
// valueText = text.substring (8, pos);
|
|
|
|
// rangeText = text.substring (pos + 1, text.length () - 1);
|
|
|
|
//
|
|
|
|
// valueExp = new Expression (parent, valueText);
|
2016-03-15 04:40:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2017-02-28 20:39:26 +00:00
|
|
|
public void calculate ()
|
2016-03-15 04:40:57 +00:00
|
|
|
{
|
2016-03-16 06:15:39 +00:00
|
|
|
value = 0;
|
2016-03-16 19:32:25 +00:00
|
|
|
valueType = ValueType.VALUE;
|
2016-03-15 04:40:57 +00:00
|
|
|
|
|
|
|
for (Address address : range)
|
|
|
|
{
|
|
|
|
Cell cell = parent.getCell (address);
|
2016-08-01 05:18:51 +00:00
|
|
|
if (cell == null || cell.isValueType (ValueType.NA))
|
2016-03-16 06:15:39 +00:00
|
|
|
continue;
|
|
|
|
|
2017-02-25 03:56:22 +00:00
|
|
|
if (!cell.isValueType (ValueType.VALUE))
|
2016-03-15 04:40:57 +00:00
|
|
|
{
|
2017-02-25 03:56:22 +00:00
|
|
|
valueType = cell.getValueType ();
|
2016-03-17 04:40:43 +00:00
|
|
|
break;
|
2016-03-15 04:40:57 +00:00
|
|
|
}
|
2016-03-16 06:15:39 +00:00
|
|
|
|
|
|
|
double temp = cell.getValue ();
|
2016-03-15 04:40:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|