public static function Bytes::toNumber in Drupal 10
Same name and namespace in other branches
- 9 core/lib/Drupal/Component/Utility/Bytes.php \Drupal\Component\Utility\Bytes::toNumber()
Parses a given byte size.
Parameters
int|float|string $size: An integer, float, or string size expressed as a number of bytes with optional SI or IEC binary unit prefix (e.g. 2, 2.4, 3K, 5MB, 10G, 6GiB, 8 bytes, 9mbytes).
Return value
float The floating point value of the size in bytes.
10 calls to Bytes::toNumber()
- BytesTest::testToNumber in core/
tests/ Drupal/ Tests/ Component/ Utility/ BytesTest.php - Tests \Drupal\Component\Utility\Bytes::toNumber().
- EditorImageDialog::buildForm in core/
modules/ editor/ src/ Form/ EditorImageDialog.php - Environment::checkMemoryLimit in core/
lib/ Drupal/ Component/ Utility/ Environment.php - Compares the memory required for an operation to the available memory.
- Environment::getUploadMaxSize in core/
lib/ Drupal/ Component/ Utility/ Environment.php - Determines the maximum file upload size by querying the PHP settings.
- FileItem::getUploadValidators in core/
modules/ file/ src/ Plugin/ Field/ FieldType/ FileItem.php - Retrieves the upload validators for a file field.
File
- core/
lib/ Drupal/ Component/ Utility/ Bytes.php, line 72
Class
- Bytes
- Provides helper methods for byte conversions.
Namespace
Drupal\Component\UtilityCode
public static function toNumber($size) : float {
// Remove the non-unit characters from the size.
$unit = preg_replace('/[^bkmgtpezy]/i', '', $size);
// Remove the non-numeric characters from the size.
$size = preg_replace('/[^0-9\\.]/', '', $size);
if ($unit) {
// Find the position of the unit in the ordered string which is the power
// of magnitude to multiply a kilobyte by.
return round($size * pow(self::KILOBYTE, stripos('bkmgtpezy', $unit[0])));
}
else {
// Ensure size is a proper number type.
return round((double) $size);
}
}