Apply Scrutinizer patches for indentation
This commit is contained in:
parent
a85f1bdbed
commit
cb0930c016
@ -232,7 +232,7 @@ class Calculation
|
||||
'NULL' => null,
|
||||
];
|
||||
|
||||
// PhpSpreadsheet functions
|
||||
// PhpSpreadsheet functions
|
||||
private static $phpSpreadsheetFunctions = [
|
||||
'ABS' => [
|
||||
'category' => Calculation\Categories::CATEGORY_MATH_AND_TRIG,
|
||||
@ -3073,13 +3073,13 @@ class Calculation
|
||||
$pCellParent = ($pCell !== null) ? $pCell->getWorksheet() : null;
|
||||
|
||||
$regexpMatchString = '/^(' . self::CALCULATION_REGEXP_FUNCTION .
|
||||
'|' . self::CALCULATION_REGEXP_CELLREF .
|
||||
'|' . self::CALCULATION_REGEXP_NUMBER .
|
||||
'|' . self::CALCULATION_REGEXP_STRING .
|
||||
'|' . self::CALCULATION_REGEXP_OPENBRACE .
|
||||
'|' . self::CALCULATION_REGEXP_NAMEDRANGE .
|
||||
'|' . self::CALCULATION_REGEXP_ERROR .
|
||||
')/si';
|
||||
'|' . self::CALCULATION_REGEXP_CELLREF .
|
||||
'|' . self::CALCULATION_REGEXP_NUMBER .
|
||||
'|' . self::CALCULATION_REGEXP_STRING .
|
||||
'|' . self::CALCULATION_REGEXP_OPENBRACE .
|
||||
'|' . self::CALCULATION_REGEXP_NAMEDRANGE .
|
||||
'|' . self::CALCULATION_REGEXP_ERROR .
|
||||
')/si';
|
||||
|
||||
// Start with initialisation
|
||||
$index = 0;
|
||||
|
@ -497,7 +497,7 @@ class FormulaParser
|
||||
(($previousToken->getTokenType() == FormulaToken::TOKEN_TYPE_FUNCTION) && ($previousToken->getTokenSubType() == FormulaToken::TOKEN_SUBTYPE_STOP)) ||
|
||||
(($previousToken->getTokenType() == FormulaToken::TOKEN_TYPE_SUBEXPRESSION) && ($previousToken->getTokenSubType() == FormulaToken::TOKEN_SUBTYPE_STOP)) ||
|
||||
($previousToken->getTokenType() == FormulaToken::TOKEN_TYPE_OPERAND)
|
||||
)) {
|
||||
)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -509,7 +509,7 @@ class FormulaParser
|
||||
(($nextToken->getTokenType() == FormulaToken::TOKEN_TYPE_FUNCTION) && ($nextToken->getTokenSubType() == FormulaToken::TOKEN_SUBTYPE_START)) ||
|
||||
(($nextToken->getTokenType() == FormulaToken::TOKEN_TYPE_SUBEXPRESSION) && ($nextToken->getTokenSubType() == FormulaToken::TOKEN_SUBTYPE_START)) ||
|
||||
($nextToken->getTokenType() == FormulaToken::TOKEN_TYPE_OPERAND)
|
||||
)) {
|
||||
)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -845,11 +845,11 @@ class Cell
|
||||
$_indexCache[$pColumnIndex] = chr(65 + $pColumnIndex);
|
||||
} elseif ($pColumnIndex < 702) {
|
||||
$_indexCache[$pColumnIndex] = chr(64 + ($pColumnIndex / 26)) .
|
||||
chr(65 + $pColumnIndex % 26);
|
||||
chr(65 + $pColumnIndex % 26);
|
||||
} else {
|
||||
$_indexCache[$pColumnIndex] = chr(64 + (($pColumnIndex - 26) / 676)) .
|
||||
chr(65 + ((($pColumnIndex - 26) % 676) / 26)) .
|
||||
chr(65 + $pColumnIndex % 26);
|
||||
chr(65 + ((($pColumnIndex - 26) % 676) / 26)) .
|
||||
chr(65 + $pColumnIndex % 26);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -76,7 +76,7 @@ class GridLines extends Properties
|
||||
|
||||
private $softEdges = [
|
||||
'size' => null,
|
||||
];
|
||||
];
|
||||
|
||||
/**
|
||||
* Get Object State
|
||||
|
@ -253,9 +253,10 @@ class CSV extends BaseReader implements IReader
|
||||
}
|
||||
$sheet = $spreadsheet->setActiveSheetIndex($this->sheetIndex);
|
||||
|
||||
$escapeEnclosures = ['\\' . $this->enclosure,
|
||||
$this->enclosure . $this->enclosure,
|
||||
];
|
||||
$escapeEnclosures = [
|
||||
'\\' . $this->enclosure,
|
||||
$this->enclosure . $this->enclosure,
|
||||
];
|
||||
|
||||
// Set our starting row based on whether we're in contiguous mode or not
|
||||
$currentRow = 1;
|
||||
|
@ -446,7 +446,7 @@ class ReferenceHelper
|
||||
if ($cell->getDataType() == Cell\DataType::TYPE_FORMULA) {
|
||||
// Formula should be adjusted
|
||||
$pSheet->getCell($newCoordinates)
|
||||
->setValue($this->updateFormulaReferences($cell->getValue(), $pBefore, $pNumCols, $pNumRows, $pSheet->getTitle()));
|
||||
->setValue($this->updateFormulaReferences($cell->getValue(), $pBefore, $pNumCols, $pNumRows, $pSheet->getTitle()));
|
||||
} else {
|
||||
// Formula should not be adjusted
|
||||
$pSheet->getCell($newCoordinates)->setValue($cell->getValue());
|
||||
|
@ -143,40 +143,40 @@ class Font
|
||||
*/
|
||||
public static $defaultColumnWidths = [
|
||||
'Arial' => [
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 56, 'width' => 9.33203125],
|
||||
9 => ['px' => 64, 'width' => 9.14062500],
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 56, 'width' => 9.33203125],
|
||||
9 => ['px' => 64, 'width' => 9.14062500],
|
||||
10 => ['px' => 64, 'width' => 9.14062500],
|
||||
],
|
||||
'Calibri' => [
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 56, 'width' => 9.33203125],
|
||||
9 => ['px' => 56, 'width' => 9.33203125],
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 56, 'width' => 9.33203125],
|
||||
9 => ['px' => 56, 'width' => 9.33203125],
|
||||
10 => ['px' => 64, 'width' => 9.14062500],
|
||||
11 => ['px' => 64, 'width' => 9.14062500],
|
||||
],
|
||||
'Verdana' => [
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 64, 'width' => 9.14062500],
|
||||
9 => ['px' => 72, 'width' => 9.00000000],
|
||||
1 => ['px' => 24, 'width' => 12.00000000],
|
||||
2 => ['px' => 24, 'width' => 12.00000000],
|
||||
3 => ['px' => 32, 'width' => 10.66406250],
|
||||
4 => ['px' => 32, 'width' => 10.66406250],
|
||||
5 => ['px' => 40, 'width' => 10.00000000],
|
||||
6 => ['px' => 48, 'width' => 9.59765625],
|
||||
7 => ['px' => 48, 'width' => 9.59765625],
|
||||
8 => ['px' => 64, 'width' => 9.14062500],
|
||||
9 => ['px' => 72, 'width' => 9.00000000],
|
||||
10 => ['px' => 72, 'width' => 9.00000000],
|
||||
],
|
||||
];
|
||||
|
@ -541,12 +541,12 @@ class PclZip
|
||||
|
||||
// ----- For each file in the list check the attributes
|
||||
$v_supported_attributes = [
|
||||
PCLZIP_ATT_FILE_NAME => 'mandatory',
|
||||
PCLZIP_ATT_FILE_NEW_SHORT_NAME => 'optional',
|
||||
PCLZIP_ATT_FILE_NEW_FULL_NAME => 'optional',
|
||||
PCLZIP_ATT_FILE_MTIME => 'optional',
|
||||
PCLZIP_ATT_FILE_CONTENT => 'optional',
|
||||
PCLZIP_ATT_FILE_COMMENT => 'optional',
|
||||
PCLZIP_ATT_FILE_NAME => 'mandatory',
|
||||
PCLZIP_ATT_FILE_NEW_SHORT_NAME => 'optional',
|
||||
PCLZIP_ATT_FILE_NEW_FULL_NAME => 'optional',
|
||||
PCLZIP_ATT_FILE_MTIME => 'optional',
|
||||
PCLZIP_ATT_FILE_CONTENT => 'optional',
|
||||
PCLZIP_ATT_FILE_COMMENT => 'optional',
|
||||
];
|
||||
foreach ($v_att_list as $v_entry) {
|
||||
$v_result = $this->privFileDescrParseAtt($v_entry, $v_filedescr_list[], $v_options, $v_supported_attributes);
|
||||
@ -704,25 +704,25 @@ class PclZip
|
||||
if ((is_integer($v_arg_list[0])) && ($v_arg_list[0] > 77000)) {
|
||||
// ----- Parse the options
|
||||
$v_result = $this->privParseOptions($v_arg_list, $v_size, $v_options, [
|
||||
PCLZIP_OPT_PATH => 'optional',
|
||||
PCLZIP_OPT_REMOVE_PATH => 'optional',
|
||||
PCLZIP_OPT_REMOVE_ALL_PATH => 'optional',
|
||||
PCLZIP_OPT_ADD_PATH => 'optional',
|
||||
PCLZIP_CB_PRE_EXTRACT => 'optional',
|
||||
PCLZIP_CB_POST_EXTRACT => 'optional',
|
||||
PCLZIP_OPT_SET_CHMOD => 'optional',
|
||||
PCLZIP_OPT_BY_NAME => 'optional',
|
||||
PCLZIP_OPT_BY_EREG => 'optional',
|
||||
PCLZIP_OPT_BY_PREG => 'optional',
|
||||
PCLZIP_OPT_BY_INDEX => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_AS_STRING => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_IN_OUTPUT => 'optional',
|
||||
PCLZIP_OPT_REPLACE_NEWER => 'optional',
|
||||
PCLZIP_OPT_STOP_ON_ERROR => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_DIR_RESTRICTION => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_THRESHOLD => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_ON => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_OFF => 'optional',
|
||||
PCLZIP_OPT_PATH => 'optional',
|
||||
PCLZIP_OPT_REMOVE_PATH => 'optional',
|
||||
PCLZIP_OPT_REMOVE_ALL_PATH => 'optional',
|
||||
PCLZIP_OPT_ADD_PATH => 'optional',
|
||||
PCLZIP_CB_PRE_EXTRACT => 'optional',
|
||||
PCLZIP_CB_POST_EXTRACT => 'optional',
|
||||
PCLZIP_OPT_SET_CHMOD => 'optional',
|
||||
PCLZIP_OPT_BY_NAME => 'optional',
|
||||
PCLZIP_OPT_BY_EREG => 'optional',
|
||||
PCLZIP_OPT_BY_PREG => 'optional',
|
||||
PCLZIP_OPT_BY_INDEX => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_AS_STRING => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_IN_OUTPUT => 'optional',
|
||||
PCLZIP_OPT_REPLACE_NEWER => 'optional',
|
||||
PCLZIP_OPT_STOP_ON_ERROR => 'optional',
|
||||
PCLZIP_OPT_EXTRACT_DIR_RESTRICTION => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_THRESHOLD => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_ON => 'optional',
|
||||
PCLZIP_OPT_TEMP_FILE_OFF => 'optional',
|
||||
]);
|
||||
if ($v_result != 1) {
|
||||
return 0;
|
||||
|
@ -706,9 +706,10 @@ class AutoFilter
|
||||
$operator = ($dynamicRuleType === AutoFilter\Column\Rule::AUTOFILTER_RULETYPE_DYNAMIC_ABOVEAVERAGE)
|
||||
? AutoFilter\Column\Rule::AUTOFILTER_COLUMN_RULE_GREATERTHAN
|
||||
: AutoFilter\Column\Rule::AUTOFILTER_COLUMN_RULE_LESSTHAN;
|
||||
$ruleValues[] = ['operator' => $operator,
|
||||
'value' => $average,
|
||||
];
|
||||
$ruleValues[] = [
|
||||
'operator' => $operator,
|
||||
'value' => $average,
|
||||
];
|
||||
$columnFilterTests[$columnID] = [
|
||||
'method' => 'filterTestInCustomDataSet',
|
||||
'arguments' => ['filterRules' => $ruleValues, 'join' => AutoFilter\Column::AUTOFILTER_COLUMN_JOIN_OR],
|
||||
|
@ -46,11 +46,11 @@ class Comments extends WriterPart
|
||||
// XML header
|
||||
$objWriter->startDocument('1.0', 'UTF-8', 'yes');
|
||||
|
||||
// Comments cache
|
||||
$comments = $pWorksheet->getComments();
|
||||
// Comments cache
|
||||
$comments = $pWorksheet->getComments();
|
||||
|
||||
// Authors cache
|
||||
$authors = [];
|
||||
// Authors cache
|
||||
$authors = [];
|
||||
$authorId = 0;
|
||||
foreach ($comments as $comment) {
|
||||
if (!isset($authors[$comment->getAuthor()])) {
|
||||
@ -126,8 +126,8 @@ class Comments extends WriterPart
|
||||
// XML header
|
||||
$objWriter->startDocument('1.0', 'UTF-8', 'yes');
|
||||
|
||||
// Comments cache
|
||||
$comments = $pWorksheet->getComments();
|
||||
// Comments cache
|
||||
$comments = $pWorksheet->getComments();
|
||||
|
||||
// xml
|
||||
$objWriter->startElement('xml');
|
||||
@ -189,7 +189,7 @@ class Comments extends WriterPart
|
||||
private function writeVMLComment(\PhpSpreadsheet\Shared\XMLWriter $objWriter = null, $pCellReference = 'A1', \PhpSpreadsheet\Comment $pComment = null)
|
||||
{
|
||||
// Metadata
|
||||
list($column, $row) = \PhpSpreadsheet\Cell::coordinateFromString($pCellReference);
|
||||
list($column, $row) = \PhpSpreadsheet\Cell::coordinateFromString($pCellReference);
|
||||
$column = \PhpSpreadsheet\Cell::columnIndexFromString($column);
|
||||
$id = 1024 + $column + $row;
|
||||
$id = substr($id, 0, 4);
|
||||
|
@ -294,8 +294,7 @@ class Excel5 extends BaseWriter implements IWriter
|
||||
|
||||
// set the shape index (we combine 1-based sheet index and $countShapes to create unique shape index)
|
||||
$reducedSpId = $countShapes[$sheetIndex];
|
||||
$spId = $reducedSpId
|
||||
| ($sheet->getParent()->getIndex($sheet) + 1) << 10;
|
||||
$spId = $reducedSpId | ($sheet->getParent()->getIndex($sheet) + 1) << 10;
|
||||
$spContainer->setSpId($spId);
|
||||
|
||||
// keep track of last reducedSpId
|
||||
@ -352,8 +351,7 @@ class Excel5 extends BaseWriter implements IWriter
|
||||
|
||||
// set the shape index (we combine 1-based sheet index and $countShapes to create unique shape index)
|
||||
$reducedSpId = $countShapes[$sheetIndex];
|
||||
$spId = $reducedSpId
|
||||
| ($sheet->getParent()->getIndex($sheet) + 1) << 10;
|
||||
$spId = $reducedSpId | ($sheet->getParent()->getIndex($sheet) + 1) << 10;
|
||||
$spContainer->setSpId($spId);
|
||||
|
||||
// keep track of last reducedSpId
|
||||
@ -564,50 +562,64 @@ class Excel5 extends BaseWriter implements IWriter
|
||||
$dataSection_Content = '';
|
||||
|
||||
// GKPIDDSI_CODEPAGE: CodePage
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x01],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x02], // 2 byte signed integer
|
||||
'data' => ['data' => 1252], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x01],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x02], // 2 byte signed integer
|
||||
'data' => ['data' => 1252],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// GKPIDDSI_CATEGORY : Category
|
||||
if ($this->spreadsheet->getProperties()->getCategory()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getCategory();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x02],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x02],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// GKPIDDSI_VERSION :Version of the application that wrote the property storage
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x17],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x03],
|
||||
'data' => ['pack' => 'V', 'data' => 0x000C0000], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x17],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x03],
|
||||
'data' => ['pack' => 'V', 'data' => 0x000C0000],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
// GKPIDDSI_SCALE : FALSE
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
// GKPIDDSI_LINKSDIRTY : True if any of the values for the linked properties have changed outside of the application
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x10],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x10],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
// GKPIDDSI_SHAREDOC : FALSE
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x13],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x13],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
// GKPIDDSI_HYPERLINKSCHANGED : True if any of the values for the _PID_LINKS (hyperlink text) have changed outside of the application
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x16],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x16],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x0B],
|
||||
'data' => ['data' => false],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// GKPIDDSI_DOCSPARTS
|
||||
@ -617,50 +629,54 @@ class Excel5 extends BaseWriter implements IWriter
|
||||
$dataProp = pack('v', 0x0001);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// array of UnalignedLpstr
|
||||
// cch
|
||||
$dataProp .= pack('v', 0x000A);
|
||||
// cch
|
||||
$dataProp .= pack('v', 0x000A);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// value
|
||||
$dataProp .= 'Worksheet' . chr(0);
|
||||
// value
|
||||
$dataProp .= 'Worksheet' . chr(0);
|
||||
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x0D],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x101E],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x0D],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x101E],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// GKPIDDSI_HEADINGPAIR
|
||||
// VtVecHeadingPairValue
|
||||
// cElements
|
||||
$dataProp = pack('v', 0x0002);
|
||||
// cElements
|
||||
$dataProp = pack('v', 0x0002);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// Array of vtHeadingPair
|
||||
// vtUnalignedString - headingString
|
||||
// stringType
|
||||
$dataProp .= pack('v', 0x001E);
|
||||
// padding
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// UnalignedLpstr
|
||||
// cch
|
||||
$dataProp .= pack('v', 0x0013);
|
||||
// Array of vtHeadingPair
|
||||
// vtUnalignedString - headingString
|
||||
// stringType
|
||||
$dataProp .= pack('v', 0x001E);
|
||||
// padding
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// value
|
||||
$dataProp .= 'Feuilles de calcul';
|
||||
// vtUnalignedString - headingParts
|
||||
// wType : 0x0003 = 32 bit signed integer
|
||||
$dataProp .= pack('v', 0x0300);
|
||||
// padding
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// value
|
||||
$dataProp .= pack('v', 0x0100);
|
||||
// UnalignedLpstr
|
||||
// cch
|
||||
$dataProp .= pack('v', 0x0013);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// value
|
||||
$dataProp .= 'Feuilles de calcul';
|
||||
// vtUnalignedString - headingParts
|
||||
// wType : 0x0003 = 32 bit signed integer
|
||||
$dataProp .= pack('v', 0x0300);
|
||||
// padding
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
// value
|
||||
$dataProp .= pack('v', 0x0100);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
$dataProp .= pack('v', 0x0000);
|
||||
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x0C],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x100C],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x0C],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x100C],
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// 4 Section Length
|
||||
@ -760,89 +776,109 @@ class Excel5 extends BaseWriter implements IWriter
|
||||
$dataSection_Content = '';
|
||||
|
||||
// CodePage : CP-1252
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x01],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x02], // 2 byte signed integer
|
||||
'data' => ['data' => 1252], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x01],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x02], // 2 byte signed integer
|
||||
'data' => ['data' => 1252],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// Title
|
||||
if ($this->spreadsheet->getProperties()->getTitle()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getTitle();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x02],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x02],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Subject
|
||||
if ($this->spreadsheet->getProperties()->getSubject()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getSubject();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x03],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x03],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Author (Creator)
|
||||
if ($this->spreadsheet->getProperties()->getCreator()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getCreator();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x04],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x04],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Keywords
|
||||
if ($this->spreadsheet->getProperties()->getKeywords()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getKeywords();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x05],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x05],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Comments (Description)
|
||||
if ($this->spreadsheet->getProperties()->getDescription()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getDescription();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x06],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x06],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Last Saved By (LastModifiedBy)
|
||||
if ($this->spreadsheet->getProperties()->getLastModifiedBy()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getLastModifiedBy();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x08],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x08],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x1E], // null-terminated string prepended by dword string length
|
||||
'data' => ['data' => $dataProp, 'length' => strlen($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Created Date/Time
|
||||
if ($this->spreadsheet->getProperties()->getCreated()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getCreated();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x0C],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x40], // Filetime (64-bit value representing the number of 100-nanosecond intervals since January 1, 1601)
|
||||
'data' => ['data' => \PhpSpreadsheet\Shared\OLE::localDateToOLE($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x0C],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x40], // Filetime (64-bit value representing the number of 100-nanosecond intervals since January 1, 1601)
|
||||
'data' => ['data' => \PhpSpreadsheet\Shared\OLE::localDateToOLE($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Modified Date/Time
|
||||
if ($this->spreadsheet->getProperties()->getModified()) {
|
||||
$dataProp = $this->spreadsheet->getProperties()->getModified();
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x0D],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x40], // Filetime (64-bit value representing the number of 100-nanosecond intervals since January 1, 1601)
|
||||
'data' => ['data' => \PhpSpreadsheet\Shared\OLE::localDateToOLE($dataProp)], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x0D],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x40], // Filetime (64-bit value representing the number of 100-nanosecond intervals since January 1, 1601)
|
||||
'data' => ['data' => \PhpSpreadsheet\Shared\OLE::localDateToOLE($dataProp)],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
}
|
||||
// Security
|
||||
$dataSection[] = ['summary' => ['pack' => 'V', 'data' => 0x13],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x03], // 4 byte signed integer
|
||||
'data' => ['data' => 0x00], ];
|
||||
$dataSection[] = [
|
||||
'summary' => ['pack' => 'V', 'data' => 0x13],
|
||||
'offset' => ['pack' => 'V'],
|
||||
'type' => ['pack' => 'V', 'data' => 0x03], // 4 byte signed integer
|
||||
'data' => ['data' => 0x00],
|
||||
];
|
||||
++$dataSection_NumProps;
|
||||
|
||||
// 4 Section Length
|
||||
|
@ -666,7 +666,7 @@ class Parser
|
||||
list($row1, $col1) = $this->cellToPackedRowcol($cell1);
|
||||
list($row2, $col2) = $this->cellToPackedRowcol($cell2);
|
||||
} else { // It's a rows range (like 26:27)
|
||||
list($row1, $col1, $row2, $col2) = $this->rangeToPackedRange($cell1 . ':' . $cell2);
|
||||
list($row1, $col1, $row2, $col2) = $this->rangeToPackedRange($cell1 . ':' . $cell2);
|
||||
}
|
||||
|
||||
// The ptg value depends on the class of the ptg.
|
||||
|
@ -1019,9 +1019,7 @@ class Worksheet extends BIFFwriter
|
||||
$data = pack('vvvv', $row1, $row2, $col1, $col2);
|
||||
|
||||
// Write the packed data
|
||||
$this->append($header . $data .
|
||||
$unknown1 . $options .
|
||||
$unknown2 . $url_len . $url);
|
||||
$this->append($header . $data . $unknown1 . $options . $unknown2 . $url_len . $url);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -1068,9 +1066,7 @@ class Worksheet extends BIFFwriter
|
||||
$data = pack('vvvv', $row1, $row2, $col1, $col2);
|
||||
|
||||
// Write the packed data
|
||||
$this->append($header . $data .
|
||||
$unknown1 . $options .
|
||||
$url_len . $url);
|
||||
$this->append($header . $data . $unknown1 . $options . $url_len . $url);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user