Dde call safe handling (#891)
* Set handler for quoted text cells and DDE expressions in the Calculation engine
This commit is contained in:
		
							parent
							
								
									d2bbb6cd8e
								
							
						
					
					
						commit
						033ed16db5
					
				| @ -10,6 +10,8 @@ and this project adheres to [Semantic Versioning](https://semver.org). | |||||||
| ### Added | ### Added | ||||||
| 
 | 
 | ||||||
| - Added support for inline styles in Html reader (borders, alignment, width, height) | - Added support for inline styles in Html reader (borders, alignment, width, height) | ||||||
|  | - QuotedText cells no longer treated as formulae if the content begins with a `=` | ||||||
|  | - Clean handling for DDE in formulae | ||||||
| 
 | 
 | ||||||
| ## [1.6.0] - 2019-01-02 | ## [1.6.0] - 2019-01-02 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2703,7 +2703,7 @@ class Calculation | |||||||
|      * @param Cell $pCell Cell to calculate |      * @param Cell $pCell Cell to calculate | ||||||
|      * @param bool $resetLog Flag indicating whether the debug log should be reset or not |      * @param bool $resetLog Flag indicating whether the debug log should be reset or not | ||||||
|      * |      * | ||||||
|      * @throws Exception |      * @throws \PhpOffice\PhpSpreadsheet\Exception | ||||||
|      * |      * | ||||||
|      * @return mixed |      * @return mixed | ||||||
|      */ |      */ | ||||||
| @ -2807,7 +2807,7 @@ class Calculation | |||||||
|      * @param string $cellID Address of the cell to calculate |      * @param string $cellID Address of the cell to calculate | ||||||
|      * @param Cell $pCell Cell to calculate |      * @param Cell $pCell Cell to calculate | ||||||
|      * |      * | ||||||
|      * @throws Exception |      * @throws \PhpOffice\PhpSpreadsheet\Exception | ||||||
|      * |      * | ||||||
|      * @return mixed |      * @return mixed | ||||||
|      */ |      */ | ||||||
| @ -2891,6 +2891,15 @@ class Calculation | |||||||
|     { |     { | ||||||
|         $cellValue = null; |         $cellValue = null; | ||||||
| 
 | 
 | ||||||
|  |         //  Quote-Prefixed cell values cannot be formulae, but are treated as strings
 | ||||||
|  |         if ($pCell !== null && $pCell->getStyle()->getQuotePrefix() === true) { | ||||||
|  |             return self::wrapResult((string) $formula); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (preg_match('/^=\s*cmd\s*\|/miu', $formula) !== 0) { | ||||||
|  |             return self::wrapResult($formula); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         //    Basic validation that this is indeed a formula
 |         //    Basic validation that this is indeed a formula
 | ||||||
|         //    We simply return the cell value if not
 |         //    We simply return the cell value if not
 | ||||||
|         $formula = trim($formula); |         $formula = trim($formula); | ||||||
|  | |||||||
| @ -140,4 +140,27 @@ class CalculationTest extends TestCase | |||||||
|         $cell->setValue('=OFFSET(D3, -1, -2)'); |         $cell->setValue('=OFFSET(D3, -1, -2)'); | ||||||
|         self::assertEquals(5, $cell->getCalculatedValue(), 'missing arguments should be filled with null'); |         self::assertEquals(5, $cell->getCalculatedValue(), 'missing arguments should be filled with null'); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public function testCellSetAsQuotedText() | ||||||
|  |     { | ||||||
|  |         $spreadsheet = new Spreadsheet(); | ||||||
|  |         $workSheet = $spreadsheet->getActiveSheet(); | ||||||
|  |         $cell = $workSheet->getCell('A1'); | ||||||
|  | 
 | ||||||
|  |         $cell->setValue("=cmd|'/C calc'!A0"); | ||||||
|  |         $cell->getStyle()->setQuotePrefix(true); | ||||||
|  | 
 | ||||||
|  |         self::assertEquals("=cmd|'/C calc'!A0", $cell->getCalculatedValue()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function testCellWithDdeExpresion() | ||||||
|  |     { | ||||||
|  |         $spreadsheet = new Spreadsheet(); | ||||||
|  |         $workSheet = $spreadsheet->getActiveSheet(); | ||||||
|  |         $cell = $workSheet->getCell('A1'); | ||||||
|  | 
 | ||||||
|  |         $cell->setValue("=cmd|'/C calc'!A0"); | ||||||
|  | 
 | ||||||
|  |         self::assertEquals("=cmd|'/C calc'!A0", $cell->getCalculatedValue()); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Mark Baker
						Mark Baker