ini_parse_quantity

(PHP 8 >= 8.2.0)

ini_parse_quantityDevuelve el tamaño interpretado a partir de la sintaxis abreviada ini

Descripción

function ini_parse_quantity(string $shorthand): int

Devuelve el tamaño interpretado en bytes en caso de éxito a partir de una sintaxis abreviada ini.

Parámetros

shorthand

La sintaxis abreviada ini a interpretar, debe ser un número seguido de un multiplicador opcional. Los multiplicadores siguientes son soportados: k/K (1024), m/M (1048576), g/G (1073741824). El número puede ser un decimal, hexadecimal (prefijado por 0x o 0X), octal (prefijado por 0o, 0O o 0) o binario (prefijado por 0b o 0B)

Valores devueltos

Devuelve el tamaño interpretado en bytes en tanto que int.

Errores/Excepciones

Si el valor no puede ser interpretado, o si un multiplicador inválido es utilizado, un E_WARNING es emitido.

Ejemplos

Ejemplo #1 Algunos ejemplos de ini_parse_quantity()

<?php

var_dump(ini_parse_quantity('1024'));
var_dump(ini_parse_quantity('1024M'));
var_dump(ini_parse_quantity('512K'));
var_dump(ini_parse_quantity('0xFFk'));
var_dump(ini_parse_quantity('0b1010k'));
var_dump(ini_parse_quantity('0o1024'));
var_dump(ini_parse_quantity('01024'));
var_dump(ini_parse_quantity('Foobar'));
var_dump(ini_parse_quantity('10F'));

?>

El ejemplo anterior mostrará:

int(1024)
int(1073741824)
int(524288)
int(261120)
int(10240)
int(532)
int(532)

Warning: Invalid quantity "Foobar": no valid leading digits, interpreting as "0" for backwards compatibility
int(0)

Warning: Invalid quantity "10F": unknown multiplier "F", interpreting as "10" for backwards compatibility
int(10)

Ver también

  • ini_get() - Lee el valor de una opción de configuración
add a note

User Contributed Notes 1 note

up
0
php at SpamDeletToDotLLMsRefuse dot dunn dot eu dot org
2 days ago
I made a very basic polyfill for this function, you're welcome to use

<?php
if(!function_exists('ini_parse_quantity')) {
    /**
     * Very basic polyfill for ini_parse_quantity
     * @license MPL-2.0
     * @license CC-BY-3.0
     */
    function ini_parse_quantity($shorthand) {
        $regex = '/^(0?[xXbBoO]?)([0-9A-Fa-f]*)([kKmMgG]?)$/';
        preg_match($regex, $shorthand, $matches);
        if(empty($matches)) {
            trigger_error('Can\'t parse '.$shorthand.' :(', E_USER_WARNING);
            return 0;
        }
        [ $full, $binOctHex, $value, $unit ] = $matches;
        switch ($binOctHex) {
            case '0b':
            case '0B':
                $base = 2;
                break;
            case '0o':
            case '0O':
            case '0':
                $base = 8;
                break;
            case '0x':
            case '0X':
                $base = 16;
                break;
            default:
                $base = 10;
                break;
        }
        $value = intval($value, $base);

        switch ($unit) {
            case 'g':
            case 'G':
                $value *= 1024;
            case 'm':
            case 'M':
                $value *= 1024;
            case 'k':
            case 'K':
                $value *= 1024;
            default:
                break;
        }
        return $value;
    }
}