2016-03-06 08:05:32 +00:00
|
|
|
package com.bytezone.diskbrowser.visicalc;
|
|
|
|
|
2016-03-12 22:38:03 +00:00
|
|
|
class Max extends Function
|
2016-03-06 08:05:32 +00:00
|
|
|
{
|
2016-03-12 02:21:00 +00:00
|
|
|
private final Range range;
|
2016-03-06 08:05:32 +00:00
|
|
|
|
|
|
|
public Max (Sheet parent, String text)
|
|
|
|
{
|
2016-03-09 10:38:53 +00:00
|
|
|
super (parent, text);
|
2016-03-07 12:16:11 +00:00
|
|
|
range = getRange (text);
|
2016-03-06 08:05:32 +00:00
|
|
|
}
|
|
|
|
|
2016-03-12 02:21:00 +00:00
|
|
|
@Override
|
2016-03-17 04:40:43 +00:00
|
|
|
public Value calculate ()
|
2016-03-12 02:21:00 +00:00
|
|
|
{
|
2016-03-16 06:15:39 +00:00
|
|
|
value = Double.MIN_VALUE;
|
|
|
|
int totalChecked = 0;
|
2016-03-12 05:05:50 +00:00
|
|
|
|
2016-03-06 08:05:32 +00:00
|
|
|
for (Address address : range)
|
|
|
|
{
|
2016-03-12 02:21:00 +00:00
|
|
|
Cell cell = parent.getCell (address);
|
2016-03-17 04:40:43 +00:00
|
|
|
if (cell == null || cell.isNotAvailable ())
|
2016-03-16 06:15:39 +00:00
|
|
|
continue;
|
|
|
|
|
2016-03-17 04:40:43 +00:00
|
|
|
if (cell.isError ())
|
2016-03-12 02:21:00 +00:00
|
|
|
{
|
2016-03-16 19:32:25 +00:00
|
|
|
valueType = ValueType.ERROR;
|
2016-03-17 04:40:43 +00:00
|
|
|
break;
|
2016-03-12 02:21:00 +00:00
|
|
|
}
|
2016-03-16 06:15:39 +00:00
|
|
|
|
|
|
|
double temp = cell.getValue ();
|
|
|
|
if (temp > value)
|
|
|
|
value = temp;
|
|
|
|
totalChecked++;
|
2016-03-06 08:05:32 +00:00
|
|
|
}
|
2016-03-16 06:15:39 +00:00
|
|
|
|
|
|
|
if (totalChecked == 0)
|
2016-03-17 04:40:43 +00:00
|
|
|
valueType = ValueType.NA;
|
2016-03-16 19:32:25 +00:00
|
|
|
else
|
|
|
|
valueType = ValueType.VALUE;
|
2016-03-17 04:40:43 +00:00
|
|
|
|
|
|
|
return this;
|
2016-03-06 08:05:32 +00:00
|
|
|
}
|
|
|
|
}
|