Read and write INI configurations.
composer require piwik/ini
PHP provides a parse_ini_file()
function to read INI files.
This component provides the following benefits over the built-in function:
- allows to write INI files
- classes can be used with dependency injection and mocked in unit tests
- throws exceptions instead of PHP errors
- better type supports:
- parses boolean values (
true
/false
,on
/off
,yes
/no
) to real PHP booleans (instead of strings"1"
and""
) - parses null to PHP
null
(instead of an empty string)
- parses boolean values (
- works even if
parse_ini_file()
orparse_ini_string()
is disabled inphp.ini
by falling back on an alternate implementation (can happen on some shared hosts) - fixes a PHP 5.3.3 bug
- fixes a parsing bug present in PHP <= 5.4.4
$reader = new IniReader();
// Read a string
$array = $reader->readString($string);
// Read a file
$array = $reader->readFile('config.ini');
$writer = new IniWriter();
// Write to a string
$string = $writer->writeToString($array);
// Write to a file
$writer->writeToFile('config.ini', $array);
The Ini component is released under the LGPL v3.0.
To run the unit tests:
vendor/bin/phpunit
To run the performance tests:
php -n vendor/bin/athletic -p tests/PerformanceTest