init
This commit is contained in:
commit
72a26edcff
22092 changed files with 2101903 additions and 0 deletions
69
lib/PhpSpreadsheet/Calculation/Engineering/ConvertBase.php
Normal file
69
lib/PhpSpreadsheet/Calculation/Engineering/ConvertBase.php
Normal file
|
|
@ -0,0 +1,69 @@
|
|||
<?php
|
||||
|
||||
namespace PhpOffice\PhpSpreadsheet\Calculation\Engineering;
|
||||
|
||||
use PhpOffice\PhpSpreadsheet\Calculation\ArrayEnabled;
|
||||
use PhpOffice\PhpSpreadsheet\Calculation\Exception;
|
||||
use PhpOffice\PhpSpreadsheet\Calculation\Functions;
|
||||
use PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;
|
||||
|
||||
abstract class ConvertBase
|
||||
{
|
||||
use ArrayEnabled;
|
||||
|
||||
protected static function validateValue(mixed $value): string
|
||||
{
|
||||
if (is_bool($value)) {
|
||||
if (Functions::getCompatibilityMode() !== Functions::COMPATIBILITY_OPENOFFICE) {
|
||||
throw new Exception(ExcelError::VALUE());
|
||||
}
|
||||
$value = (int) $value;
|
||||
}
|
||||
|
||||
if (is_numeric($value)) {
|
||||
if (Functions::getCompatibilityMode() == Functions::COMPATIBILITY_GNUMERIC) {
|
||||
$value = floor((float) $value);
|
||||
}
|
||||
}
|
||||
|
||||
return strtoupper((string) $value);
|
||||
}
|
||||
|
||||
protected static function validatePlaces(mixed $places = null): ?int
|
||||
{
|
||||
if ($places === null) {
|
||||
return $places;
|
||||
}
|
||||
|
||||
if (is_numeric($places)) {
|
||||
if ($places < 0 || $places > 10) {
|
||||
throw new Exception(ExcelError::NAN());
|
||||
}
|
||||
|
||||
return (int) $places;
|
||||
}
|
||||
|
||||
throw new Exception(ExcelError::VALUE());
|
||||
}
|
||||
|
||||
/**
|
||||
* Formats a number base string value with leading zeroes.
|
||||
*
|
||||
* @param string $value The "number" to pad
|
||||
* @param ?int $places The length that we want to pad this value
|
||||
*
|
||||
* @return string The padded "number"
|
||||
*/
|
||||
protected static function nbrConversionFormat(string $value, ?int $places): string
|
||||
{
|
||||
if ($places !== null) {
|
||||
if (strlen($value) <= $places) {
|
||||
return substr(str_pad($value, $places, '0', STR_PAD_LEFT), -10);
|
||||
}
|
||||
|
||||
return ExcelError::NAN();
|
||||
}
|
||||
|
||||
return substr($value, -10);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue