diff --git a/CHANGELOG.md b/CHANGELOG.md index 20d26f9e5a..3a72cc643f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -28,6 +28,7 @@ and this project adheres to [Semantic Versioning](https://semver.org). - Best effort to support invalid colspan values in HTML reader - [878](/~https://github.com/PHPOffice/PhpSpreadsheet/pull/878) - Fixes incorrect rows deletion [#868](/~https://github.com/PHPOffice/PhpSpreadsheet/issues/868) - MATCH function fix (value search by type, stop search when match_type=-1 and unordered element encountered) - [Issue #1116](/~https://github.com/PHPOffice/PhpSpreadsheet/issues/1116) +- Fix getCalculatedValue error with more than two INDIRECT ## [1.8.2] - 2019-07-08 diff --git a/src/PhpSpreadsheet/Calculation/Calculation.php b/src/PhpSpreadsheet/Calculation/Calculation.php index a131fca980..f2e6647fa2 100644 --- a/src/PhpSpreadsheet/Calculation/Calculation.php +++ b/src/PhpSpreadsheet/Calculation/Calculation.php @@ -4140,6 +4140,9 @@ private function processTokenStack($tokens, $cellID = null, Cell $pCell = null) // if the token is a function, pop arguments off the stack, hand them to the function, and push the result back on } elseif (preg_match('/^' . self::CALCULATION_REGEXP_FUNCTION . '$/i', $token, $matches)) { + if ($pCellParent) { + $pCell->attach($pCellParent); + } if (($cellID == 'AC99') || (isset($pCell) && $pCell->getCoordinate() == 'AC99')) { if (defined('RESOLVING')) { define('RESOLVING2', true); @@ -4215,6 +4218,7 @@ private function processTokenStack($tokens, $cellID = null, Cell $pCell = null) } unset($arg); } + $result = call_user_func_array($functionCall, $args); if ($functionName != 'MKMATRIX') { diff --git a/tests/PhpSpreadsheetTests/Calculation/CalculationTest.php b/tests/PhpSpreadsheetTests/Calculation/CalculationTest.php index 6bceee0f37..4cdfe5cbd8 100644 --- a/tests/PhpSpreadsheetTests/Calculation/CalculationTest.php +++ b/tests/PhpSpreadsheetTests/Calculation/CalculationTest.php @@ -164,6 +164,22 @@ public function testCellWithDdeExpresion() self::assertEquals("=cmd|'/C calc'!A0", $cell->getCalculatedValue()); } + public function testCellWithFormulaTwoIndirect() + { + $spreadsheet = new Spreadsheet(); + $workSheet = $spreadsheet->getActiveSheet(); + $cell1 = $workSheet->getCell('A1'); + $cell1->setValue('2'); + $cell2 = $workSheet->getCell('B1'); + $cell2->setValue('3'); + $cell2 = $workSheet->getCell('C1'); + $cell2->setValue('4'); + $cell3 = $workSheet->getCell('D1'); + $cell3->setValue('=SUM(INDIRECT("A"&ROW()),INDIRECT("B"&ROW()),INDIRECT("C"&ROW()))'); + + self::assertEquals('9', $cell3->getCalculatedValue()); + } + public function testBranchPruningFormulaParsingSimpleCase() { $calculation = Calculation::getInstance();