Fix to allow calculate formula against a workbook, without passing in a cell
This commit is contained in:
		
							parent
							
								
									0a949eb2d2
								
							
						
					
					
						commit
						450e1672f0
					
				| @ -2547,7 +2547,7 @@ class Calculation | ||||
|             return '"'.$value.'"'; | ||||
|         //    Convert numeric errors to NaN error
 | ||||
|         } elseif ((is_float($value)) && ((is_nan($value)) || (is_infinite($value)))) { | ||||
|             return Calculation\Categories::NaN(); | ||||
|             return Calculation\Functions::NaN(); | ||||
|         } | ||||
| 
 | ||||
|         return $value; | ||||
| @ -2568,7 +2568,7 @@ class Calculation | ||||
|             } | ||||
|         //    Convert numeric errors to NaN error
 | ||||
|         } elseif ((is_float($value)) && ((is_nan($value)) || (is_infinite($value)))) { | ||||
|             return Calculation\Categories::NaN(); | ||||
|             return Calculation\Functions::NaN(); | ||||
|         } | ||||
|         return $value; | ||||
|     } | ||||
| @ -2638,9 +2638,9 @@ class Calculation | ||||
| 
 | ||||
|         if ((is_array($result)) && (self::$returnArrayAsType != self::RETURN_ARRAY_AS_ARRAY)) { | ||||
|             self::$returnArrayAsType = $returnArrayAsType; | ||||
|             $testResult = Calculation\Categories::flattenArray($result); | ||||
|             $testResult = Calculation\Functions::flattenArray($result); | ||||
|             if (self::$returnArrayAsType == self::RETURN_ARRAY_AS_ERROR) { | ||||
|                 return Calculation\Categories::VALUE(); | ||||
|                 return Calculation\Functions::VALUE(); | ||||
|             } | ||||
|             //    If there's only a single cell in the array, then we allow it
 | ||||
|             if (count($testResult) != 1) { | ||||
| @ -2648,13 +2648,13 @@ class Calculation | ||||
|                 $r = array_keys($result); | ||||
|                 $r = array_shift($r); | ||||
|                 if (!is_numeric($r)) { | ||||
|                     return Calculation\Categories::VALUE(); | ||||
|                     return Calculation\Functions::VALUE(); | ||||
|                 } | ||||
|                 if (is_array($result[$r])) { | ||||
|                     $c = array_keys($result[$r]); | ||||
|                     $c = array_shift($c); | ||||
|                     if (!is_numeric($c)) { | ||||
|                         return Calculation\Categories::VALUE(); | ||||
|                         return Calculation\Functions::VALUE(); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
| @ -2666,7 +2666,7 @@ class Calculation | ||||
|         if ($result === null) { | ||||
|             return 0; | ||||
|         } elseif ((is_float($result)) && ((is_nan($result)) || (is_infinite($result)))) { | ||||
|             return Calculation\Categories::NaN(); | ||||
|             return Calculation\Functions::NaN(); | ||||
|         } | ||||
|         return $result; | ||||
|     } | ||||
| @ -2713,10 +2713,16 @@ class Calculation | ||||
|         $this->_debugLog->clearLog(); | ||||
|         $this->cyclicReferenceStack->clear(); | ||||
| 
 | ||||
|         if ($this->spreadsheet !== null && $cellID === null && $pCell === null) { | ||||
|             $cellID = 'A1'; | ||||
|             $pCell = $this->spreadsheet->getActiveSheet()->getCell($cellID); | ||||
|         } else { | ||||
|             //    Disable calculation cacheing because it only applies to cell calculations, not straight formulae
 | ||||
|             //    But don't actually flush any cache
 | ||||
|             $resetCache = $this->getCalculationCacheEnabled(); | ||||
|             $this->calculationCacheEnabled = false; | ||||
|         } | ||||
| 
 | ||||
|         //    Execute the calculation
 | ||||
|         try { | ||||
|             $result = self::unwrapResult($this->_calculateFormulaValue($formula, $cellID, $pCell)); | ||||
| @ -2724,8 +2730,10 @@ class Calculation | ||||
|             throw new Calculation\Exception($e->getMessage()); | ||||
|         } | ||||
| 
 | ||||
|         if ($this->spreadsheet === null) { | ||||
|             //    Reset calculation cacheing to its previous state
 | ||||
|             $this->calculationCacheEnabled = $resetCache; | ||||
|         } | ||||
| 
 | ||||
|         return $result; | ||||
|     } | ||||
| @ -2984,7 +2992,7 @@ class Calculation | ||||
|     private function showValue($value) | ||||
|     { | ||||
|         if ($this->_debugLog->getWriteDebugLog()) { | ||||
|             $testArray = Calculation\Categories::flattenArray($value); | ||||
|             $testArray = Calculation\Functions::flattenArray($value); | ||||
|             if (count($testArray) == 1) { | ||||
|                 $value = array_pop($testArray); | ||||
|             } | ||||
| @ -3007,7 +3015,7 @@ class Calculation | ||||
|                 return ($value) ? self::$localeBoolean['TRUE'] : self::$localeBoolean['FALSE']; | ||||
|             } | ||||
|         } | ||||
|         return Calculation\Categories::flattenSingleValue($value); | ||||
|         return Calculation\Functions::flattenSingleValue($value); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| @ -3020,7 +3028,7 @@ class Calculation | ||||
|     private function showTypeDetails($value) | ||||
|     { | ||||
|         if ($this->_debugLog->getWriteDebugLog()) { | ||||
|             $testArray = Calculation\Categories::flattenArray($value); | ||||
|             $testArray = Calculation\Functions::flattenArray($value); | ||||
|             if (count($testArray) == 1) { | ||||
|                 $value = array_pop($testArray); | ||||
|             } | ||||
| @ -3610,7 +3618,7 @@ class Calculation | ||||
|                             } | ||||
|                             $stack->push('Cell Reference', $cellValue, $cellRef); | ||||
|                         } else { | ||||
|                             $stack->push('Error', Calculation\Categories::REF(), null); | ||||
|                             $stack->push('Error', Calculation\Functions::REF(), null); | ||||
|                         } | ||||
|                         break; | ||||
|                     case '+':            //    Addition
 | ||||
| @ -3712,7 +3720,7 @@ class Calculation | ||||
| //                    echo 'Reference is a Range of cells<br />';
 | ||||
|                     if ($pCell === null) { | ||||
| //                        We can't access the range, so return a REF error
 | ||||
|                         $cellValue = Calculation\Categories::REF(); | ||||
|                         $cellValue = Calculation\Functions::REF(); | ||||
|                     } else { | ||||
|                         $cellRef = $matches[6].$matches[7].':'.$matches[9].$matches[10]; | ||||
|                         if ($matches[2] > '') { | ||||
| @ -3746,7 +3754,7 @@ class Calculation | ||||
| //                    echo 'Reference is a single Cell<br />';
 | ||||
|                     if ($pCell === null) { | ||||
| //                        We can't access the cell, so return a REF error
 | ||||
|                         $cellValue = Calculation\Categories::REF(); | ||||
|                         $cellValue = Calculation\Functions::REF(); | ||||
|                     } else { | ||||
|                         $cellRef = $matches[6].$matches[7]; | ||||
|                         if ($matches[2] > '') { | ||||
| @ -3843,7 +3851,7 @@ class Calculation | ||||
|                     if ($functionName != 'MKMATRIX') { | ||||
|                         if ($this->_debugLog->getWriteDebugLog()) { | ||||
|                             krsort($argArrayVals); | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating ', self::localeFunc($functionName), '( ', implode(self::$localeArgumentSeparator.' ', Calculation\Categories::flattenArray($argArrayVals)), ' )'); | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating ', self::localeFunc($functionName), '( ', implode(self::$localeArgumentSeparator.' ', Calculation\Functions::flattenArray($argArrayVals)), ' )'); | ||||
|                         } | ||||
|                     } | ||||
|                     //    Process each argument in turn, building the return value as an array
 | ||||
| @ -3877,7 +3885,7 @@ class Calculation | ||||
|                         $result = call_user_func_array(explode('::', $functionCall), $args); | ||||
|                     } else { | ||||
|                         foreach ($args as &$arg) { | ||||
|                             $arg = Calculation\Categories::flattenSingleValue($arg); | ||||
|                             $arg = Calculation\Functions::flattenSingleValue($arg); | ||||
|                         } | ||||
|                         unset($arg); | ||||
|                         $result = call_user_func_array($functionCall, $args); | ||||
| @ -3921,7 +3929,7 @@ class Calculation | ||||
|         $output = $output['value']; | ||||
| 
 | ||||
| //        if ((is_array($output)) && (self::$returnArrayAsType != self::RETURN_ARRAY_AS_ARRAY)) {
 | ||||
| //            return array_shift(Calculation\Categories::flattenArray($output));
 | ||||
| //            return array_shift(Calculation\Functions::flattenArray($output));
 | ||||
| //        }
 | ||||
|         return $output; | ||||
|     } | ||||
| @ -4010,7 +4018,7 @@ class Calculation | ||||
|         } | ||||
| 
 | ||||
|         // Use case insensitive comparaison if not OpenOffice mode
 | ||||
|         if (Calculation\Categories::getCompatibilityMode() != Calculation\Categories::COMPATIBILITY_OPENOFFICE) { | ||||
|         if (Calculation\Functions::getCompatibilityMode() != Calculation\Functions::COMPATIBILITY_OPENOFFICE) { | ||||
|             if (is_string($operand1)) { | ||||
|                 $operand1 = strtoupper($operand1); | ||||
|             } | ||||
| @ -4019,7 +4027,7 @@ class Calculation | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         $useLowercaseFirstComparison = is_string($operand1) && is_string($operand2) && Calculation\Categories::getCompatibilityMode() == Calculation\Categories::COMPATIBILITY_OPENOFFICE; | ||||
|         $useLowercaseFirstComparison = is_string($operand1) && is_string($operand2) && Calculation\Functions::getCompatibilityMode() == Calculation\Functions::COMPATIBILITY_OPENOFFICE; | ||||
| 
 | ||||
|         //    execute the necessary operation
 | ||||
|         switch ($operation) { | ||||
| @ -4126,10 +4134,10 @@ class Calculation | ||||
|                 $result = '#VALUE!'; | ||||
|             } | ||||
|         } else { | ||||
|             if ((Calculation\Categories::getCompatibilityMode() != Calculation\Categories::COMPATIBILITY_OPENOFFICE) && | ||||
|             if ((Calculation\Functions::getCompatibilityMode() != Calculation\Functions::COMPATIBILITY_OPENOFFICE) && | ||||
|                 ((is_string($operand1) && !is_numeric($operand1) && strlen($operand1)>0) || | ||||
|                  (is_string($operand2) && !is_numeric($operand2) && strlen($operand2)>0))) { | ||||
|                 $result = Calculation\Categories::VALUE(); | ||||
|                 $result = Calculation\Functions::VALUE(); | ||||
|             } else { | ||||
|                 //    If we're dealing with non-matrix operations, execute the necessary operation
 | ||||
|                 switch ($operation) { | ||||
| @ -4292,7 +4300,7 @@ class Calculation | ||||
| //                    }
 | ||||
| //                }
 | ||||
|             } else { | ||||
|                 return Calculation\Categories::REF(); | ||||
|                 return Calculation\Functions::REF(); | ||||
|             } | ||||
| 
 | ||||
|             // Extract range
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 MarkBaker
						MarkBaker