Delete debug and commented out code
This commit is contained in:
		
							parent
							
								
									f917b3b1f4
								
							
						
					
					
						commit
						91417ad1c3
					
				| @ -18,8 +18,6 @@ if (!defined('CALCULATION_REGEXP_CELLREF')) { | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Calculation (Multiton) | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -3099,34 +3097,25 @@ class Calculation | ||||
|         //    The guts of the lexical parser
 | ||||
|         //    Loop through the formula extracting each operator and operand in turn
 | ||||
|         while (true) { | ||||
|             //echo 'Assessing Expression '.substr($formula, $index), PHP_EOL;
 | ||||
|             $opCharacter = $formula{$index};    //    Get the first character of the value at the current index position
 | ||||
| //echo 'Initial character of expression block is '.$opCharacter, PHP_EOL;
 | ||||
|             if ((isset(self::$comparisonOperators[$opCharacter])) && (strlen($formula) > $index) && (isset(self::$comparisonOperators[$formula{$index + 1}]))) { | ||||
|                 $opCharacter .= $formula{++$index}; | ||||
| //echo 'Initial character of expression block is comparison operator '.$opCharacter.PHP_EOL;
 | ||||
|             } | ||||
| 
 | ||||
|             //    Find out if we're currently at the beginning of a number, variable, cell reference, function, parenthesis or operand
 | ||||
|             $isOperandOrFunction = preg_match($regexpMatchString, substr($formula, $index), $match); | ||||
| //echo '$isOperandOrFunction is '.(($isOperandOrFunction) ? 'True' : 'False').PHP_EOL;
 | ||||
| //var_dump($match);
 | ||||
| 
 | ||||
|             if ($opCharacter == '-' && !$expectingOperator) {                //    Is it a negation instead of a minus?
 | ||||
| //echo 'Element is a Negation operator', PHP_EOL;
 | ||||
|                 $stack->push('Unary Operator', '~'); //    Put a negation on the stack
 | ||||
|                 ++$index; //        and drop the negation symbol
 | ||||
|             } elseif ($opCharacter == '%' && $expectingOperator) { | ||||
|                 //echo 'Element is a Percentage operator', PHP_EOL;
 | ||||
|                 $stack->push('Unary Operator', '%'); //    Put a percentage on the stack
 | ||||
|                 ++$index; | ||||
|             } elseif ($opCharacter == '+' && !$expectingOperator) {            //    Positive (unary plus rather than binary operator plus) can be discarded?
 | ||||
| //echo 'Element is a Positive number, not Plus operator', PHP_EOL;
 | ||||
|                 ++$index; //    Drop the redundant plus symbol
 | ||||
|             } elseif ((($opCharacter == '~') || ($opCharacter == '|')) && (!$isOperandOrFunction)) {    //    We have to explicitly deny a tilde or pipe, because they are legal
 | ||||
|                 return $this->raiseFormulaError("Formula Error: Illegal character '~'"); //        on the stack but not in the input expression
 | ||||
|             } elseif ((isset(self::$operators[$opCharacter]) or $isOperandOrFunction) && $expectingOperator) {    //    Are we putting an operator on the stack?
 | ||||
| //echo 'Element with value '.$opCharacter.' is an Operator', PHP_EOL;
 | ||||
|                 while ($stack->count() > 0 && | ||||
|                     ($o2 = $stack->last()) && | ||||
|                     isset(self::$operators[$o2['value']]) && | ||||
| @ -3137,7 +3126,6 @@ class Calculation | ||||
|                 ++$index; | ||||
|                 $expectingOperator = false; | ||||
|             } elseif ($opCharacter == ')' && $expectingOperator) {            //    Are we expecting to close a parenthesis?
 | ||||
| //echo 'Element is a Closing bracket', PHP_EOL;
 | ||||
|                 $expectingOperand = false; | ||||
|                 while (($o2 = $stack->pop()) && $o2['value'] != '(') {        //    Pop off the stack back to the last (
 | ||||
|                     if ($o2 === null) { | ||||
| @ -3149,24 +3137,14 @@ class Calculation | ||||
|                 $d = $stack->last(2); | ||||
|                 if (preg_match('/^' . self::CALCULATION_REGEXP_FUNCTION . '$/i', $d['value'], $matches)) {    //    Did this parenthesis just close a function?
 | ||||
|                     $functionName = $matches[1]; //    Get the function name
 | ||||
| //echo 'Closed Function is '.$functionName, PHP_EOL;
 | ||||
|                     $d = $stack->pop(); | ||||
|                     $argumentCount = $d['value']; //    See how many arguments there were (argument count is the next value stored on the stack)
 | ||||
| //if ($argumentCount == 0) {
 | ||||
| //    echo 'With no arguments', PHP_EOL;
 | ||||
| //} elseif ($argumentCount == 1) {
 | ||||
| //    echo 'With 1 argument', PHP_EOL;
 | ||||
| //} else {
 | ||||
| //    echo 'With '.$argumentCount.' arguments', PHP_EOL;
 | ||||
| //}
 | ||||
|                     $output[] = $d; //    Dump the argument count on the output
 | ||||
|                     $output[] = $stack->pop(); //    Pop the function and push onto the output
 | ||||
|                     if (isset(self::$controlFunctions[$functionName])) { | ||||
|                         //echo 'Built-in function '.$functionName, PHP_EOL;
 | ||||
|                         $expectedArgumentCount = self::$controlFunctions[$functionName]['argumentCount']; | ||||
|                         $functionCall = self::$controlFunctions[$functionName]['functionCall']; | ||||
|                     } elseif (isset(self::$phpSpreadsheetFunctions[$functionName])) { | ||||
|                         //echo 'PhpSpreadsheet function '.$functionName, PHP_EOL;
 | ||||
|                         $expectedArgumentCount = self::$phpSpreadsheetFunctions[$functionName]['argumentCount']; | ||||
|                         $functionCall = self::$phpSpreadsheetFunctions[$functionName]['functionCall']; | ||||
|                     } else {    // did we somehow push a non-function on the stack? this should never happen
 | ||||
| @ -3176,13 +3154,11 @@ class Calculation | ||||
|                     $argumentCountError = false; | ||||
|                     if (is_numeric($expectedArgumentCount)) { | ||||
|                         if ($expectedArgumentCount < 0) { | ||||
|                             //echo '$expectedArgumentCount is between 0 and '.abs($expectedArgumentCount), PHP_EOL;
 | ||||
|                             if ($argumentCount > abs($expectedArgumentCount)) { | ||||
|                                 $argumentCountError = true; | ||||
|                                 $expectedArgumentCountString = 'no more than ' . abs($expectedArgumentCount); | ||||
|                             } | ||||
|                         } else { | ||||
|                             //echo '$expectedArgumentCount is numeric '.$expectedArgumentCount, PHP_EOL;
 | ||||
|                             if ($argumentCount != $expectedArgumentCount) { | ||||
|                                 $argumentCountError = true; | ||||
|                                 $expectedArgumentCountString = $expectedArgumentCount; | ||||
| @ -3190,8 +3166,6 @@ class Calculation | ||||
|                         } | ||||
|                     } elseif ($expectedArgumentCount != '*') { | ||||
|                         $isOperandOrFunction = preg_match('/(\d*)([-+,])(\d*)/', $expectedArgumentCount, $argMatch); | ||||
| //print_r($argMatch);
 | ||||
| //echo PHP_EOL;
 | ||||
|                         switch ($argMatch[2]) { | ||||
|                             case '+': | ||||
|                                 if ($argumentCount < $argMatch[1]) { | ||||
| @ -3219,7 +3193,6 @@ class Calculation | ||||
|                 } | ||||
|                 ++$index; | ||||
|             } elseif ($opCharacter == ',') {            //    Is this the separator for function arguments?
 | ||||
| //echo 'Element is a Function argument separator', PHP_EOL;
 | ||||
|                 while (($o2 = $stack->pop()) && $o2['value'] != '(') {        //    Pop off the stack back to the last (
 | ||||
|                     if ($o2 === null) { | ||||
|                         return $this->raiseFormulaError('Formula Error: Unexpected ,'); | ||||
| @ -3244,7 +3217,6 @@ class Calculation | ||||
|                 $expectingOperand = true; | ||||
|                 ++$index; | ||||
|             } elseif ($opCharacter == '(' && !$expectingOperator) { | ||||
|                 //                echo 'Element is an Opening Bracket<br />';
 | ||||
|                 $stack->push('Brace', '('); | ||||
|                 ++$index; | ||||
|             } elseif ($isOperandOrFunction && !$expectingOperator) {    // do we now have a function/variable/number?
 | ||||
| @ -3252,11 +3224,9 @@ class Calculation | ||||
|                 $expectingOperand = false; | ||||
|                 $val = $match[1]; | ||||
|                 $length = strlen($val); | ||||
| //                echo 'Element with value '.$val.' is an Operand, Variable, Constant, String, Number, Cell Reference or Function<br />';
 | ||||
| 
 | ||||
|                 if (preg_match('/^' . self::CALCULATION_REGEXP_FUNCTION . '$/i', $val, $matches)) { | ||||
|                     $val = preg_replace('/\s/u', '', $val); | ||||
| //                    echo 'Element '.$val.' is a Function<br />';
 | ||||
|                     if (isset(self::$phpSpreadsheetFunctions[strtoupper($matches[1])]) || isset(self::$controlFunctions[strtoupper($matches[1])])) {    // it's a function
 | ||||
|                         $stack->push('Function', strtoupper($val)); | ||||
|                         $ax = preg_match('/^\s*(\s*\))/ui', substr($formula, $index + $length), $amatch); | ||||
| @ -3272,7 +3242,6 @@ class Calculation | ||||
|                         $output[] = ['type' => 'Value', 'value' => $matches[1], 'reference' => null]; | ||||
|                     } | ||||
|                 } elseif (preg_match('/^' . self::CALCULATION_REGEXP_CELLREF . '$/i', $val, $matches)) { | ||||
|                     //                    echo 'Element '.$val.' is a Cell reference<br />';
 | ||||
|                     //    Watch for this case-change when modifying to allow cell references in different worksheets...
 | ||||
|                     //    Should only be applied to the actual cell column, not the worksheet name
 | ||||
| 
 | ||||
| @ -3294,9 +3263,7 @@ class Calculation | ||||
|                     } | ||||
| 
 | ||||
|                     $output[] = ['type' => 'Cell Reference', 'value' => $val, 'reference' => $val]; | ||||
| //                    $expectingOperator = FALSE;
 | ||||
|                 } else {    // it's a variable, constant, string, number or boolean
 | ||||
| //                    echo 'Element is a Variable, Constant, String, Number or Boolean<br />';
 | ||||
|                     //    If the last entry on the stack was a : operator, then we may have a row or column range reference
 | ||||
|                     $testPrevOp = $stack->last(1); | ||||
|                     if ($testPrevOp['value'] == ':') { | ||||
| @ -3332,24 +3299,18 @@ class Calculation | ||||
| 
 | ||||
|                     $localeConstant = false; | ||||
|                     if ($opCharacter == '"') { | ||||
|                         //                        echo 'Element is a String<br />';
 | ||||
|                         //    UnEscape any quotes within the string
 | ||||
|                         $val = self::wrapResult(str_replace('""', '"', self::unwrapResult($val))); | ||||
|                     } elseif (is_numeric($val)) { | ||||
|                         //                        echo 'Element is a Number<br />';
 | ||||
|                         if ((strpos($val, '.') !== false) || (stripos($val, 'e') !== false) || ($val > PHP_INT_MAX) || ($val < -PHP_INT_MAX)) { | ||||
|                             //                            echo 'Casting '.$val.' to float<br />';
 | ||||
|                             $val = (float) $val; | ||||
|                         } else { | ||||
|                             //                            echo 'Casting '.$val.' to integer<br />';
 | ||||
|                             $val = (integer) $val; | ||||
|                         } | ||||
|                     } elseif (isset(self::$excelConstants[trim(strtoupper($val))])) { | ||||
|                         $excelConstant = trim(strtoupper($val)); | ||||
| //                        echo 'Element '.$excelConstant.' is an Excel Constant<br />';
 | ||||
|                         $val = self::$excelConstants[$excelConstant]; | ||||
|                     } elseif (($localeConstant = array_search(trim(strtoupper($val)), self::$localeBoolean)) !== false) { | ||||
|                         //                        echo 'Element '.$localeConstant.' is an Excel Constant<br />';
 | ||||
|                         $val = self::$excelConstants[$localeConstant]; | ||||
|                     } | ||||
|                     $details = ['type' => 'Value', 'value' => $val, 'reference' => null]; | ||||
| @ -3394,10 +3355,8 @@ class Calculation | ||||
|                 } | ||||
|                 //    If we're expecting an operator, but only have a space between the previous and next operands (and both are
 | ||||
|                 //        Cell References) then we have an INTERSECTION operator
 | ||||
| //                echo 'Possible Intersect Operator<br />';
 | ||||
|                 if (($expectingOperator) && (preg_match('/^' . self::CALCULATION_REGEXP_CELLREF . '.*/Ui', substr($formula, $index), $match)) && | ||||
|                     ($output[count($output) - 1]['type'] == 'Cell Reference')) { | ||||
|                     //                    echo 'Element is an Intersect Operator<br />';
 | ||||
|                     while ($stack->count() > 0 && | ||||
|                         ($o2 = $stack->last()) && | ||||
|                         isset(self::$operators[$o2['value']]) && | ||||
| @ -3455,13 +3414,9 @@ class Calculation | ||||
| 
 | ||||
|         //    Loop through each token in turn
 | ||||
|         foreach ($tokens as $tokenData) { | ||||
|             //            print_r($tokenData);
 | ||||
| //            echo '<br />';
 | ||||
|             $token = $tokenData['value']; | ||||
| //            echo '<b>Token is '.$token.'</b><br />';
 | ||||
|             // if the token is a binary operator, pop the top two values off the stack, do the operation, and push the result back on the stack
 | ||||
|             if (isset(self::$binaryOperators[$token])) { | ||||
|                 //                echo 'Token is a binary operator<br />';
 | ||||
|                 //    We must have two operands, error if we don't
 | ||||
|                 if (($operand2Data = $stack->pop()) === null) { | ||||
|                     return $this->raiseFormulaError('Internal error - Operand value missing from stack'); | ||||
| @ -3604,17 +3559,14 @@ class Calculation | ||||
| 
 | ||||
|             // if the token is a unary operator, pop one value off the stack, do the operation, and push it back on
 | ||||
|             } elseif (($token === '~') || ($token === '%')) { | ||||
|                 //                echo 'Token is a unary operator<br />';
 | ||||
|                 if (($arg = $stack->pop()) === null) { | ||||
|                     return $this->raiseFormulaError('Internal error - Operand value missing from stack'); | ||||
|                 } | ||||
|                 $arg = $arg['value']; | ||||
|                 if ($token === '~') { | ||||
|                     //                    echo 'Token is a negation operator<br />';
 | ||||
|                     $this->_debugLog->writeDebugLog('Evaluating Negation of ', $this->showValue($arg)); | ||||
|                     $multiplier = -1; | ||||
|                 } else { | ||||
|                     //                    echo 'Token is a percentile operator<br />';
 | ||||
|                     $this->_debugLog->writeDebugLog('Evaluating Percentile of ', $this->showValue($arg)); | ||||
|                     $multiplier = 0.01; | ||||
|                 } | ||||
| @ -3635,9 +3587,7 @@ class Calculation | ||||
|                 } | ||||
|             } elseif (preg_match('/^' . self::CALCULATION_REGEXP_CELLREF . '$/i', $token, $matches)) { | ||||
|                 $cellRef = null; | ||||
| //                echo 'Element '.$token.' is a Cell reference<br />';
 | ||||
|                 if (isset($matches[8])) { | ||||
|                     //                    echo 'Reference is a Range of cells<br />';
 | ||||
|                     if ($pCell === null) { | ||||
|                         //                        We can't access the range, so return a REF error
 | ||||
|                         $cellValue = Calculation\Functions::REF(); | ||||
| @ -3650,7 +3600,6 @@ class Calculation | ||||
|                                 return $this->raiseFormulaError('Unable to access External Workbook'); | ||||
|                             } | ||||
|                             $matches[2] = trim($matches[2], "\"'"); | ||||
| //                            echo '$cellRef='.$cellRef.' in worksheet '.$matches[2].'<br />';
 | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating Cell Range ', $cellRef, ' in worksheet ', $matches[2]); | ||||
|                             if ($pCellParent !== null) { | ||||
|                                 $cellValue = $this->extractCellRange($cellRef, $this->spreadsheet->getSheetByName($matches[2]), false); | ||||
| @ -3658,9 +3607,7 @@ class Calculation | ||||
|                                 return $this->raiseFormulaError('Unable to access Cell Reference'); | ||||
|                             } | ||||
|                             $this->_debugLog->writeDebugLog('Evaluation Result for cells ', $cellRef, ' in worksheet ', $matches[2], ' is ', $this->showTypeDetails($cellValue)); | ||||
| //                            $cellRef = $matches[2].'!'.$cellRef;
 | ||||
|                         } else { | ||||
|                             //                            echo '$cellRef='.$cellRef.' in current worksheet<br />';
 | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating Cell Range ', $cellRef, ' in current worksheet'); | ||||
|                             if ($pCellParent !== null) { | ||||
|                                 $cellValue = $this->extractCellRange($cellRef, $pCellWorksheet, false); | ||||
| @ -3671,7 +3618,6 @@ class Calculation | ||||
|                         } | ||||
|                     } | ||||
|                 } else { | ||||
|                     //                    echo 'Reference is a single Cell<br />';
 | ||||
|                     if ($pCell === null) { | ||||
|                         //                        We can't access the cell, so return a REF error
 | ||||
|                         $cellValue = Calculation\Functions::REF(); | ||||
| @ -3683,7 +3629,6 @@ class Calculation | ||||
|                                 //    It's a Reference to an external spreadsheet (not currently supported)
 | ||||
|                                 return $this->raiseFormulaError('Unable to access External Workbook'); | ||||
|                             } | ||||
| //                            echo '$cellRef='.$cellRef.' in worksheet '.$matches[2].'<br />';
 | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating Cell ', $cellRef, ' in worksheet ', $matches[2]); | ||||
|                             if ($pCellParent !== null) { | ||||
|                                 $cellSheet = $this->spreadsheet->getSheetByName($matches[2]); | ||||
| @ -3697,9 +3642,7 @@ class Calculation | ||||
|                                 return $this->raiseFormulaError('Unable to access Cell Reference'); | ||||
|                             } | ||||
|                             $this->_debugLog->writeDebugLog('Evaluation Result for cell ', $cellRef, ' in worksheet ', $matches[2], ' is ', $this->showTypeDetails($cellValue)); | ||||
| //                            $cellRef = $matches[2].'!'.$cellRef;
 | ||||
|                         } else { | ||||
|                             //                            echo '$cellRef='.$cellRef.' in current worksheet<br />';
 | ||||
|                             $this->_debugLog->writeDebugLog('Evaluating Cell ', $cellRef, ' in current worksheet'); | ||||
|                             if ($pCellParent->isDataSet($cellRef)) { | ||||
|                                 $cellValue = $this->extractCellRange($cellRef, $pCellWorksheet, false); | ||||
| @ -3715,7 +3658,6 @@ class Calculation | ||||
| 
 | ||||
|             // 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)) { | ||||
|                 //                echo 'Token is a function<br />';
 | ||||
|                 $functionName = $matches[1]; | ||||
|                 $argCount = $stack->pop(); | ||||
|                 $argCount = $argCount['value']; | ||||
| @ -3733,7 +3675,6 @@ class Calculation | ||||
|                         $passCellReference = isset(self::$controlFunctions[$functionName]['passCellReference']); | ||||
|                     } | ||||
|                     // get the arguments for this function
 | ||||
| //                    echo 'Function '.$functionName.' expects '.$argCount.' arguments<br />';
 | ||||
|                     $args = $argArrayVals = []; | ||||
|                     for ($i = 0; $i < $argCount; ++$i) { | ||||
|                         $arg = $stack->pop(); | ||||
| @ -3765,38 +3706,14 @@ class Calculation | ||||
|                         $args[] = $cellID; | ||||
|                         $argArrayVals[] = $this->showValue($cellID); | ||||
|                     } | ||||
| //                    echo 'Arguments are: ';
 | ||||
| //                    print_r($args);
 | ||||
| //                    echo '<br />';
 | ||||
| 
 | ||||
|                     if ($functionName != 'MKMATRIX') { | ||||
|                         if ($this->_debugLog->getWriteDebugLog()) { | ||||
|                             krsort($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
 | ||||
| //                    if (($argCount == 1) && (is_array($args[1])) && ($functionName != 'MKMATRIX')) {
 | ||||
| //                        $operand1 = $args[1];
 | ||||
| //                        $this->_debugLog->writeDebugLog('Argument is a matrix: ', $this->showValue($operand1));
 | ||||
| //                        $result = array();
 | ||||
| //                        $row = 0;
 | ||||
| //                        foreach($operand1 as $args) {
 | ||||
| //                            if (is_array($args)) {
 | ||||
| //                                foreach($args as $arg) {
 | ||||
| //                                    $this->_debugLog->writeDebugLog('Evaluating ', self::localeFunc($functionName), '( ', $this->showValue($arg), ' )');
 | ||||
| //                                    $r = call_user_func_array($functionCall, $arg);
 | ||||
| //                                    $this->_debugLog->writeDebugLog('Evaluation Result for ', self::localeFunc($functionName), '() function call is ', $this->showTypeDetails($r));
 | ||||
| //                                    $result[$row][] = $r;
 | ||||
| //                                }
 | ||||
| //                                ++$row;
 | ||||
| //                            } else {
 | ||||
| //                                $this->_debugLog->writeDebugLog('Evaluating ', self::localeFunc($functionName), '( ', $this->showValue($args), ' )');
 | ||||
| //                                $r = call_user_func_array($functionCall, $args);
 | ||||
| //                                $this->_debugLog->writeDebugLog('Evaluation Result for ', self::localeFunc($functionName), '() function call is ', $this->showTypeDetails($r));
 | ||||
| //                                $result[] = $r;
 | ||||
| //                            }
 | ||||
| //                        }
 | ||||
| //                    } else {
 | ||||
| 
 | ||||
|                     //    Process the argument with the appropriate function call
 | ||||
|                     if ($passCellReference) { | ||||
|                         $args[] = $pCell; | ||||
| @ -3819,17 +3736,13 @@ class Calculation | ||||
|                 // if the token is a number, boolean, string or an Excel error, push it onto the stack
 | ||||
|                 if (isset(self::$excelConstants[strtoupper($token)])) { | ||||
|                     $excelConstant = strtoupper($token); | ||||
| //                    echo 'Token is a PhpSpreadsheet constant: '.$excelConstant.'<br />';
 | ||||
|                     $stack->push('Constant Value', self::$excelConstants[$excelConstant]); | ||||
|                     $this->_debugLog->writeDebugLog('Evaluating Constant ', $excelConstant, ' as ', $this->showTypeDetails(self::$excelConstants[$excelConstant])); | ||||
|                 } elseif ((is_numeric($token)) || ($token === null) || (is_bool($token)) || ($token == '') || ($token{0} == '"') || ($token{0} == '#')) { | ||||
|                     //                    echo 'Token is a number, boolean, string, null or an Excel error<br />';
 | ||||
|                     $stack->push('Value', $token); | ||||
|                 // if the token is a named range, push the named range name onto the stack
 | ||||
|                 } elseif (preg_match('/^' . self::CALCULATION_REGEXP_NAMEDRANGE . '$/i', $token, $matches)) { | ||||
|                     //                    echo 'Token is a named range<br />';
 | ||||
|                     $namedRange = $matches[6]; | ||||
| //                    echo 'Named Range is '.$namedRange.'<br />';
 | ||||
|                     $this->_debugLog->writeDebugLog('Evaluating Named Range ', $namedRange); | ||||
|                     $cellValue = $this->extractNamedRange($namedRange, ((null !== $pCell) ? $pCellWorksheet : null), false); | ||||
|                     $pCell->attach($pCellParent); | ||||
| @ -4130,16 +4043,10 @@ class Calculation | ||||
|         // Return value
 | ||||
|         $returnValue = []; | ||||
| 
 | ||||
| //        echo 'extractCellRange('.$pRange.')', PHP_EOL;
 | ||||
|         if ($pSheet !== null) { | ||||
|             $pSheetName = $pSheet->getTitle(); | ||||
| //            echo 'Passed sheet name is '.$pSheetName.PHP_EOL;
 | ||||
| //            echo 'Range reference is '.$pRange.PHP_EOL;
 | ||||
|             if (strpos($pRange, '!') !== false) { | ||||
|                 //                echo '$pRange reference includes sheet reference', PHP_EOL;
 | ||||
|                 list($pSheetName, $pRange) = Worksheet::extractSheetTitle($pRange, true); | ||||
| //                echo 'New sheet name is '.$pSheetName, PHP_EOL;
 | ||||
| //                echo 'Adjusted Range reference is '.$pRange, PHP_EOL;
 | ||||
|                 $pSheet = $this->spreadsheet->getSheetByName($pSheetName); | ||||
|             } | ||||
| 
 | ||||
| @ -4187,16 +4094,10 @@ class Calculation | ||||
|         // Return value
 | ||||
|         $returnValue = []; | ||||
| 
 | ||||
| //        echo 'extractNamedRange('.$pRange.')<br />';
 | ||||
|         if ($pSheet !== null) { | ||||
|             $pSheetName = $pSheet->getTitle(); | ||||
| //            echo 'Current sheet name is '.$pSheetName.'<br />';
 | ||||
| //            echo 'Range reference is '.$pRange.'<br />';
 | ||||
|             if (strpos($pRange, '!') !== false) { | ||||
|                 //                echo '$pRange reference includes sheet reference', PHP_EOL;
 | ||||
|                 list($pSheetName, $pRange) = Worksheet::extractSheetTitle($pRange, true); | ||||
| //                echo 'New sheet name is '.$pSheetName, PHP_EOL;
 | ||||
| //                echo 'Adjusted Range reference is '.$pRange, PHP_EOL;
 | ||||
|                 $pSheet = $this->spreadsheet->getSheetByName($pSheetName); | ||||
|             } | ||||
| 
 | ||||
| @ -4204,7 +4105,6 @@ class Calculation | ||||
|             $namedRange = NamedRange::resolveRange($pRange, $pSheet); | ||||
|             if ($namedRange !== null) { | ||||
|                 $pSheet = $namedRange->getWorksheet(); | ||||
| //                echo 'Named Range '.$pRange.' (';
 | ||||
|                 $pRange = $namedRange->getRange(); | ||||
|                 $splitRange = Cell::splitRange($pRange); | ||||
|                 //    Convert row and column references
 | ||||
| @ -4213,22 +4113,12 @@ class Calculation | ||||
|                 } elseif (ctype_digit($splitRange[0][0])) { | ||||
|                     $pRange = 'A' . $splitRange[0][0] . ':' . $namedRange->getWorksheet()->getHighestColumn() . $splitRange[0][1]; | ||||
|                 } | ||||
| //                echo $pRange.') is in sheet '.$namedRange->getWorksheet()->getTitle().'<br />';
 | ||||
| 
 | ||||
| //                if ($pSheet->getTitle() != $namedRange->getWorksheet()->getTitle()) {
 | ||||
| //                    if (!$namedRange->getLocalOnly()) {
 | ||||
| //                        $pSheet = $namedRange->getWorksheet();
 | ||||
| //                    } else {
 | ||||
| //                        return $returnValue;
 | ||||
| //                    }
 | ||||
| //                }
 | ||||
|             } else { | ||||
|                 return Calculation\Functions::REF(); | ||||
|             } | ||||
| 
 | ||||
|             // Extract range
 | ||||
|             $aReferences = Cell::extractAllCellReferencesInRange($pRange); | ||||
| //            var_dump($aReferences);
 | ||||
|             if (!isset($aReferences[1])) { | ||||
|                 //    Single cell (or single column or row) in range
 | ||||
|                 list($currentCol, $currentRow) = Cell::coordinateFromString($aReferences[0]); | ||||
| @ -4243,7 +4133,6 @@ class Calculation | ||||
|                 foreach ($aReferences as $reference) { | ||||
|                     // Extract range
 | ||||
|                     list($currentCol, $currentRow) = Cell::coordinateFromString($reference); | ||||
| //                    echo 'NAMED RANGE: $currentCol='.$currentCol.' $currentRow='.$currentRow.'<br />';
 | ||||
|                     $cellValue = null; | ||||
|                     if ($pSheet->cellExists($reference)) { | ||||
|                         $returnValue[$currentRow][$currentCol] = $pSheet->getCell($reference)->getCalculatedValue($resetLog); | ||||
| @ -4252,8 +4141,6 @@ class Calculation | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
| //                print_r($returnValue);
 | ||||
| //            echo '<br />';
 | ||||
|         } | ||||
| 
 | ||||
|         return $returnValue; | ||||
|  | ||||
| @ -661,8 +661,6 @@ class MathTrig | ||||
| 
 | ||||
|             return $matrixA->times($matrixB)->getArray(); | ||||
|         } catch (\PhpSpreadsheet\Exception $ex) { | ||||
|             var_dump($ex->getMessage()); | ||||
| 
 | ||||
|             return Functions::VALUE(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @ -1409,7 +1409,6 @@ class Statistical | ||||
|             $PGuess = $UnscaledPGuess / $TotalUnscaledProbability; | ||||
|             $CumPGuess = $UnscaledCumPGuess / $TotalUnscaledProbability; | ||||
| 
 | ||||
| //            $CumPGuessMinus1 = $CumPGuess - $PGuess;
 | ||||
|             $CumPGuessMinus1 = $CumPGuess - 1; | ||||
| 
 | ||||
|             while (true) { | ||||
|  | ||||
| @ -262,14 +262,11 @@ class Cell | ||||
|      */ | ||||
|     public function getCalculatedValue($resetLog = true) | ||||
|     { | ||||
|         //echo 'Cell '.$this->getCoordinate().' value is a '.$this->dataType.' with a value of '.$this->getValue().PHP_EOL;
 | ||||
|         if ($this->dataType == Cell\DataType::TYPE_FORMULA) { | ||||
|             try { | ||||
|                 //echo 'Cell value for '.$this->getCoordinate().' is a formula: Calculating value'.PHP_EOL;
 | ||||
|                 $result = Calculation::getInstance( | ||||
|                     $this->getWorksheet()->getParent() | ||||
|                 )->calculateCellValue($this, $resetLog); | ||||
| //echo $this->getCoordinate().' calculation result is '.$result.PHP_EOL;
 | ||||
|                 //    We don't yet handle array returns
 | ||||
|                 if (is_array($result)) { | ||||
|                     while (is_array($result)) { | ||||
| @ -278,10 +275,8 @@ class Cell | ||||
|                 } | ||||
|             } catch (Exception $ex) { | ||||
|                 if (($ex->getMessage() === 'Unable to access External Workbook') && ($this->calculatedValue !== null)) { | ||||
|                     //echo 'Returning fallback value of '.$this->calculatedValue.' for cell '.$this->getCoordinate().PHP_EOL;
 | ||||
|                     return $this->calculatedValue; // Fallback for calculations referencing external files.
 | ||||
|                 } | ||||
| //echo 'Calculation Exception: '.$ex->getMessage().PHP_EOL;
 | ||||
|                 $result = '#N/A'; | ||||
|                 throw new Calculation\Exception( | ||||
|                     $this->getWorksheet()->getTitle() . '!' . $this->getCoordinate() . ' -> ' . $ex->getMessage() | ||||
| @ -289,16 +284,14 @@ class Cell | ||||
|             } | ||||
| 
 | ||||
|             if ($result === '#Not Yet Implemented') { | ||||
|                 //echo 'Returning fallback value of '.$this->calculatedValue.' for cell '.$this->getCoordinate().PHP_EOL;
 | ||||
|                 return $this->calculatedValue; // Fallback if calculation engine does not support the formula.
 | ||||
|             } | ||||
| //echo 'Returning calculated value of '.$result.' for cell '.$this->getCoordinate().PHP_EOL;
 | ||||
| 
 | ||||
|             return $result; | ||||
|         } elseif ($this->value instanceof RichText) { | ||||
|             //        echo 'Cell value for '.$this->getCoordinate().' is rich text: Returning data value of '.$this->value.'<br />';
 | ||||
|             return $this->value->getPlainText(); | ||||
|         } | ||||
| //        echo 'Cell value for '.$this->getCoordinate().' is not a formula: Returning data value of '.$this->value.'<br />';
 | ||||
| 
 | ||||
|         return $this->value; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Chart; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Chart\DataSeriesValues | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Chart; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Chart\Layout | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Chart; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Chart\Legend | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -96,7 +96,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|         if (preg_match('/<?xml.*encoding=[\'"](.*?)[\'"].*?>/um', $data, $matches)) { | ||||
|             $this->charSet = strtoupper($matches[1]); | ||||
|         } | ||||
| //        echo 'Character Set is ', $this->charSet,'<br />';
 | ||||
| 
 | ||||
|         return $valid; | ||||
|     } | ||||
| @ -404,15 +403,12 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|         foreach ($xml->Styles[0] as $style) { | ||||
|             $style_ss = $style->attributes($namespaces['ss']); | ||||
|             $styleID = (string) $style_ss['ID']; | ||||
| //            echo 'Style ID = '.$styleID.'<br />';
 | ||||
|             $this->styles[$styleID] = (isset($this->styles['Default'])) ? $this->styles['Default'] : []; | ||||
|             foreach ($style as $styleType => $styleData) { | ||||
|                 $styleAttributes = $styleData->attributes($namespaces['ss']); | ||||
| //                echo $styleType.'<br />';
 | ||||
|                 switch ($styleType) { | ||||
|                     case 'Alignment': | ||||
|                         foreach ($styleAttributes as $styleAttributeKey => $styleAttributeValue) { | ||||
|                             //                                echo $styleAttributeKey.' = '.$styleAttributeValue.'<br />';
 | ||||
|                             $styleAttributeValue = (string) $styleAttributeValue; | ||||
|                             switch ($styleAttributeKey) { | ||||
|                                 case 'Vertical': | ||||
| @ -436,14 +432,11 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                             $borderAttributes = $borderStyle->attributes($namespaces['ss']); | ||||
|                             $thisBorder = []; | ||||
|                             foreach ($borderAttributes as $borderStyleKey => $borderStyleValue) { | ||||
|                                 //                                    echo $borderStyleKey.' = '.$borderStyleValue.'<br />';
 | ||||
|                                 switch ($borderStyleKey) { | ||||
|                                     case 'LineStyle': | ||||
|                                         $thisBorder['style'] = \PhpSpreadsheet\Style\Border::BORDER_MEDIUM; | ||||
| //                                                $thisBorder['style'] = $borderStyleValue;
 | ||||
|                                         break; | ||||
|                                     case 'Weight': | ||||
| //                                                $thisBorder['style'] = $borderStyleValue;
 | ||||
|                                         break; | ||||
|                                     case 'Position': | ||||
|                                         $borderPosition = strtolower($borderStyleValue); | ||||
| @ -463,7 +456,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                         break; | ||||
|                     case 'Font': | ||||
|                         foreach ($styleAttributes as $styleAttributeKey => $styleAttributeValue) { | ||||
|                             //                                echo $styleAttributeKey.' = '.$styleAttributeValue.'<br />';
 | ||||
|                             $styleAttributeValue = (string) $styleAttributeValue; | ||||
|                             switch ($styleAttributeKey) { | ||||
|                                 case 'FontName': | ||||
| @ -491,7 +483,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                         break; | ||||
|                     case 'Interior': | ||||
|                         foreach ($styleAttributes as $styleAttributeKey => $styleAttributeValue) { | ||||
|                             //                                echo $styleAttributeKey.' = '.$styleAttributeValue.'<br />';
 | ||||
|                             switch ($styleAttributeKey) { | ||||
|                                 case 'Color': | ||||
|                                     $this->styles[$styleID]['fill']['color']['rgb'] = substr($styleAttributeValue, 1); | ||||
| @ -501,7 +492,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                         break; | ||||
|                     case 'NumberFormat': | ||||
|                         foreach ($styleAttributes as $styleAttributeKey => $styleAttributeValue) { | ||||
|                             //                                echo $styleAttributeKey.' = '.$styleAttributeValue.'<br />';
 | ||||
|                             $styleAttributeValue = str_replace($fromFormats, $toFormats, $styleAttributeValue); | ||||
|                             switch ($styleAttributeValue) { | ||||
|                                 case 'Short Date': | ||||
| @ -515,15 +505,11 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                         break; | ||||
|                     case 'Protection': | ||||
|                         foreach ($styleAttributes as $styleAttributeKey => $styleAttributeValue) { | ||||
|                             //                                echo $styleAttributeKey.' = '.$styleAttributeValue.'<br />';
 | ||||
|                         } | ||||
|                         break; | ||||
|                 } | ||||
|             } | ||||
| //            print_r($this->styles[$styleID]);
 | ||||
| //            echo '<hr />';
 | ||||
|         } | ||||
| //        echo '<hr />';
 | ||||
| 
 | ||||
|         $worksheetID = 0; | ||||
|         $xml_ss = $xml->children($namespaces['ss']); | ||||
| @ -536,8 +522,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                 continue; | ||||
|             } | ||||
| 
 | ||||
| //            echo '<h3>Worksheet: ', $worksheet_ss['Name'],'<h3>';
 | ||||
| //
 | ||||
|             // Create new Worksheet
 | ||||
|             $spreadsheet->createSheet(); | ||||
|             $spreadsheet->setActiveSheetIndex($worksheetID); | ||||
| @ -558,7 +542,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                     } | ||||
|                     if (isset($columnData_ss['Width'])) { | ||||
|                         $columnWidth = $columnData_ss['Width']; | ||||
| //                        echo '<b>Setting column width for '.$columnID.' to '.$columnWidth.'</b><br />';
 | ||||
|                         $spreadsheet->getActiveSheet()->getColumnDimension($columnID)->setWidth($columnWidth / 5.4); | ||||
|                     } | ||||
|                     ++$columnID; | ||||
| @ -574,7 +557,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                     if (isset($row_ss['Index'])) { | ||||
|                         $rowID = (integer) $row_ss['Index']; | ||||
|                     } | ||||
| //                    echo '<b>Row '.$rowID.'</b><br />';
 | ||||
| 
 | ||||
|                     $columnID = 'A'; | ||||
|                     foreach ($rowData->Cell as $cell) { | ||||
| @ -611,7 +593,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                             // added this as a check for array formulas
 | ||||
|                             if (isset($cell_ss['ArrayRange'])) { | ||||
|                                 $cellDataCSEFormula = $cell_ss['ArrayRange']; | ||||
| //                                echo "found an array formula at ".$columnID.$rowID."<br />";
 | ||||
|                             } | ||||
|                             $hasCalculatedValue = true; | ||||
|                         } | ||||
| @ -657,12 +638,10 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                             } | ||||
| 
 | ||||
|                             if ($hasCalculatedValue) { | ||||
|                                 //                                echo 'FORMULA<br />';
 | ||||
|                                 $type = \PhpSpreadsheet\Cell\DataType::TYPE_FORMULA; | ||||
|                                 $columnNumber = \PhpSpreadsheet\Cell::columnIndexFromString($columnID); | ||||
|                                 if (substr($cellDataFormula, 0, 3) == 'of:') { | ||||
|                                     $cellDataFormula = substr($cellDataFormula, 3); | ||||
| //                                    echo 'Before: ', $cellDataFormula,'<br />';
 | ||||
|                                     $temp = explode('"', $cellDataFormula); | ||||
|                                     $key = false; | ||||
|                                     foreach ($temp as &$value) { | ||||
| @ -673,7 +652,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                                     } | ||||
|                                 } else { | ||||
|                                     //    Convert R1C1 style references to A1 style references (but only when not quoted)
 | ||||
| //                                    echo 'Before: ', $cellDataFormula,'<br />';
 | ||||
|                                     $temp = explode('"', $cellDataFormula); | ||||
|                                     $key = false; | ||||
|                                     foreach ($temp as &$value) { | ||||
| @ -714,42 +692,29 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                                 unset($value); | ||||
|                                 //    Then rebuild the formula string
 | ||||
|                                 $cellDataFormula = implode('"', $temp); | ||||
| //                                echo 'After: ', $cellDataFormula,'<br />';
 | ||||
|                             } | ||||
| 
 | ||||
| //                            echo 'Cell '.$columnID.$rowID.' is a '.$type.' with a value of '.(($hasCalculatedValue) ? $cellDataFormula : $cellValue).'<br />';
 | ||||
| //
 | ||||
|                             $spreadsheet->getActiveSheet()->getCell($columnID . $rowID)->setValueExplicit((($hasCalculatedValue) ? $cellDataFormula : $cellValue), $type); | ||||
|                             if ($hasCalculatedValue) { | ||||
|                                 //                                echo 'Formula result is '.$cellValue.'<br />';
 | ||||
|                                 $spreadsheet->getActiveSheet()->getCell($columnID . $rowID)->setCalculatedValue($cellValue); | ||||
|                             } | ||||
|                             $cellIsSet = $rowHasData = true; | ||||
|                         } | ||||
| 
 | ||||
|                         if (isset($cell->Comment)) { | ||||
|                             //                            echo '<b>comment found</b><br />';
 | ||||
|                             $commentAttributes = $cell->Comment->attributes($namespaces['ss']); | ||||
|                             $author = 'unknown'; | ||||
|                             if (isset($commentAttributes->Author)) { | ||||
|                                 $author = (string) $commentAttributes->Author; | ||||
| //                                echo 'Author: ', $author,'<br />';
 | ||||
|                             } | ||||
|                             $node = $cell->Comment->Data->asXML(); | ||||
| //                            $annotation = str_replace('html:','',substr($node,49,-10));
 | ||||
| //                            echo $annotation,'<br />';
 | ||||
|                             $annotation = strip_tags($node); | ||||
| //                            echo 'Annotation: ', $annotation,'<br />';
 | ||||
|                             $spreadsheet->getActiveSheet()->getComment($columnID . $rowID)->setAuthor(self::convertStringEncoding($author, $this->charSet))->setText($this->parseRichText($annotation)); | ||||
|                         } | ||||
| 
 | ||||
|                         if (($cellIsSet) && (isset($cell_ss['StyleID']))) { | ||||
|                             $style = (string) $cell_ss['StyleID']; | ||||
| //                            echo 'Cell style for '.$columnID.$rowID.' is '.$style.'<br />';
 | ||||
|                             if ((isset($this->styles[$style])) && (!empty($this->styles[$style]))) { | ||||
|                                 //                                echo 'Cell '.$columnID.$rowID.'<br />';
 | ||||
| //                                print_r($this->styles[$style]);
 | ||||
| //                                echo '<br />';
 | ||||
|                                 if (!$spreadsheet->getActiveSheet()->cellExists($columnID . $rowID)) { | ||||
|                                     $spreadsheet->getActiveSheet()->getCell($columnID . $rowID)->setValue(null); | ||||
|                                 } | ||||
| @ -769,7 +734,6 @@ class Excel2003XML extends BaseReader implements IReader | ||||
|                         } | ||||
|                         if (isset($row_ss['Height'])) { | ||||
|                             $rowHeight = $row_ss['Height']; | ||||
| //                            echo '<b>Setting row height to '.$rowHeight.'</b><br />';
 | ||||
|                             $spreadsheet->getActiveSheet()->getRowDimension($rowID)->setRowHeight($rowHeight); | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
| @ -259,7 +259,6 @@ class Excel2007 extends BaseReader implements IReader | ||||
| 
 | ||||
|     private static function castToBoolean($c) | ||||
|     { | ||||
|         //        echo 'Initial Cast to Boolean', PHP_EOL;
 | ||||
|         $value = isset($c->v) ? (string) $c->v : null; | ||||
|         if ($value == '0') { | ||||
|             return false; | ||||
| @ -274,44 +273,27 @@ class Excel2007 extends BaseReader implements IReader | ||||
| 
 | ||||
|     private static function castToError($c) | ||||
|     { | ||||
|         //        echo 'Initial Cast to Error', PHP_EOL;
 | ||||
|         return isset($c->v) ? (string) $c->v : null; | ||||
|     } | ||||
| 
 | ||||
|     private static function castToString($c) | ||||
|     { | ||||
|         //        echo 'Initial Cast to String, PHP_EOL;
 | ||||
|         return isset($c->v) ? (string) $c->v : null; | ||||
|     } | ||||
| 
 | ||||
|     private function castToFormula($c, $r, &$cellDataType, &$value, &$calculatedValue, &$sharedFormulas, $castBaseType) | ||||
|     { | ||||
|         //        echo 'Formula', PHP_EOL;
 | ||||
| //        echo '$c->f is ', $c->f, PHP_EOL;
 | ||||
|         $cellDataType = 'f'; | ||||
|         $value = "={$c->f}"; | ||||
|         $calculatedValue = self::$castBaseType($c); | ||||
| 
 | ||||
|         // Shared formula?
 | ||||
|         if (isset($c->f['t']) && strtolower((string) $c->f['t']) == 'shared') { | ||||
|             //            echo 'SHARED FORMULA', PHP_EOL;
 | ||||
|             $instance = (string) $c->f['si']; | ||||
| 
 | ||||
| //            echo 'Instance ID = ', $instance, PHP_EOL;
 | ||||
| //
 | ||||
| //            echo 'Shared Formula Array:', PHP_EOL;
 | ||||
| //            print_r($sharedFormulas);
 | ||||
|             if (!isset($sharedFormulas[(string) $c->f['si']])) { | ||||
|                 //                echo 'SETTING NEW SHARED FORMULA', PHP_EOL;
 | ||||
| //                echo 'Master is ', $r, PHP_EOL;
 | ||||
| //                echo 'Formula is ', $value, PHP_EOL;
 | ||||
|                 $sharedFormulas[$instance] = ['master' => $r, 'formula' => $value]; | ||||
| //                echo 'New Shared Formula Array:', PHP_EOL;
 | ||||
| //                print_r($sharedFormulas);
 | ||||
|             } else { | ||||
|                 //                echo 'GETTING SHARED FORMULA', PHP_EOL;
 | ||||
| //                echo 'Master is ', $sharedFormulas[$instance]['master'], PHP_EOL;
 | ||||
| //                echo 'Formula is ', $sharedFormulas[$instance]['formula'], PHP_EOL;
 | ||||
|                 $master = \PhpSpreadsheet\Cell::coordinateFromString($sharedFormulas[$instance]['master']); | ||||
|                 $current = \PhpSpreadsheet\Cell::coordinateFromString($r); | ||||
| 
 | ||||
| @ -320,7 +302,6 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                 $difference[1] = $current[1] - $master[1]; | ||||
| 
 | ||||
|                 $value = $this->referenceHelper->updateFormulaReferences($sharedFormulas[$instance]['formula'], 'A1', $difference[0], $difference[1]); | ||||
| //                echo 'Adjusted Formula is ', $value, PHP_EOL;
 | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @ -828,11 +809,7 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                                         if ($col['style'] && !$this->readDataOnly) { | ||||
|                                             $docSheet->getColumnDimension(\PhpSpreadsheet\Cell::stringFromColumnIndex($i))->setXfIndex(intval($col['style'])); | ||||
|                                         } | ||||
|                                         if (self::boolean($col['bestFit'])) { | ||||
|                                             //$docSheet->getColumnDimension(\PhpSpreadsheet\Cell::stringFromColumnIndex($i))->setAutoSize(true);
 | ||||
|                                         } | ||||
|                                         if (self::boolean($col['hidden'])) { | ||||
|                                             // echo \PhpSpreadsheet\Cell::stringFromColumnIndex($i), ': HIDDEN COLUMN',PHP_EOL;
 | ||||
|                                             $docSheet->getColumnDimension(\PhpSpreadsheet\Cell::stringFromColumnIndex($i))->setVisible(false); | ||||
|                                         } | ||||
|                                         if (self::boolean($col['collapsed'])) { | ||||
| @ -898,15 +875,9 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                                             } | ||||
|                                         } | ||||
| 
 | ||||
|     //                                    echo 'Reading cell ', $coordinates[0], $coordinates[1], PHP_EOL;
 | ||||
|     //                                    print_r($c);
 | ||||
|     //                                    echo PHP_EOL;
 | ||||
|     //                                    echo 'Cell Data Type is ', $cellDataType, ': ';
 | ||||
|     //
 | ||||
|                                         // Read cell!
 | ||||
|                                         switch ($cellDataType) { | ||||
|                                             case 's': | ||||
|     //                                            echo 'String', PHP_EOL;
 | ||||
|                                                 if ((string) $c->v != '') { | ||||
|                                                     $value = $sharedStrings[intval($c->v)]; | ||||
| 
 | ||||
| @ -918,7 +889,6 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                                                 } | ||||
|                                                 break; | ||||
|                                             case 'b': | ||||
|     //                                            echo 'Boolean', PHP_EOL;
 | ||||
|                                                 if (!isset($c->f)) { | ||||
|                                                     $value = self::castToBoolean($c); | ||||
|                                                 } else { | ||||
| @ -929,11 +899,9 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                                                         $att = $c->f; | ||||
|                                                         $docSheet->getCell($r)->setFormulaAttributes($att); | ||||
|                                                     } | ||||
|     //                                                echo '$calculatedValue = ', $calculatedValue, PHP_EOL;
 | ||||
|                                                 } | ||||
|                                                 break; | ||||
|                                             case 'inlineStr': | ||||
| //                                                echo 'Inline String', PHP_EOL;
 | ||||
|                                                 if (isset($c->f)) { | ||||
|                                                     $this->castToFormula($c, $r, $cellDataType, $value, $calculatedValue, $sharedFormulas, 'castToError'); | ||||
|                                                 } else { | ||||
| @ -941,29 +909,22 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                                                 } | ||||
|                                                 break; | ||||
|                                             case 'e': | ||||
|     //                                            echo 'Error', PHP_EOL;
 | ||||
|                                                 if (!isset($c->f)) { | ||||
|                                                     $value = self::castToError($c); | ||||
|                                                 } else { | ||||
|                                                     // Formula
 | ||||
|                                                     $this->castToFormula($c, $r, $cellDataType, $value, $calculatedValue, $sharedFormulas, 'castToError'); | ||||
|     //                                                echo '$calculatedValue = ', $calculatedValue, PHP_EOL;
 | ||||
|                                                 } | ||||
|                                                 break; | ||||
|                                             default: | ||||
| //                                                echo 'Default', PHP_EOL;
 | ||||
|                                                 if (!isset($c->f)) { | ||||
|                                                     //                                                echo 'Not a Formula', PHP_EOL;
 | ||||
|                                                     $value = self::castToString($c); | ||||
|                                                 } else { | ||||
|                                                     //                                                echo 'Treat as Formula', PHP_EOL;
 | ||||
|                                                     // Formula
 | ||||
|                                                     $this->castToFormula($c, $r, $cellDataType, $value, $calculatedValue, $sharedFormulas, 'castToString'); | ||||
|     //                                                echo '$calculatedValue = ', $calculatedValue, PHP_EOL;
 | ||||
|                                                 } | ||||
|                                                 break; | ||||
|                                         } | ||||
|     //                                    echo 'Value is ', $value, PHP_EOL;
 | ||||
| 
 | ||||
|                                         // Check for numeric values
 | ||||
|                                         if (is_numeric($value) && $cellDataType != 's') { | ||||
| @ -1870,15 +1831,10 @@ class Excel2007 extends BaseReader implements IReader | ||||
|                             ); | ||||
|                             $objChart = \PhpSpreadsheet\Reader\Excel2007\Chart::readChart($chartElements, basename($chartEntryRef, '.xml')); | ||||
| 
 | ||||
| //                            echo 'Chart ', $chartEntryRef, '<br />';
 | ||||
| //                            var_dump($charts[$chartEntryRef]);
 | ||||
| //
 | ||||
|                             if (isset($charts[$chartEntryRef])) { | ||||
|                                 $chartPositionRef = $charts[$chartEntryRef]['sheet'] . '!' . $charts[$chartEntryRef]['id']; | ||||
| //                                echo 'Position Ref ', $chartPositionRef, '<br />';
 | ||||
|                                 if (isset($chartDetails[$chartPositionRef])) { | ||||
|                                     //                                    var_dump($chartDetails[$chartPositionRef]);
 | ||||
| 
 | ||||
|                                     $excel->getSheetByName($charts[$chartEntryRef]['sheet'])->addChart($objChart); | ||||
|                                     $objChart->setWorksheet($excel->getSheetByName($charts[$chartEntryRef]['sheet'])); | ||||
|                                     $objChart->setTopLeftPosition($chartDetails[$chartPositionRef]['fromCoordinate'], $chartDetails[$chartPositionRef]['fromOffsetX'], $chartDetails[$chartPositionRef]['fromOffsetY']); | ||||
| @ -1925,14 +1881,7 @@ class Excel2007 extends BaseReader implements IReader | ||||
|      */ | ||||
|     private static function readStyle($docStyle, \PhpSpreadsheet\Style $style) | ||||
|     { | ||||
|         // format code
 | ||||
| //        if (isset($style->numFmt)) {
 | ||||
| //            if (isset($style->numFmt['formatCode'])) {
 | ||||
| //                $docStyle->getNumberFormat()->setFormatCode((string) $style->numFmt['formatCode']);
 | ||||
| //            } else {
 | ||||
|                 $docStyle->getNumberFormat()->setFormatCode($style->numFmt); | ||||
| //            }
 | ||||
| //        }
 | ||||
|         $docStyle->getNumberFormat()->setFormatCode($style->numFmt); | ||||
| 
 | ||||
|         // font
 | ||||
|         if (isset($style->font)) { | ||||
|  | ||||
| @ -240,7 +240,6 @@ class Chart | ||||
|         } | ||||
|         $layout = []; | ||||
|         foreach ($details as $detailKey => $detail) { | ||||
|             //            echo $detailKey, ' => ',self::getAttribute($detail, 'val', 'string'),PHP_EOL;
 | ||||
|             $layout[$detailKey] = self::getAttribute($detail, 'val', 'string'); | ||||
|         } | ||||
| 
 | ||||
|  | ||||
| @ -991,10 +991,6 @@ class Excel5 extends BaseReader implements IReader | ||||
| 
 | ||||
|             // treat OBJ records
 | ||||
|             foreach ($this->objs as $n => $obj) { | ||||
|                 //                echo '<hr /><b>Object</b> reference is ', $n,'<br />';
 | ||||
| //                var_dump($obj);
 | ||||
| //                echo '<br />';
 | ||||
| 
 | ||||
|                 // the first shape container never has a corresponding OBJ record, hence $n + 1
 | ||||
|                 if (isset($allSpContainers[$n + 1]) && is_object($allSpContainers[$n + 1])) { | ||||
|                     $spContainer = $allSpContainers[$n + 1]; | ||||
| @ -1023,8 +1019,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|                     switch ($obj['otObjType']) { | ||||
|                         case 0x19: | ||||
|                             // Note
 | ||||
| //                            echo 'Cell Annotation Object<br />';
 | ||||
| //                            echo 'Object ID is ', $obj['idObjID'],'<br />';
 | ||||
|                             if (isset($this->cellNotes[$obj['idObjID']])) { | ||||
|                                 $cellNote = $this->cellNotes[$obj['idObjID']]; | ||||
| 
 | ||||
| @ -1035,7 +1029,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|                             } | ||||
|                             break; | ||||
|                         case 0x08: | ||||
| //                            echo 'Picture Object<br />';
 | ||||
|                             // picture
 | ||||
|                             // get index to BSE entry (1-based)
 | ||||
|                             $BSEindex = $spContainer->getOPT(0x0104); | ||||
| @ -1099,9 +1092,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|                             $noteDetails['objTextData']['text'] = ''; | ||||
|                         } | ||||
|                     } | ||||
| //                    echo '<b>Cell annotation ', $note,'</b><br />';
 | ||||
| //                    var_dump($noteDetails);
 | ||||
| //                    echo '<br />';
 | ||||
|                     $cellAddress = str_replace('$', '', $noteDetails['cellRef']); | ||||
|                     $this->phpSheet->getComment($cellAddress)->setAuthor($noteDetails['author'])->setText($this->parseRichText($noteDetails['objTextData']['text'])); | ||||
|                 } | ||||
| @ -1275,8 +1265,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|         $this->summaryInformation = $ole->getStream($ole->summaryInformation); | ||||
|         // Get additional document summary information data
 | ||||
|         $this->documentSummaryInformation = $ole->getStream($ole->documentSummaryInformation); | ||||
|         // Get user-defined property data
 | ||||
| //        $this->userDefinedProperties = $ole->getUserDefinedProperties();
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -1429,21 +1417,17 @@ class Excel5 extends BaseReader implements IReader | ||||
|         //    offset: 8;    size: 16
 | ||||
|         //    offset: 24;    size: 4;    section count
 | ||||
|         $secCount = self::getInt4d($this->documentSummaryInformation, 24); | ||||
| //        echo '$secCount = ', $secCount,'<br />';
 | ||||
| 
 | ||||
|         // offset: 28;    size: 16;    first section's class id: 02 d5 cd d5 9c 2e 1b 10 93 97 08 00 2b 2c f9 ae
 | ||||
|         // offset: 44;    size: 4;    first section offset
 | ||||
|         $secOffset = self::getInt4d($this->documentSummaryInformation, 44); | ||||
| //        echo '$secOffset = ', $secOffset,'<br />';
 | ||||
| 
 | ||||
|         //    section header
 | ||||
|         //    offset: $secOffset;    size: 4;    section length
 | ||||
|         $secLength = self::getInt4d($this->documentSummaryInformation, $secOffset); | ||||
| //        echo '$secLength = ', $secLength,'<br />';
 | ||||
| 
 | ||||
|         //    offset: $secOffset+4;    size: 4;    property count
 | ||||
|         $countProperties = self::getInt4d($this->documentSummaryInformation, $secOffset + 4); | ||||
| //        echo '$countProperties = ', $countProperties,'<br />';
 | ||||
| 
 | ||||
|         // initialize code page (used to resolve string values)
 | ||||
|         $codePage = 'CP1252'; | ||||
| @ -1451,17 +1435,14 @@ class Excel5 extends BaseReader implements IReader | ||||
|         //    offset: ($secOffset+8);    size: var
 | ||||
|         //    loop through property decarations and properties
 | ||||
|         for ($i = 0; $i < $countProperties; ++$i) { | ||||
|             //            echo 'Property ', $i,'<br />';
 | ||||
|             //    offset: ($secOffset+8) + (8 * $i);    size: 4;    property ID
 | ||||
|             $id = self::getInt4d($this->documentSummaryInformation, ($secOffset + 8) + (8 * $i)); | ||||
| //            echo 'ID is ', $id,'<br />';
 | ||||
| 
 | ||||
|             // Use value of property id as appropriate
 | ||||
|             // offset: 60 + 8 * $i;    size: 4;    offset from beginning of section (48)
 | ||||
|             $offset = self::getInt4d($this->documentSummaryInformation, ($secOffset + 12) + (8 * $i)); | ||||
| 
 | ||||
|             $type = self::getInt4d($this->documentSummaryInformation, $secOffset + $offset); | ||||
| //            echo 'Type is ', $type,', ';
 | ||||
| 
 | ||||
|             // initialize property value
 | ||||
|             $value = null; | ||||
| @ -1555,7 +1536,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|     private function readDefault() | ||||
|     { | ||||
|         $length = self::getInt2d($this->data, $this->pos + 2); | ||||
| //        $recordData = $this->readRecordData($this->data, $this->pos + 4, $length);
 | ||||
| 
 | ||||
|         // move stream pointer to next record
 | ||||
|         $this->pos += 4 + $length; | ||||
| @ -1567,7 +1547,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|      */ | ||||
|     private function readNote() | ||||
|     { | ||||
|         //        echo '<b>Read Cell Annotation</b><br />';
 | ||||
|         $length = self::getInt2d($this->data, $this->pos + 2); | ||||
|         $recordData = $this->readRecordData($this->data, $this->pos + 4, $length); | ||||
| 
 | ||||
| @ -1583,10 +1562,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|             $noteObjID = self::getInt2d($recordData, 6); | ||||
|             $noteAuthor = self::readUnicodeStringLong(substr($recordData, 8)); | ||||
|             $noteAuthor = $noteAuthor['value']; | ||||
| //            echo 'Note Address=', $cellAddress,'<br />';
 | ||||
| //            echo 'Note Object ID=', $noteObjID,'<br />';
 | ||||
| //            echo 'Note Author=', $noteAuthor,'<hr />';
 | ||||
| //
 | ||||
|             $this->cellNotes[$noteObjID] = [ | ||||
|                 'cellRef' => $cellAddress, | ||||
|                 'objectID' => $noteObjID, | ||||
| @ -1602,13 +1577,10 @@ class Excel5 extends BaseReader implements IReader | ||||
|                 $extension = true; | ||||
|                 $cellAddress = array_pop(array_keys($this->phpSheet->getComments())); | ||||
|             } | ||||
| //            echo 'Note Address=', $cellAddress,'<br />';
 | ||||
| 
 | ||||
|             $cellAddress = str_replace('$', '', $cellAddress); | ||||
|             $noteLength = self::getInt2d($recordData, 4); | ||||
|             $noteText = trim(substr($recordData, 6)); | ||||
| //            echo 'Note Length=', $noteLength,'<br />';
 | ||||
| //            echo 'Note Text=', $noteText,'<br />';
 | ||||
| 
 | ||||
|             if ($extension) { | ||||
|                 //    Concatenate this extension with the currently set comment for the cell
 | ||||
| @ -1656,10 +1628,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|             'alignment' => $grbitOpts, | ||||
|             'rotation' => $rot, | ||||
|         ]; | ||||
| 
 | ||||
| //        echo '<b>_readTextObject()</b><br />';
 | ||||
| //        var_dump($this->textObjects[$this->textObjRef]);
 | ||||
| //        echo '<br />';
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -4192,10 +4160,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|             'grbitOpts' => $grbitOpts, | ||||
|         ]; | ||||
|         $this->textObjRef = $idObjID; | ||||
| 
 | ||||
| //        echo '<b>_readObj()</b><br />';
 | ||||
| //        var_dump(end($this->objs));
 | ||||
| //        echo '<br />';
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -4280,8 +4244,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|         // move stream pointer to next record
 | ||||
|         $this->pos += 4 + $length; | ||||
| 
 | ||||
|         //var_dump(unpack("vrt/vgrbitFrt/V2reserved/vwScalePLV/vgrbit", $recordData));
 | ||||
| 
 | ||||
|         // offset: 0; size: 2; rt
 | ||||
|         //->ignore
 | ||||
|         $rt = self::getInt2d($recordData, 0); | ||||
| @ -5057,22 +5019,18 @@ class Excel5 extends BaseReader implements IReader | ||||
|                 // 1. BITMAPCOREHEADER
 | ||||
|                 // offset: 0; size: 4; bcSize, Specifies the number of bytes required by the structure
 | ||||
|                 $bcSize = self::getInt4d($iData, 0); | ||||
|     //            var_dump($bcSize);
 | ||||
| 
 | ||||
|                 // offset: 4; size: 2; bcWidth, specifies the width of the bitmap, in pixels
 | ||||
|                 $bcWidth = self::getInt2d($iData, 4); | ||||
|     //            var_dump($bcWidth);
 | ||||
| 
 | ||||
|                 // offset: 6; size: 2; bcHeight, specifies the height of the bitmap, in pixels.
 | ||||
|                 $bcHeight = self::getInt2d($iData, 6); | ||||
|     //            var_dump($bcHeight);
 | ||||
|                 $ih = imagecreatetruecolor($bcWidth, $bcHeight); | ||||
| 
 | ||||
|                 // offset: 8; size: 2; bcPlanes, specifies the number of planes for the target device. This value must be 1
 | ||||
| 
 | ||||
|                 // offset: 10; size: 2; bcBitCount specifies the number of bits-per-pixel. This value must be 1, 4, 8, or 24
 | ||||
|                 $bcBitCount = self::getInt2d($iData, 10); | ||||
|     //            var_dump($bcBitCount);
 | ||||
| 
 | ||||
|                 $rgbString = substr($iData, 12); | ||||
|                 $rgbTriples = []; | ||||
| @ -5205,21 +5163,9 @@ class Excel5 extends BaseReader implements IReader | ||||
|         // offset: 2; size: sz
 | ||||
|         $formulaData = substr($formulaStructure, 2, $sz); | ||||
| 
 | ||||
|         // for debug: dump the formula data
 | ||||
|         //echo '<xmp>';
 | ||||
|         //echo 'size: ' . $sz . "\n";
 | ||||
|         //echo 'the entire formula data: ';
 | ||||
|         //Debug::dump($formulaData);
 | ||||
|         //echo "\n----\n";
 | ||||
| 
 | ||||
|         // offset: 2 + sz; size: variable (optional)
 | ||||
|         if (strlen($formulaStructure) > 2 + $sz) { | ||||
|             $additionalData = substr($formulaStructure, 2 + $sz); | ||||
| 
 | ||||
|             // for debug: dump the additional data
 | ||||
|             //echo 'the entire additional data: ';
 | ||||
|             //Debug::dump($additionalData);
 | ||||
|             //echo "\n----\n";
 | ||||
|         } else { | ||||
|             $additionalData = ''; | ||||
|         } | ||||
| @ -5243,9 +5189,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|         while (strlen($formulaData) > 0 and $token = $this->getNextToken($formulaData, $baseCell)) { | ||||
|             $tokens[] = $token; | ||||
|             $formulaData = substr($formulaData, $token['size']); | ||||
| 
 | ||||
|             // for debug: dump the token
 | ||||
|             //var_dump($token);
 | ||||
|         } | ||||
| 
 | ||||
|         $formulaString = $this->createFormulaFromTokens($tokens, $additionalData); | ||||
| @ -5408,10 +5351,6 @@ class Excel5 extends BaseReader implements IReader | ||||
|         } | ||||
|         $formulaString = $formulaStrings[0]; | ||||
| 
 | ||||
|         // for debug: dump the human readable formula
 | ||||
|         //echo '----' . "\n";
 | ||||
|         //echo 'Formula: ' . $formulaString;
 | ||||
| 
 | ||||
|         return $formulaString; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Reader; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Reader\Exception | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -218,15 +218,9 @@ class Gnumeric extends BaseReader implements IReader | ||||
| 
 | ||||
|         $gFileData = $this->gzfileGetContents($pFilename); | ||||
| 
 | ||||
| //        echo '<pre>';
 | ||||
| //        echo htmlentities($gFileData,ENT_QUOTES,'UTF-8');
 | ||||
| //        echo '</pre><hr />';
 | ||||
| //
 | ||||
|         $xml = simplexml_load_string($this->securityScan($gFileData), 'SimpleXMLElement', \PhpSpreadsheet\Settings::getLibXmlLoaderOptions()); | ||||
|         $namespacesMeta = $xml->getNamespaces(true); | ||||
| 
 | ||||
| //        var_dump($namespacesMeta);
 | ||||
| //
 | ||||
|         $gnmXML = $xml->children($namespacesMeta['gnm']); | ||||
| 
 | ||||
|         $docProps = $spreadsheet->getProperties(); | ||||
| @ -335,7 +329,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|         $worksheetID = 0; | ||||
|         foreach ($gnmXML->Sheets->Sheet as $sheet) { | ||||
|             $worksheetName = (string) $sheet->Name; | ||||
| //            echo '<b>Worksheet: ', $worksheetName,'</b><br />';
 | ||||
|             if ((isset($this->loadSheetsOnly)) && (!in_array($worksheetName, $this->loadSheetsOnly))) { | ||||
|                 continue; | ||||
|             } | ||||
| @ -407,9 +400,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
| 
 | ||||
|                 $ValueType = $cellAttributes->ValueType; | ||||
|                 $ExprID = (string) $cellAttributes->ExprID; | ||||
| //                echo 'Cell ', $column, $row,'<br />';
 | ||||
| //                echo 'Type is ', $ValueType,'<br />';
 | ||||
| //                echo 'Value is ', $cell,'<br />';
 | ||||
|                 $type = \PhpSpreadsheet\Cell\DataType::TYPE_FORMULA; | ||||
|                 if ($ExprID > '') { | ||||
|                     if (((string) $cell) > '') { | ||||
| @ -418,7 +408,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                             'row' => $cellAttributes->Row, | ||||
|                             'formula' => (string) $cell, | ||||
|                         ]; | ||||
| //                        echo 'NEW EXPRESSION ', $ExprID,'<br />';
 | ||||
|                     } else { | ||||
|                         $expression = $this->expressions[$ExprID]; | ||||
| 
 | ||||
| @ -429,8 +418,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                             $cellAttributes->Row - $expression['row'], | ||||
|                             $worksheetName | ||||
|                         ); | ||||
| //                        echo 'SHARED EXPRESSION ', $ExprID,'<br />';
 | ||||
| //                        echo 'New Value is ', $cell,'<br />';
 | ||||
|                     } | ||||
|                     $type = \PhpSpreadsheet\Cell\DataType::TYPE_FORMULA; | ||||
|                 } else { | ||||
| @ -470,8 +457,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
| //            echo '$maxCol=', $maxCol,'; $maxRow=', $maxRow,'<br />';
 | ||||
| //
 | ||||
|             foreach ($sheet->Styles->StyleRegion as $styleRegion) { | ||||
|                 $styleAttributes = $styleRegion->attributes(); | ||||
|                 if (($styleAttributes['startRow'] <= $maxRow) && | ||||
| @ -484,11 +469,8 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                     $endRow = ($styleAttributes['endRow'] > $maxRow) ? $maxRow : $styleAttributes['endRow']; | ||||
|                     $endRow += 1; | ||||
|                     $cellRange = $startColumn . $startRow . ':' . $endColumn . $endRow; | ||||
| //                    echo $cellRange,'<br />';
 | ||||
| 
 | ||||
|                     $styleAttributes = $styleRegion->Style->attributes(); | ||||
| //                    var_dump($styleAttributes);
 | ||||
| //                    echo '<br />';
 | ||||
| 
 | ||||
|                     //    We still set the number format mask for date/time values, even if readDataOnly is true
 | ||||
|                     if ((!$this->readDataOnly) || | ||||
| @ -611,8 +593,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                             } | ||||
| 
 | ||||
|                             $fontAttributes = $styleRegion->Style->Font->attributes(); | ||||
| //                            var_dump($fontAttributes);
 | ||||
| //                            echo '<br />';
 | ||||
|                             $styleArray['font']['name'] = (string) $styleRegion->Style->Font; | ||||
|                             $styleArray['font']['size'] = intval($fontAttributes['Unit']); | ||||
|                             $styleArray['font']['bold'] = ($fontAttributes['Bold'] == '1') ? true : false; | ||||
| @ -673,8 +653,6 @@ class Gnumeric extends BaseReader implements IReader | ||||
|                                 $hyperlink = $styleRegion->Style->HyperLink->attributes(); | ||||
|                             } | ||||
|                         } | ||||
| //                        var_dump($styleArray);
 | ||||
| //                        echo '<br />';
 | ||||
|                         $spreadsheet->getActiveSheet()->getStyle($cellRange)->applyFromArray($styleArray); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
| @ -208,7 +208,6 @@ class HTML extends BaseReader implements IReader | ||||
|             //    Simple String content
 | ||||
|             if (trim($cellContent) > '') { | ||||
|                 //    Only actually write it if there's content in the string
 | ||||
| //                echo 'FLUSH CELL: ' , $column , $row , ' => ' , $cellContent , '<br />';
 | ||||
|                 //    Write to worksheet to be done here...
 | ||||
|                 //    ... we return the cell so we can mess about with styles more easily
 | ||||
|                 $sheet->setCellValue($column . $row, $cellContent, true); | ||||
| @ -242,11 +241,8 @@ class HTML extends BaseReader implements IReader | ||||
|                     //    TODO
 | ||||
|                 } | ||||
|             } elseif ($child instanceof DOMElement) { | ||||
|                 //                echo '<b>DOM ELEMENT: </b>' , strtoupper($child->nodeName) , '<br />';
 | ||||
| 
 | ||||
|                 $attributeArray = []; | ||||
|                 foreach ($child->attributes as $attribute) { | ||||
|                     //                    echo '<b>ATTRIBUTE: </b>' , $attribute->name , ' => ' , $attribute->value , '<br />';
 | ||||
|                     $attributeArray[$attribute->name] = $attribute->value; | ||||
|                 } | ||||
| 
 | ||||
| @ -274,7 +270,6 @@ class HTML extends BaseReader implements IReader | ||||
|                     case 'em': | ||||
|                     case 'strong': | ||||
|                     case 'b': | ||||
| //                        echo 'STYLING, SPAN OR DIV<br />';
 | ||||
|                         if ($cellContent > '') { | ||||
|                             $cellContent .= ' '; | ||||
|                         } | ||||
| @ -282,7 +277,6 @@ class HTML extends BaseReader implements IReader | ||||
|                         if ($cellContent > '') { | ||||
|                             $cellContent .= ' '; | ||||
|                         } | ||||
| //                        echo 'END OF STYLING, SPAN OR DIV<br />';
 | ||||
|                         break; | ||||
|                     case 'hr': | ||||
|                         $this->flushCell($sheet, $column, $row, $cellContent); | ||||
| @ -304,14 +298,11 @@ class HTML extends BaseReader implements IReader | ||||
|                             $this->flushCell($sheet, $column, $row, $cellContent); | ||||
|                             ++$row; | ||||
|                         } | ||||
| //                        echo 'HARD LINE BREAK: ' , '<br />';
 | ||||
|                         break; | ||||
|                     case 'a': | ||||
| //                        echo 'START OF HYPERLINK: ' , '<br />';
 | ||||
|                         foreach ($attributeArray as $attributeName => $attributeValue) { | ||||
|                             switch ($attributeName) { | ||||
|                                 case 'href': | ||||
| //                                    echo 'Link to ' , $attributeValue , '<br />';
 | ||||
|                                     $sheet->getCell($column . $row)->getHyperlink()->setUrl($attributeValue); | ||||
|                                     if (isset($this->formats[$child->nodeName])) { | ||||
|                                         $sheet->getStyle($column . $row)->applyFromArray($this->formats[$child->nodeName]); | ||||
| @ -321,7 +312,6 @@ class HTML extends BaseReader implements IReader | ||||
|                         } | ||||
|                         $cellContent .= ' '; | ||||
|                         $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                        echo 'END OF HYPERLINK:' , '<br />';
 | ||||
|                         break; | ||||
|                     case 'h1': | ||||
|                     case 'h2': | ||||
| @ -335,17 +325,13 @@ class HTML extends BaseReader implements IReader | ||||
|                         if ($this->tableLevel > 0) { | ||||
|                             //    If we're inside a table, replace with a \n
 | ||||
|                             $cellContent .= "\n"; | ||||
| //                            echo 'LIST ENTRY: ' , '<br />';
 | ||||
|                             $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                            echo 'END OF LIST ENTRY:' , '<br />';
 | ||||
|                         } else { | ||||
|                             if ($cellContent > '') { | ||||
|                                 $this->flushCell($sheet, $column, $row, $cellContent); | ||||
|                                 ++$row; | ||||
|                             } | ||||
| //                            echo 'START OF PARAGRAPH: ' , '<br />';
 | ||||
|                             $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                            echo 'END OF PARAGRAPH:' , '<br />';
 | ||||
|                             $this->flushCell($sheet, $column, $row, $cellContent); | ||||
| 
 | ||||
|                             if (isset($this->formats[$child->nodeName])) { | ||||
| @ -360,17 +346,13 @@ class HTML extends BaseReader implements IReader | ||||
|                         if ($this->tableLevel > 0) { | ||||
|                             //    If we're inside a table, replace with a \n
 | ||||
|                             $cellContent .= "\n"; | ||||
| //                            echo 'LIST ENTRY: ' , '<br />';
 | ||||
|                             $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                            echo 'END OF LIST ENTRY:' , '<br />';
 | ||||
|                         } else { | ||||
|                             if ($cellContent > '') { | ||||
|                                 $this->flushCell($sheet, $column, $row, $cellContent); | ||||
|                             } | ||||
|                             ++$row; | ||||
| //                            echo 'LIST ENTRY: ' , '<br />';
 | ||||
|                             $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                            echo 'END OF LIST ENTRY:' , '<br />';
 | ||||
|                             $this->flushCell($sheet, $column, $row, $cellContent); | ||||
|                             $column = 'A'; | ||||
|                         } | ||||
| @ -378,12 +360,10 @@ class HTML extends BaseReader implements IReader | ||||
|                     case 'table': | ||||
|                         $this->flushCell($sheet, $column, $row, $cellContent); | ||||
|                         $column = $this->setTableStartColumn($column); | ||||
| //                        echo 'START OF TABLE LEVEL ' , $this->tableLevel , '<br />';
 | ||||
|                         if ($this->tableLevel > 1) { | ||||
|                             --$row; | ||||
|                         } | ||||
|                         $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                        echo 'END OF TABLE LEVEL ' , $this->tableLevel , '<br />';
 | ||||
|                         $column = $this->releaseTableStartColumn(); | ||||
|                         if ($this->tableLevel > 1) { | ||||
|                             ++$column; | ||||
| @ -398,16 +378,12 @@ class HTML extends BaseReader implements IReader | ||||
|                     case 'tr': | ||||
|                         $column = $this->getTableStartColumn(); | ||||
|                         $cellContent = ''; | ||||
| //                        echo 'START OF TABLE ' , $this->tableLevel , ' ROW<br />';
 | ||||
|                         $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
|                         ++$row; | ||||
| //                        echo 'END OF TABLE ' , $this->tableLevel , ' ROW<br />';
 | ||||
|                         break; | ||||
|                     case 'th': | ||||
|                     case 'td': | ||||
| //                        echo 'START OF TABLE ' , $this->tableLevel , ' CELL<br />';
 | ||||
|                         $this->processDomElement($child, $sheet, $row, $column, $cellContent); | ||||
| //                        echo 'END OF TABLE ' , $this->tableLevel , ' CELL<br />';
 | ||||
| 
 | ||||
|                         while (isset($this->rowspan[$column . $row])) { | ||||
|                             ++$column; | ||||
| @ -415,14 +391,6 @@ class HTML extends BaseReader implements IReader | ||||
| 
 | ||||
|                         $this->flushCell($sheet, $column, $row, $cellContent); | ||||
| 
 | ||||
| //                        if (isset($attributeArray['style']) && !empty($attributeArray['style'])) {
 | ||||
| //                            $styleAry = $this->getPhpSpreadsheetStyleArray($attributeArray['style']);
 | ||||
| //
 | ||||
| //                            if (!empty($styleAry)) {
 | ||||
| //                                $sheet->getStyle($column . $row)->applyFromArray($styleAry);
 | ||||
| //                            }
 | ||||
| //                        }
 | ||||
| 
 | ||||
|                         if (isset($attributeArray['rowspan']) && isset($attributeArray['colspan'])) { | ||||
|                             //create merging rowspan and colspan
 | ||||
|                             $columnTo = $column; | ||||
|  | ||||
| @ -242,41 +242,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                     $worksheetInfo[] = $tmpInfo; | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
| //                foreach ($workbookData->table as $worksheetDataSet) {
 | ||||
| //                    $worksheetData = $worksheetDataSet->children($namespacesContent['table']);
 | ||||
| //                    $worksheetDataAttributes = $worksheetDataSet->attributes($namespacesContent['table']);
 | ||||
| //
 | ||||
| //                    $rowIndex = 0;
 | ||||
| //                    foreach ($worksheetData as $key => $rowData) {
 | ||||
| //                        switch ($key) {
 | ||||
| //                            case 'table-row' :
 | ||||
| //                                $rowDataTableAttributes = $rowData->attributes($namespacesContent['table']);
 | ||||
| //                                $rowRepeats = (isset($rowDataTableAttributes['number-rows-repeated'])) ?
 | ||||
| //                                        $rowDataTableAttributes['number-rows-repeated'] : 1;
 | ||||
| //                                $columnIndex = 0;
 | ||||
| //
 | ||||
| //                                foreach ($rowData as $key => $cellData) {
 | ||||
| //                                    $cellDataTableAttributes = $cellData->attributes($namespacesContent['table']);
 | ||||
| //                                    $colRepeats = (isset($cellDataTableAttributes['number-columns-repeated'])) ?
 | ||||
| //                                        $cellDataTableAttributes['number-columns-repeated'] : 1;
 | ||||
| //                                    $cellDataOfficeAttributes = $cellData->attributes($namespacesContent['office']);
 | ||||
| //                                    if (isset($cellDataOfficeAttributes['value-type'])) {
 | ||||
| //                                        $tmpInfo['lastColumnIndex'] = max($tmpInfo['lastColumnIndex'], $columnIndex + $colRepeats - 1);
 | ||||
| //                                        $tmpInfo['totalRows'] = max($tmpInfo['totalRows'], $rowIndex + $rowRepeats);
 | ||||
| //                                    }
 | ||||
| //                                    $columnIndex += $colRepeats;
 | ||||
| //                                }
 | ||||
| //                                $rowIndex += $rowRepeats;
 | ||||
| //                                break;
 | ||||
| //                        }
 | ||||
| //                    }
 | ||||
| //
 | ||||
| //                    $tmpInfo['lastColumnLetter'] = \PhpSpreadsheet\Cell::stringFromColumnIndex($tmpInfo['lastColumnIndex']);
 | ||||
| //                    $tmpInfo['totalColumns'] = $tmpInfo['lastColumnIndex'] + 1;
 | ||||
| //
 | ||||
| //                }
 | ||||
| //            }
 | ||||
|         } | ||||
| 
 | ||||
|         return $worksheetInfo; | ||||
| @ -337,16 +302,12 @@ class OOCalc extends BaseReader implements IReader | ||||
|             throw new Exception('Could not open ' . $pFilename . ' for reading! Error opening file.'); | ||||
|         } | ||||
| 
 | ||||
| //        echo '<h1>Meta Information</h1>';
 | ||||
|         $xml = simplexml_load_string( | ||||
|             $this->securityScan($zip->getFromName('meta.xml')), | ||||
|             'SimpleXMLElement', | ||||
|             \PhpSpreadsheet\Settings::getLibXmlLoaderOptions() | ||||
|         ); | ||||
|         $namespacesMeta = $xml->getNamespaces(true); | ||||
| //        echo '<pre>';
 | ||||
| //        print_r($namespacesMeta);
 | ||||
| //        echo '</pre><hr />';
 | ||||
| 
 | ||||
|         $docProps = $spreadsheet->getProperties(); | ||||
|         $officeProperty = $xml->children($namespacesMeta['office']); | ||||
| @ -426,16 +387,12 @@ class OOCalc extends BaseReader implements IReader | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
| //        echo '<h1>Workbook Content</h1>';
 | ||||
|         $xml = simplexml_load_string( | ||||
|             $this->securityScan($zip->getFromName('content.xml')), | ||||
|             'SimpleXMLElement', | ||||
|             \PhpSpreadsheet\Settings::getLibXmlLoaderOptions() | ||||
|         ); | ||||
|         $namespacesContent = $xml->getNamespaces(true); | ||||
| //        echo '<pre>';
 | ||||
| //        print_r($namespacesContent);
 | ||||
| //        echo '</pre><hr />';
 | ||||
| 
 | ||||
|         $workbook = $xml->children($namespacesContent['office']); | ||||
|         foreach ($workbook->body->spreadsheet as $workbookData) { | ||||
| @ -443,17 +400,12 @@ class OOCalc extends BaseReader implements IReader | ||||
|             $worksheetID = 0; | ||||
|             foreach ($workbookData->table as $worksheetDataSet) { | ||||
|                 $worksheetData = $worksheetDataSet->children($namespacesContent['table']); | ||||
| //                print_r($worksheetData);
 | ||||
| //                echo '<br />';
 | ||||
|                 $worksheetDataAttributes = $worksheetDataSet->attributes($namespacesContent['table']); | ||||
| //                print_r($worksheetDataAttributes);
 | ||||
| //                echo '<br />';
 | ||||
|                 if ((isset($this->loadSheetsOnly)) && (isset($worksheetDataAttributes['name'])) && | ||||
|                     (!in_array($worksheetDataAttributes['name'], $this->loadSheetsOnly))) { | ||||
|                     continue; | ||||
|                 } | ||||
| 
 | ||||
| //                echo '<h2>Worksheet '.$worksheetDataAttributes['name'].'</h2>';
 | ||||
|                 // Create new Worksheet
 | ||||
|                 $spreadsheet->createSheet(); | ||||
|                 $spreadsheet->setActiveSheetIndex($worksheetID); | ||||
| @ -467,7 +419,6 @@ class OOCalc extends BaseReader implements IReader | ||||
| 
 | ||||
|                 $rowID = 1; | ||||
|                 foreach ($worksheetData as $key => $rowData) { | ||||
|                     //                    echo '<b>'.$key.'</b><br />';
 | ||||
|                     switch ($key) { | ||||
|                         case 'table-header-rows': | ||||
|                             foreach ($rowData as $keyRowData => $cellData) { | ||||
| @ -486,20 +437,11 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                     } | ||||
|                                 } | ||||
| 
 | ||||
| //                                echo '<b>'.$columnID.$rowID.'</b><br />';
 | ||||
|                                 $cellDataText = (isset($namespacesContent['text'])) ? $cellData->children($namespacesContent['text']) : ''; | ||||
|                                 $cellDataOffice = $cellData->children($namespacesContent['office']); | ||||
|                                 $cellDataOfficeAttributes = $cellData->attributes($namespacesContent['office']); | ||||
|                                 $cellDataTableAttributes = $cellData->attributes($namespacesContent['table']); | ||||
| 
 | ||||
| //                                echo 'Office Attributes: ';
 | ||||
| //                                print_r($cellDataOfficeAttributes);
 | ||||
| //                                echo '<br />Table Attributes: ';
 | ||||
| //                                print_r($cellDataTableAttributes);
 | ||||
| //                                echo '<br />Cell Data Text';
 | ||||
| //                                print_r($cellDataText);
 | ||||
| //                                echo '<br />';
 | ||||
| //
 | ||||
|                                 $type = $formatting = $hyperlink = null; | ||||
|                                 $hasCalculatedValue = false; | ||||
|                                 $cellDataFormula = ''; | ||||
| @ -509,7 +451,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                 } | ||||
| 
 | ||||
|                                 if (isset($cellDataOffice->annotation)) { | ||||
|                                     //                                    echo 'Cell has comment<br />';
 | ||||
|                                     $annotationText = $cellDataOffice->annotation->children($namespacesContent['text']); | ||||
|                                     $textArray = []; | ||||
|                                     foreach ($annotationText as $t) { | ||||
| @ -522,7 +463,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                         } | ||||
|                                     } | ||||
|                                     $text = implode("\n", $textArray); | ||||
| //                                    echo $text, '<br />';
 | ||||
|                                     $spreadsheet->getActiveSheet()->getComment($columnID . $rowID)->setText($this->parseRichText($text)); | ||||
| //                                                                    ->setAuthor( $author )
 | ||||
|                                 } | ||||
| @ -548,7 +488,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                     } | ||||
|                                     $allCellDataText = implode($dataArray, "\n"); | ||||
| 
 | ||||
| //                                    echo 'Value Type is '.$cellDataOfficeAttributes['value-type'].'<br />';
 | ||||
|                                     switch ($cellDataOfficeAttributes['value-type']) { | ||||
|                                         case 'string': | ||||
|                                             $type = \PhpSpreadsheet\Cell\DataType::TYPE_STRING; | ||||
| @ -608,10 +547,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                             $formatting = \PhpSpreadsheet\Style\NumberFormat::FORMAT_DATE_TIME4; | ||||
|                                             break; | ||||
|                                     } | ||||
| //                                    echo 'Data value is '.$dataValue.'<br />';
 | ||||
| //                                    if ($hyperlink !== null) {
 | ||||
| //                                        echo 'Hyperlink is '.$hyperlink.'<br />';
 | ||||
| //                                    }
 | ||||
|                                 } else { | ||||
|                                     $type = \PhpSpreadsheet\Cell\DataType::TYPE_NULL; | ||||
|                                     $dataValue = null; | ||||
| @ -619,7 +554,6 @@ class OOCalc extends BaseReader implements IReader | ||||
| 
 | ||||
|                                 if ($hasCalculatedValue) { | ||||
|                                     $type = \PhpSpreadsheet\Cell\DataType::TYPE_FORMULA; | ||||
| //                                    echo 'Formula: ', $cellDataFormula, PHP_EOL;
 | ||||
|                                     $cellDataFormula = substr($cellDataFormula, strpos($cellDataFormula, ':=') + 1); | ||||
|                                     $temp = explode('"', $cellDataFormula); | ||||
|                                     $tKey = false; | ||||
| @ -636,7 +570,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                     unset($value); | ||||
|                                     //    Then rebuild the formula string
 | ||||
|                                     $cellDataFormula = implode('"', $temp); | ||||
| //                                    echo 'Adjusted Formula: ', $cellDataFormula, PHP_EOL;
 | ||||
|                                 } | ||||
| 
 | ||||
|                                 $colRepeats = (isset($cellDataTableAttributes['number-columns-repeated'])) ? $cellDataTableAttributes['number-columns-repeated'] : 1; | ||||
| @ -650,7 +583,6 @@ class OOCalc extends BaseReader implements IReader | ||||
|                                                 $rID = $rowID + $rowAdjust; | ||||
|                                                 $spreadsheet->getActiveSheet()->getCell($columnID . $rID)->setValueExplicit((($hasCalculatedValue) ? $cellDataFormula : $dataValue), $type); | ||||
|                                                 if ($hasCalculatedValue) { | ||||
|                                                     //                                                    echo 'Forumla result is '.$dataValue.'<br />';
 | ||||
|                                                     $spreadsheet->getActiveSheet()->getCell($columnID . $rID)->setCalculatedValue($dataValue); | ||||
|                                                 } | ||||
|                                                 if ($formatting !== null) { | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\CodePage | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\Date | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\File | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\Font | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -309,13 +307,9 @@ class Font | ||||
| 
 | ||||
|         // Get corners positions
 | ||||
|         $lowerLeftCornerX = $textBox[0]; | ||||
| //        $lowerLeftCornerY  = $textBox[1];
 | ||||
|         $lowerRightCornerX = $textBox[2]; | ||||
| //        $lowerRightCornerY = $textBox[3];
 | ||||
|         $upperRightCornerX = $textBox[4]; | ||||
| //        $upperRightCornerY = $textBox[5];
 | ||||
|         $upperLeftCornerX = $textBox[6]; | ||||
| //        $upperLeftCornerY  = $textBox[7];
 | ||||
| 
 | ||||
|         // Consider the rotation when calculating the width
 | ||||
|         $textWidth = max($lowerRightCornerX - $upperLeftCornerX, $upperRightCornerX - $lowerLeftCornerX); | ||||
| @ -345,8 +339,6 @@ class Font | ||||
|                 break; | ||||
| 
 | ||||
|             case 'Arial': | ||||
|                 // value 7 was found via interpolation by inspecting real Excel files with Arial 10 font.
 | ||||
| //                $columnWidth = (int) (7 * String::countCharacters($columnText));
 | ||||
|                 // value 8 was set because of experience in different exports at Arial 10 font.
 | ||||
|                 $columnWidth = (int) (8 * StringHelper::countCharacters($columnText)); | ||||
|                 $columnWidth = $columnWidth * $fontSize / 10; // extrapolate from font size
 | ||||
|  | ||||
| @ -20,7 +20,6 @@ namespace PhpSpreadsheet\Shared; | ||||
| // | Based on OLE::Storage_Lite by Kawai, Takanori                        |
 | ||||
| // +----------------------------------------------------------------------+
 | ||||
| //
 | ||||
| // $Id: OLE.php,v 1.13 2007/03/07 14:38:25 schmidt Exp $
 | ||||
| 
 | ||||
| /* | ||||
| * Array for storing OLE instances that are accessed from | ||||
| @ -156,8 +155,7 @@ class OLE | ||||
|             $pos = $this->_getBlockOffset(self::_readInt4($fh)); | ||||
|         } | ||||
| 
 | ||||
|         // Read Big Block Allocation Table according to chain specified by
 | ||||
|         // $mbatBlocks
 | ||||
|         // Read Big Block Allocation Table according to chain specified by $mbatBlocks
 | ||||
|         for ($i = 0; $i < $bbatBlockCount; ++$i) { | ||||
|             $pos = $this->_getBlockOffset($mbatBlocks[$i]); | ||||
|             fseek($fh, $pos); | ||||
|  | ||||
| @ -20,7 +20,6 @@ namespace PhpSpreadsheet\Shared\OLE; | ||||
| // | Based on OLE::Storage_Lite by Kawai, Takanori                        |
 | ||||
| // +----------------------------------------------------------------------+
 | ||||
| //
 | ||||
| // $Id: PPS.php,v 1.7 2007/02/13 21:00:42 schmidt Exp $
 | ||||
| 
 | ||||
| /** | ||||
|  * Class for creating PPS's for OLE containers | ||||
| @ -151,13 +150,8 @@ class PPS | ||||
|         if (!isset($this->_data)) { | ||||
|             return 0; | ||||
|         } | ||||
|         //if (isset($this->_PPS_FILE)) {
 | ||||
|         //    fseek($this->_PPS_FILE, 0);
 | ||||
|         //    $stats = fstat($this->_PPS_FILE);
 | ||||
|         //    return $stats[7];
 | ||||
|         //} else {
 | ||||
|             return strlen($this->_data); | ||||
|         //}
 | ||||
| 
 | ||||
|         return strlen($this->_data); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|  | ||||
| @ -20,7 +20,6 @@ namespace PhpSpreadsheet\Shared\OLE\PPS; | ||||
| // | Based on OLE::Storage_Lite by Kawai, Takanori                        |
 | ||||
| // +----------------------------------------------------------------------+
 | ||||
| //
 | ||||
| // $Id: File.php,v 1.11 2007/02/13 21:00:42 schmidt Exp $
 | ||||
| 
 | ||||
| /** | ||||
|  * Class for creating File PPS's for OLE containers | ||||
|  | ||||
| @ -20,7 +20,6 @@ namespace PhpSpreadsheet\Shared\OLE\PPS; | ||||
| // | Based on OLE::Storage_Lite by Kawai, Takanori                        |
 | ||||
| // +----------------------------------------------------------------------+
 | ||||
| //
 | ||||
| // $Id: Root.php,v 1.9 2005/04/23 21:53:49 dufuz Exp $
 | ||||
| 
 | ||||
| /** | ||||
|  * Class for creating Root PPS's for OLE containers | ||||
| @ -260,17 +259,7 @@ class Root extends \PhpSpreadsheet\Shared\OLE\PPS | ||||
|             if ($raList[$i]->Type != \PhpSpreadsheet\Shared\OLE::OLE_PPS_TYPE_DIR) { | ||||
|                 $raList[$i]->Size = $raList[$i]->getDataLen(); | ||||
|                 if (($raList[$i]->Size >= \PhpSpreadsheet\Shared\OLE::OLE_DATA_SIZE_SMALL) || (($raList[$i]->Type == \PhpSpreadsheet\Shared\OLE::OLE_PPS_TYPE_ROOT) && isset($raList[$i]->_data))) { | ||||
|                     // Write Data
 | ||||
|                     //if (isset($raList[$i]->_PPS_FILE)) {
 | ||||
|                     //    $iLen = 0;
 | ||||
|                     //    fseek($raList[$i]->_PPS_FILE, 0); // To The Top
 | ||||
|                     //    while ($sBuff = fread($raList[$i]->_PPS_FILE, 4096)) {
 | ||||
|                     //        $iLen += strlen($sBuff);
 | ||||
|                     //        fwrite($FILE, $sBuff);
 | ||||
|                     //    }
 | ||||
|                     //} else {
 | ||||
|                         fwrite($FILE, $raList[$i]->_data); | ||||
|                     //}
 | ||||
|                     fwrite($FILE, $raList[$i]->_data); | ||||
| 
 | ||||
|                     if ($raList[$i]->Size % $this->_BIG_BLOCK_SIZE) { | ||||
|                         fwrite($FILE, str_repeat("\x00", $this->_BIG_BLOCK_SIZE - ($raList[$i]->Size % $this->_BIG_BLOCK_SIZE))); | ||||
| @ -281,12 +270,6 @@ class Root extends \PhpSpreadsheet\Shared\OLE\PPS | ||||
|                             (floor($raList[$i]->Size / $this->_BIG_BLOCK_SIZE) + | ||||
|                                 (($raList[$i]->Size % $this->_BIG_BLOCK_SIZE) ? 1 : 0)); | ||||
|                 } | ||||
|                 // Close file for each PPS, and unlink it
 | ||||
|                 //if (isset($raList[$i]->_PPS_FILE)) {
 | ||||
|                 //    fclose($raList[$i]->_PPS_FILE);
 | ||||
|                 //    $raList[$i]->_PPS_FILE = null;
 | ||||
|                 //    unlink($raList[$i]->_tmp_filename);
 | ||||
|                 //}
 | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @ -319,15 +302,8 @@ class Root extends \PhpSpreadsheet\Shared\OLE\PPS | ||||
|                     } | ||||
|                     fwrite($FILE, pack('V', -2)); | ||||
| 
 | ||||
|                     //// Add to Data String(this will be written for RootEntry)
 | ||||
|                     //if ($raList[$i]->_PPS_FILE) {
 | ||||
|                     //    fseek($raList[$i]->_PPS_FILE, 0); // To The Top
 | ||||
|                     //    while ($sBuff = fread($raList[$i]->_PPS_FILE, 4096)) {
 | ||||
|                     //        $sRes .= $sBuff;
 | ||||
|                     //    }
 | ||||
|                     //} else {
 | ||||
|                         $sRes .= $raList[$i]->_data; | ||||
|                     //}
 | ||||
|                     // Add to Data String(this will be written for RootEntry)
 | ||||
|                     $sRes .= $raList[$i]->_data; | ||||
|                     if ($raList[$i]->Size % $this->_SMALL_BLOCK_SIZE) { | ||||
|                         $sRes .= str_repeat("\x00", $this->_SMALL_BLOCK_SIZE - ($raList[$i]->Size % $this->_SMALL_BLOCK_SIZE)); | ||||
|                     } | ||||
|  | ||||
| @ -281,13 +281,11 @@ class OLERead | ||||
| 
 | ||||
|             // Summary information
 | ||||
|             if ($name == chr(5) . 'SummaryInformation') { | ||||
|                 //                echo 'Summary Information<br />';
 | ||||
|                 $this->summaryInformation = count($this->props) - 1; | ||||
|             } | ||||
| 
 | ||||
|             // Additional Document Summary information
 | ||||
|             if ($name == chr(5) . 'DocumentSummaryInformation') { | ||||
|                 //                echo 'Document Summary Information<br />';
 | ||||
|                 $this->documentSummaryInformation = count($this->props) - 1; | ||||
|             } | ||||
| 
 | ||||
|  | ||||
| @ -25,8 +25,6 @@ namespace PhpSpreadsheet\Shared\PCLZip; | ||||
| //     The use of this software is at the risk of the user.
 | ||||
| //
 | ||||
| // --------------------------------------------------------------------------------
 | ||||
| // $Id: PclZip.php,v 1.60 2009/09/30 21:01:04 vblavet Exp $
 | ||||
| // --------------------------------------------------------------------------------
 | ||||
| 
 | ||||
| // ----- Constants
 | ||||
| if (!defined('PCLZIP_READ_BLOCK_SIZE')) { | ||||
| @ -688,7 +686,6 @@ class PclZip | ||||
| 
 | ||||
|         // ----- Set default values
 | ||||
|         $v_options = []; | ||||
|     //        $v_path = "./";
 | ||||
|         $v_path = ''; | ||||
|         $v_remove_path = ''; | ||||
|         $v_remove_all_path = false; | ||||
| @ -839,7 +836,6 @@ class PclZip | ||||
| 
 | ||||
|         // ----- Set default values
 | ||||
|         $v_options = []; | ||||
|     //        $v_path = "./";
 | ||||
|         $v_path = ''; | ||||
|         $v_remove_path = ''; | ||||
|         $v_remove_all_path = false; | ||||
| @ -2726,7 +2722,6 @@ class PclZip | ||||
|         while ($v_size != 0) { | ||||
|             $v_read_size = ($v_size < PCLZIP_READ_BLOCK_SIZE ? $v_size : PCLZIP_READ_BLOCK_SIZE); | ||||
|             $v_buffer = @fread($v_file_compressed, $v_read_size); | ||||
|             //$v_binary_data = pack('a'.$v_read_size, $v_buffer);
 | ||||
|             @fwrite($this->zip_fd, $v_buffer, $v_read_size); | ||||
|             $v_size -= $v_read_size; | ||||
|         } | ||||
| @ -3690,7 +3685,6 @@ class PclZip | ||||
|         while ($v_size != 0) { | ||||
|             $v_read_size = ($v_size < PCLZIP_READ_BLOCK_SIZE ? $v_size : PCLZIP_READ_BLOCK_SIZE); | ||||
|             $v_buffer = @gzread($v_src_file, $v_read_size); | ||||
|             //$v_binary_data = pack('a'.$v_read_size, $v_buffer);
 | ||||
|             @fwrite($v_dest_file, $v_buffer, $v_read_size); | ||||
|             $v_size -= $v_read_size; | ||||
|         } | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\PasswordHasher | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\StringHelper | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -43,7 +41,7 @@ class StringHelper | ||||
|     /** | ||||
|      * SYLK Characters array | ||||
|      * | ||||
|      * $var array | ||||
|      * @var array | ||||
|      */ | ||||
|     private static $SYLKCharacters = []; | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\TimeZone | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -398,11 +398,9 @@ class BestFit | ||||
|         } | ||||
| 
 | ||||
|         // calculate slope
 | ||||
| //        $this->slope = (($this->valueCount * $xy_sum) - ($x_sum * $y_sum)) / (($this->valueCount * $xx_sum) - ($x_sum * $x_sum));
 | ||||
|         $this->slope = $mBase / $mDivisor; | ||||
| 
 | ||||
|         // calculate intersect
 | ||||
| //        $this->intersect = ($y_sum - ($this->slope * $x_sum)) / $this->valueCount;
 | ||||
|         if ($const) { | ||||
|             $this->intersect = $meanY - ($this->slope * $meanX); | ||||
|         } else { | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Shared\Trend; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Shared\Trend\powerBestFit | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Style; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Style\NumberFormat | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -688,7 +686,6 @@ class NumberFormat extends Supervisor implements \PhpSpreadsheet\IComparable | ||||
|                 } | ||||
| 
 | ||||
|                 if (preg_match('/#?.*\?\/\?/', $format, $m)) { | ||||
|                     //echo 'Format mask is fractional '.$format.' <br />';
 | ||||
|                     if ($value != (int) $value) { | ||||
|                         self::formatAsFraction($value, $format); | ||||
|                     } | ||||
|  | ||||
| @ -2647,15 +2647,7 @@ class Worksheet implements IComparable | ||||
|     { | ||||
|         // Flush cache
 | ||||
|         $this->cellCollection->getCacheData('A1'); | ||||
|         // Build a reference table from images
 | ||||
| //        $imageCoordinates = array();
 | ||||
| //        $iterator = $this->getDrawingCollection()->getIterator();
 | ||||
| //        while ($iterator->valid()) {
 | ||||
| //            $imageCoordinates[$iterator->current()->getCoordinates()] = true;
 | ||||
| //
 | ||||
| //            $iterator->next();
 | ||||
| //        }
 | ||||
| //
 | ||||
| 
 | ||||
|         // Lookup highest column and highest row if cells are cleaned
 | ||||
|         $colRow = $this->cellCollection->getHighestRowAndColumn(); | ||||
|         $highestRow = $colRow['row']; | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\AutoFilter | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -593,7 +591,6 @@ class AutoFilter | ||||
|         list($rangeStart, $rangeEnd) = \PhpSpreadsheet\Cell::rangeBoundaries($this->range); | ||||
| 
 | ||||
|         //    The heading row should always be visible
 | ||||
| //        echo 'AutoFilter Heading Row ', $rangeStart[1],' is always SHOWN',PHP_EOL;
 | ||||
|         $this->workSheet->getRowDimension($rangeStart[1])->setVisible(true); | ||||
| 
 | ||||
|         $columnFilterTests = []; | ||||
| @ -774,31 +771,23 @@ class AutoFilter | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
| //        echo 'Column Filter Test CRITERIA',PHP_EOL;
 | ||||
| //        var_dump($columnFilterTests);
 | ||||
| //
 | ||||
|         //    Execute the column tests for each row in the autoFilter range to determine show/hide,
 | ||||
|         for ($row = $rangeStart[1] + 1; $row <= $rangeEnd[1]; ++$row) { | ||||
|             //            echo 'Testing Row = ', $row,PHP_EOL;
 | ||||
|             $result = true; | ||||
|             foreach ($columnFilterTests as $columnID => $columnFilterTest) { | ||||
|                 //                echo 'Testing cell ', $columnID.$row,PHP_EOL;
 | ||||
|                 $cellValue = $this->workSheet->getCell($columnID . $row)->getCalculatedValue(); | ||||
| //                echo 'Value is ', $cellValue,PHP_EOL;
 | ||||
|                 //    Execute the filter test
 | ||||
|                 $result = $result && | ||||
|                     call_user_func_array( | ||||
|                         ['\\PhpSpreadsheet\\Worksheet\\AutoFilter', $columnFilterTest['method']], | ||||
|                         [$cellValue, $columnFilterTest['arguments']] | ||||
|                     ); | ||||
| //                echo (($result) ? 'VALID' : 'INVALID'),PHP_EOL;
 | ||||
|                 //    If filter test has resulted in FALSE, exit the loop straightaway rather than running any more tests
 | ||||
|                 if (!$result) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|             //    Set show/hide for the row based on the result of the autoFilter result
 | ||||
| //            echo (($result) ? 'SHOW' : 'HIDE'),PHP_EOL;
 | ||||
|             $this->workSheet->getRowDimension($row)->setVisible($result); | ||||
|         } | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet\AutoFilter; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\AutoFilter\Column | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet\AutoFilter\Column; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\AutoFilter\Column\Rule | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_BaseDrawing | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_CellIterator | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\Column | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\ColumnCellIterator | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\ColumnDimension | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -6,8 +6,6 @@ use PhpSpreadsheet\Cell; | ||||
| use PhpSpreadsheet\Exception; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\ColumnIterator | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_Dimension | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_Drawing | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet\Drawing; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_Drawing_Shadow | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_HeaderFooter | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_HeaderFooterDrawing | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_MemoryDrawing | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\PageMargins | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\PageSetup | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_Protection | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\Row | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\RowCellIterator | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\RowDimension | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet\RowIterator | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Worksheet; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Worksheet_SheetView | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\BaseWriter | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2016 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -310,10 +310,6 @@ class Chart extends WriterPart | ||||
|             } | ||||
| 
 | ||||
|             //    Generate 2 unique numbers to use for axId values
 | ||||
|             //                    $id1 = $id2 = rand(10000000,99999999);
 | ||||
|             //                    do {
 | ||||
|             //                        $id2 = rand(10000000,99999999);
 | ||||
|             //                    } while ($id1 == $id2);
 | ||||
|             $id1 = '75091328'; | ||||
|             $id2 = '75089408'; | ||||
| 
 | ||||
| @ -458,7 +454,6 @@ class Chart extends WriterPart | ||||
|                 $caption = $caption[0]; | ||||
|             } | ||||
|             $objWriter->startElement('a:t'); | ||||
|             //                                        $objWriter->writeAttribute('xml:space', 'preserve');
 | ||||
|             $objWriter->writeRawData(\PhpSpreadsheet\Shared\StringHelper::controlCharacterPHP2OOXML($caption)); | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
| @ -808,7 +803,6 @@ class Chart extends WriterPart | ||||
|             } | ||||
| 
 | ||||
|             $objWriter->startElement('a:t'); | ||||
|             //                                        $objWriter->writeAttribute('xml:space', 'preserve');
 | ||||
|             $objWriter->writeRawData(\PhpSpreadsheet\Shared\StringHelper::controlCharacterPHP2OOXML($caption)); | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
|  | ||||
| @ -240,9 +240,6 @@ class Comments extends WriterPart | ||||
|                 // x:SizeWithCells
 | ||||
|                 $objWriter->writeElement('x:SizeWithCells', ''); | ||||
| 
 | ||||
|                 // x:Anchor
 | ||||
|                 //$objWriter->writeElement('x:Anchor', $column . ', 15, ' . ($row - 2) . ', 10, ' . ($column + 4) . ', 15, ' . ($row + 5) . ', 18');
 | ||||
| 
 | ||||
|                 // x:AutoFill
 | ||||
|                 $objWriter->writeElement('x:AutoFill', 'False'); | ||||
| 
 | ||||
|  | ||||
| @ -242,47 +242,6 @@ class Drawing extends WriterPart | ||||
| 
 | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
| //                        // a:solidFill
 | ||||
| //                        $objWriter->startElement('a:solidFill');
 | ||||
| 
 | ||||
| //                            // a:srgbClr
 | ||||
| //                            $objWriter->startElement('a:srgbClr');
 | ||||
| //                            $objWriter->writeAttribute('val', 'FFFFFF');
 | ||||
| 
 | ||||
| ///* SHADE
 | ||||
| //                                // a:shade
 | ||||
| //                                $objWriter->startElement('a:shade');
 | ||||
| //                                $objWriter->writeAttribute('val', '85000');
 | ||||
| //                                $objWriter->endElement();
 | ||||
| //*/
 | ||||
| 
 | ||||
| //                            $objWriter->endElement();
 | ||||
| 
 | ||||
| //                        $objWriter->endElement();
 | ||||
| /* | ||||
|             // a:ln
 | ||||
|             $objWriter->startElement('a:ln'); | ||||
|             $objWriter->writeAttribute('w', '88900'); | ||||
|             $objWriter->writeAttribute('cap', 'sq'); | ||||
| 
 | ||||
|                 // a:solidFill
 | ||||
|                 $objWriter->startElement('a:solidFill'); | ||||
| 
 | ||||
|                     // a:srgbClr
 | ||||
|                     $objWriter->startElement('a:srgbClr'); | ||||
|                     $objWriter->writeAttribute('val', 'FFFFFF'); | ||||
|                     $objWriter->endElement(); | ||||
| 
 | ||||
|                 $objWriter->endElement(); | ||||
| 
 | ||||
|                 // a:miter
 | ||||
|                 $objWriter->startElement('a:miter'); | ||||
|                 $objWriter->writeAttribute('lim', '800000'); | ||||
|                 $objWriter->endElement(); | ||||
| 
 | ||||
|             $objWriter->endElement(); | ||||
| */ | ||||
| 
 | ||||
|             if ($pDrawing->getShadow()->getVisible()) { | ||||
|                 // a:effectLst
 | ||||
|                 $objWriter->startElement('a:effectLst'); | ||||
|  | ||||
| @ -221,21 +221,6 @@ class Rels extends WriterPart | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|         // Write chart relationships?
 | ||||
| //            $chartCount = 0;
 | ||||
| //            $charts = $pWorksheet->getChartCollection();
 | ||||
| //            echo 'Chart Rels: ' , count($charts) , '<br />';
 | ||||
| //            if (count($charts) > 0) {
 | ||||
| //                foreach ($charts as $chart) {
 | ||||
| //                    $this->writeRelationship(
 | ||||
| //                        $objWriter,
 | ||||
| //                        ++$d,
 | ||||
| //                        'http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart',
 | ||||
| //                        '../charts/chart' . ++$chartCount . '.xml'
 | ||||
| //                    );
 | ||||
| //                }
 | ||||
| //            }
 | ||||
| //
 | ||||
|         // Write hyperlink relationships?
 | ||||
|         $i = 1; | ||||
|         foreach ($pWorksheet->getHyperlinkCollection() as $hyperlink) { | ||||
|  | ||||
| @ -264,22 +264,10 @@ class StringTable extends WriterPart | ||||
|             $objWriter->writeAttribute('typeface', $element->getFont()->getName()); | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
|                 // Superscript / subscript
 | ||||
| //                    if ($element->getFont()->getSuperScript() || $element->getFont()->getSubScript()) {
 | ||||
| //                        $objWriter->startElement($prefix.'vertAlign');
 | ||||
| //                        if ($element->getFont()->getSuperScript()) {
 | ||||
| //                            $objWriter->writeAttribute('val', 'superscript');
 | ||||
| //                        } elseif ($element->getFont()->getSubScript()) {
 | ||||
| //                            $objWriter->writeAttribute('val', 'subscript');
 | ||||
| //                        }
 | ||||
| //                        $objWriter->endElement();
 | ||||
| //                    }
 | ||||
| //
 | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
|             // t
 | ||||
|             $objWriter->startElement($prefix . 't'); | ||||
| //                    $objWriter->writeAttribute('xml:space', 'preserve');    //    Excel2010 accepts, Excel2007 complains
 | ||||
|             $objWriter->writeRawData(\PhpSpreadsheet\Shared\StringHelper::controlCharacterPHP2OOXML($element->getText())); | ||||
|             $objWriter->endElement(); | ||||
| 
 | ||||
|  | ||||
| @ -145,7 +145,6 @@ class Worksheet extends WriterPart | ||||
|     { | ||||
|         // sheetPr
 | ||||
|         $objWriter->startElement('sheetPr'); | ||||
|         //$objWriter->writeAttribute('codeName',        $pSheet->getTitle());
 | ||||
|         if ($pSheet->getParent()->hasMacros()) { | ||||
|             //if the workbook have macros, we need to have codeName for the sheet
 | ||||
|             if ($pSheet->hasCodeName() == false) { | ||||
| @ -1125,7 +1124,6 @@ class Worksheet extends WriterPart | ||||
|                         } | ||||
|                         if ($this->getParentWriter()->getOffice2003Compatibility() === false) { | ||||
|                             if ($this->getParentWriter()->getPreCalculateFormulas()) { | ||||
|                                 //                                $calculatedValue = $pCell->getCalculatedValue();
 | ||||
|                                 if (!is_array($calculatedValue) && substr($calculatedValue, 0, 1) != '#') { | ||||
|                                     $objWriter->writeElement('v', \PhpSpreadsheet\Shared\StringHelper::formatNumber($calculatedValue)); | ||||
|                                 } else { | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel2007; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel2007\WriterPart | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5 | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\BIFFwriter | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -94,7 +92,6 @@ class BIFFwriter | ||||
|     { | ||||
|         $this->_data = ''; | ||||
|         $this->_datasize = 0; | ||||
| //        $this->limit      = 8224;
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Escher | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -292,7 +290,6 @@ class Escher | ||||
|                 // number of shapes in this drawing (including group shape)
 | ||||
|                 $countShapes = count($this->object->getSpgrContainer()->getChildren()); | ||||
|                 $innerData .= $header . pack('VV', $countShapes, $this->object->getLastSpId()); | ||||
|                 //$innerData .= $header . pack('VV', 0, 0);
 | ||||
| 
 | ||||
|                 // write the spgrContainer
 | ||||
|                 if ($spgrContainer = $this->object->getSpgrContainer()) { | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Font | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Parser | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -592,7 +590,6 @@ class Parser | ||||
|     private function convertFunction($token, $num_args) | ||||
|     { | ||||
|         $args = $this->functions[$token][1]; | ||||
| //        $volatile = $this->functions[$token][3];
 | ||||
| 
 | ||||
|         // Fixed number of args eg. TIME($i, $j, $k).
 | ||||
|         if ($args >= 0) { | ||||
| @ -650,8 +647,6 @@ class Parser | ||||
|      */ | ||||
|     private function convertRange3d($token) | ||||
|     { | ||||
|         //        $class = 0; // formulas like Sheet1!$A$1:$A$2 in list type data validation need this class (0x3B)
 | ||||
| 
 | ||||
|         // Split the ref at the ! symbol
 | ||||
|         list($ext_ref, $range) = explode('!', $token); | ||||
| 
 | ||||
| @ -670,15 +665,7 @@ class Parser | ||||
|         } | ||||
| 
 | ||||
|         // The ptg value depends on the class of the ptg.
 | ||||
| //        if ($class == 0) {
 | ||||
|             $ptgArea = pack('C', $this->ptg['ptgArea3d']); | ||||
| //        } elseif ($class == 1) {
 | ||||
| //            $ptgArea = pack("C", $this->ptg['ptgArea3dV']);
 | ||||
| //        } elseif ($class == 2) {
 | ||||
| //            $ptgArea = pack("C", $this->ptg['ptgArea3dA']);
 | ||||
| //        } else {
 | ||||
| //            throw new \PhpSpreadsheet\Writer\Exception("Unknown class $class");
 | ||||
| //        }
 | ||||
|         $ptgArea = pack('C', $this->ptg['ptgArea3d']); | ||||
| 
 | ||||
|         return $ptgArea . $ext_ref . $row1 . $row2 . $col1 . $col2; | ||||
|     } | ||||
| @ -691,23 +678,13 @@ class Parser | ||||
|      */ | ||||
|     private function convertRef2d($cell) | ||||
|     { | ||||
|         //        $class = 2; // as far as I know, this is magick.
 | ||||
| 
 | ||||
|         // Convert the cell reference
 | ||||
|         $cell_array = $this->cellToPackedRowcol($cell); | ||||
|         list($row, $col) = $cell_array; | ||||
| 
 | ||||
|         // The ptg value depends on the class of the ptg.
 | ||||
| //        if ($class == 0) {
 | ||||
| //            $ptgRef = pack("C", $this->ptg['ptgRef']);
 | ||||
| //        } elseif ($class == 1) {
 | ||||
| //            $ptgRef = pack("C", $this->ptg['ptgRefV']);
 | ||||
| //        } elseif ($class == 2) {
 | ||||
|             $ptgRef = pack('C', $this->ptg['ptgRefA']); | ||||
| //        } else {
 | ||||
| //            // TODO: use real error codes
 | ||||
| //            throw new \PhpSpreadsheet\Writer\Exception("Unknown class $class");
 | ||||
| //        }
 | ||||
|         $ptgRef = pack('C', $this->ptg['ptgRefA']); | ||||
| 
 | ||||
|         return $ptgRef . $row . $col; | ||||
|     } | ||||
| 
 | ||||
| @ -720,8 +697,6 @@ class Parser | ||||
|      */ | ||||
|     private function convertRef3d($cell) | ||||
|     { | ||||
|         //        $class = 2; // as far as I know, this is magick.
 | ||||
| 
 | ||||
|         // Split the ref at the ! symbol
 | ||||
|         list($ext_ref, $cell) = explode('!', $cell); | ||||
| 
 | ||||
| @ -732,15 +707,7 @@ class Parser | ||||
|         list($row, $col) = $this->cellToPackedRowcol($cell); | ||||
| 
 | ||||
|         // The ptg value depends on the class of the ptg.
 | ||||
| //        if ($class == 0) {
 | ||||
| //            $ptgRef = pack("C", $this->ptg['ptgRef3d']);
 | ||||
| //        } elseif ($class == 1) {
 | ||||
| //            $ptgRef = pack("C", $this->ptg['ptgRef3dV']);
 | ||||
| //        } elseif ($class == 2) {
 | ||||
|             $ptgRef = pack('C', $this->ptg['ptgRef3dA']); | ||||
| //        } else {
 | ||||
| //            throw new \PhpSpreadsheet\Writer\Exception("Unknown class $class");
 | ||||
| //        }
 | ||||
|         $ptgRef = pack('C', $this->ptg['ptgRef3dA']); | ||||
| 
 | ||||
|         return $ptgRef . $ext_ref . $row . $col; | ||||
|     } | ||||
| @ -1034,9 +1001,6 @@ class Parser | ||||
|             } | ||||
| 
 | ||||
|             if ($this->match($token) != '') { | ||||
|                 //if ($i < strlen($this->formula) - 1) {
 | ||||
|                 //    $this->lookAhead = $this->formula{$i+1};
 | ||||
|                 //}
 | ||||
|                 $this->currentCharacter = $i + 1; | ||||
|                 $this->currentToken = $token; | ||||
| 
 | ||||
| @ -1355,7 +1319,6 @@ class Parser | ||||
|         } elseif (preg_match('/^' . self::REGEX_SHEET_TITLE_UNQUOTED . "(\:" . self::REGEX_SHEET_TITLE_UNQUOTED . ")?\!\\$?([A-Ia-i]?[A-Za-z])?\\$?[0-9]+:\\$?([A-Ia-i]?[A-Za-z])?\\$?[0-9]+$/u", $this->currentToken)) { | ||||
|             // If it's an external range (Sheet1!A1:B2 or Sheet1:Sheet2!A1:B2 or Sheet1!$A$1:$B$2 or Sheet1:Sheet2!$A$1:$B$2)
 | ||||
|             // must be an error?
 | ||||
|             //$result = $this->currentToken;
 | ||||
|             $result = $this->createTree($this->currentToken, '', ''); | ||||
|             $this->advance(); | ||||
| 
 | ||||
| @ -1363,7 +1326,6 @@ class Parser | ||||
|         } elseif (preg_match("/^'" . self::REGEX_SHEET_TITLE_QUOTED . "(\:" . self::REGEX_SHEET_TITLE_QUOTED . ")?'\!\\$?([A-Ia-i]?[A-Za-z])?\\$?[0-9]+:\\$?([A-Ia-i]?[A-Za-z])?\\$?[0-9]+$/u", $this->currentToken)) { | ||||
|             // If it's an external range ('Sheet1'!A1:B2 or 'Sheet1'!A1:B2 or 'Sheet1'!$A$1:$B$2 or 'Sheet1'!$A$1:$B$2)
 | ||||
|             // must be an error?
 | ||||
|             //$result = $this->currentToken;
 | ||||
|             $result = $this->createTree($this->currentToken, '', ''); | ||||
|             $this->advance(); | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Workbook | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -210,8 +208,6 @@ class Workbook extends BIFFwriter | ||||
| 
 | ||||
|         $this->spreadsheet = $spreadsheet; | ||||
| 
 | ||||
|         // set BIFFwriter limit for CONTINUE records
 | ||||
|         //        $this->_limit = 8224;
 | ||||
|         $this->codepage = 0x04B0; | ||||
| 
 | ||||
|         // Add empty sheets and Build color cache
 | ||||
| @ -1228,7 +1224,7 @@ class Workbook extends BIFFwriter | ||||
|         $header = pack('vv', $record, $length); | ||||
|         /* using the same country code always for simplicity */ | ||||
|         $data = pack('vv', $this->countryCode, $this->countryCode); | ||||
|         //$this->append($header . $data);
 | ||||
| 
 | ||||
|         return $this->writeData($header . $data); | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Worksheet | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
| @ -209,9 +207,6 @@ class Worksheet extends BIFFwriter | ||||
|         // It needs to call its parent's constructor explicitly
 | ||||
|         parent::__construct(); | ||||
| 
 | ||||
|         // change BIFFwriter limit for CONTINUE records
 | ||||
| //        $this->_limit = 8224;
 | ||||
| 
 | ||||
|         $this->_preCalculateFormulas = $preCalculateFormulas; | ||||
|         $this->stringTotal = &$str_total; | ||||
|         $this->stringUnique = &$str_unique; | ||||
| @ -221,8 +216,6 @@ class Worksheet extends BIFFwriter | ||||
| 
 | ||||
|         $this->phpSheet = $phpSheet; | ||||
| 
 | ||||
|         //$this->ext_sheets        = array();
 | ||||
|         //$this->offset            = 0;
 | ||||
|         $this->xlsStringMaxLength = 255; | ||||
|         $this->columnInfo = []; | ||||
|         $this->selection = [0, 0, 0, 0]; | ||||
| @ -245,7 +238,6 @@ class Worksheet extends BIFFwriter | ||||
|         $maxC = $this->phpSheet->getHighestColumn(); | ||||
| 
 | ||||
|         // Determine lowest and highest column and row
 | ||||
| //        $this->firstRowIndex = ($minR > 65535) ? 65535 : $minR;
 | ||||
|         $this->lastRowIndex = ($maxR > 65535) ? 65535 : $maxR; | ||||
| 
 | ||||
|         $this->firstColumnIndex = \PhpSpreadsheet\Cell::columnIndexFromString($minC); | ||||
| @ -398,7 +390,6 @@ class Worksheet extends BIFFwriter | ||||
| 
 | ||||
|             $cVal = $cell->getValue(); | ||||
|             if ($cVal instanceof \PhpSpreadsheet\RichText) { | ||||
|                 // $this->writeString($row, $column, $cVal->getPlainText(), $xfIndex);
 | ||||
|                 $arrcRun = []; | ||||
|                 $str_len = \PhpSpreadsheet\Shared\StringHelper::countCharacters($cVal->getPlainText(), 'UTF-8'); | ||||
|                 $str_pos = 0; | ||||
| @ -479,7 +470,6 @@ class Worksheet extends BIFFwriter | ||||
|                 $url = str_replace('sheet://', 'internal:', $url); | ||||
|             } elseif (preg_match('/^(http:|https:|ftp:|mailto:)/', $url)) { | ||||
|                 // URL
 | ||||
|                 // $url = $url;
 | ||||
|             } else { | ||||
|                 // external (local file)
 | ||||
|                 $url = 'external:' . $url; | ||||
| @ -2305,7 +2295,7 @@ class Worksheet extends BIFFwriter | ||||
|     public function insertBitmap($row, $col, $bitmap, $x = 0, $y = 0, $scale_x = 1, $scale_y = 1) | ||||
|     { | ||||
|         $bitmap_array = (is_resource($bitmap) ? $this->processBitmapGd($bitmap) : $this->processBitmap($bitmap)); | ||||
|         list($width, $height, $size, $data) = $bitmap_array; //$this->processBitmap($bitmap);
 | ||||
|         list($width, $height, $size, $data) = $bitmap_array; | ||||
| 
 | ||||
|         // Scale the frame of the image.
 | ||||
|         $width *= $scale_x; | ||||
| @ -2606,7 +2596,6 @@ class Worksheet extends BIFFwriter | ||||
|         $compression = unpack('Vcomp', substr($data, 0, 4)); | ||||
|         $data = substr($data, 4); | ||||
| 
 | ||||
|         //$compression = 0;
 | ||||
|         if ($compression['comp'] != 0) { | ||||
|             throw new \PhpSpreadsheet\Writer\Exception("$bitmap: compression not supported in bitmap image.\n"); | ||||
|         } | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer\Excel5; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Excel5\Xf | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -3,8 +3,6 @@ | ||||
| namespace PhpSpreadsheet\Writer; | ||||
| 
 | ||||
| /** | ||||
|  * \PhpSpreadsheet\Writer\Exception | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2015 PhpSpreadsheet | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  | ||||
| @ -1035,8 +1035,6 @@ class HTML extends BaseWriter implements IWriter | ||||
|      */ | ||||
|     private function createCSSStyleBorder(\Spreadsheet\Style\Border $pStyle) | ||||
|     { | ||||
|         // Create CSS
 | ||||
| //        $css = $this->mapBorderStyle($pStyle->getBorderStyle()) . ' #' . $pStyle->getColor()->getRGB();
 | ||||
|         //    Create CSS - add !important to non-none border styles for merged cells
 | ||||
|         $borderStyle = $this->mapBorderStyle($pStyle->getBorderStyle()); | ||||
|         $css = $borderStyle . ' #' . $pStyle->getColor()->getRGB() . (($borderStyle == 'none') ? '' : ' !important'); | ||||
|  | ||||
| @ -43,19 +43,12 @@ class Comment | ||||
|         $comment = $comments[$cell->getCoordinate()]; | ||||
| 
 | ||||
|         $objWriter->startElement('office:annotation'); | ||||
|             //$objWriter->writeAttribute('draw:style-name', 'gr1');
 | ||||
|             //$objWriter->writeAttribute('draw:text-style-name', 'P1');
 | ||||
|             $objWriter->writeAttribute('svg:width', $comment->getWidth()); | ||||
|         $objWriter->writeAttribute('svg:width', $comment->getWidth()); | ||||
|         $objWriter->writeAttribute('svg:height', $comment->getHeight()); | ||||
|         $objWriter->writeAttribute('svg:x', $comment->getMarginLeft()); | ||||
|         $objWriter->writeAttribute('svg:y', $comment->getMarginTop()); | ||||
|             //$objWriter->writeAttribute('draw:caption-point-x', $comment->getMarginLeft());
 | ||||
|             //$objWriter->writeAttribute('draw:caption-point-y', $comment->getMarginTop());
 | ||||
|                 $objWriter->writeElement('dc:creator', $comment->getAuthor()); | ||||
|                 // TODO: Not realized in \PhpSpreadsheet\Comment yet.
 | ||||
|                 //$objWriter->writeElement('dc:date', $comment->getDate());
 | ||||
|                 $objWriter->writeElement('text:p', $comment->getText()->getPlainText()); | ||||
|                     //$objWriter->writeAttribute('draw:text-style-name', 'P1');
 | ||||
|         $objWriter->writeElement('dc:creator', $comment->getAuthor()); | ||||
|         $objWriter->writeElement('text:p', $comment->getText()->getPlainText()); | ||||
|         $objWriter->endElement(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -123,7 +123,6 @@ class Content extends WriterPart | ||||
| 
 | ||||
|         $sheet_count = $spreadsheet->getSheetCount(); | ||||
|         for ($i = 0; $i < $sheet_count; ++$i) { | ||||
|             //$this->getWriterPart('Worksheet')->writeWorksheet());
 | ||||
|             $objWriter->startElement('table:table'); | ||||
|             $objWriter->writeAttribute('table:name', $spreadsheet->getSheet($i)->getTitle()); | ||||
|             $objWriter->writeElement('office:forms'); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Adrien Crivelli
						Adrien Crivelli