TOML 1.0.0/1.1.0 parser and encoder for PHP 8.1+. Parse TOML files into PHP arrays or encode PHP data structures back to TOML format.
composer require internal/tomluse Internal\Toml\Toml;
// Parse to PHP array
$data = Toml::parseToArray(<<<'TOML'
title = "TOML Example"
version = "1.0.0"
[database]
host = "localhost"
ports = [8000, 8001, 8002]
TOML);
// Result:
// [
// 'title' => 'TOML Example',
// 'version' => '1.0.0',
// 'database' => [
// 'host' => 'localhost',
// 'ports' => [8000, 8001, 8002],
// ],
// ]use Internal\Toml\Toml;
$data = [
'title' => 'Configuration',
'database' => [
'host' => 'localhost',
'port' => 5432,
],
'servers' => [
['name' => 'alpha', 'ip' => '10.0.0.1'],
['name' => 'beta', 'ip' => '10.0.0.2'],
],
];
$toml = (string) Toml::encode($data);
// Output:
// title = 'Configuration'
//
// [database]
// host = 'localhost'
// port = 5432
//
// [[servers]]
// name = 'alpha'
// ip = '10.0.0.1'
//
// [[servers]]
// name = 'beta'
// ip = '10.0.0.2'use Internal\Toml\Toml;
// Parse to AST (Abstract Syntax Tree)
$document = Toml::parse('key = "value"');
// Access nodes
foreach ($document->nodes as $node) {
// Work with Entry, Table, TableArray nodes
}
// Convert to array
$array = $document->toArray();
// Serialize back to TOML
$toml = (string) $document;// Parse → Modify → Encode
$document = Toml::parse($tomlString);
$data = $document->toArray();
// Modify data
$data['new_key'] = 'new_value';
// Encode back
$newToml = (string) Toml::encode($data);
// Perfect round-trip preservation
$parsed = Toml::parseToArray($newToml);$data = [
'created' => new DateTimeImmutable('1979-05-27T07:32:00Z'),
'updated' => new DateTimeImmutable('2024-01-15T10:30:00+03:00'),
];
$toml = (string) Toml::encode($data);
// created = 1979-05-27T07:32:00Z
// updated = 2024-01-15T10:30:00+03:00$object = new class implements JsonSerializable {
public function jsonSerialize(): array {
return ['name' => 'Example', 'value' => 123];
}
};
$toml = (string) Toml::encode($object);// Original TOML with hex number
$toml = 'magic = 0xDEADBEEF';
$document = Toml::parse($toml);
echo (string) $document;
// Output: magic = 0xDEADBEEF
// ✅ Original format preserved!// Parse TOML string to Document AST
Toml::parse(string $toml): Document
// Parse TOML string to PHP array
Toml::parseToArray(string $toml): array
// Encode PHP array or JsonSerializable to TOML
Toml::encode(array|JsonSerializable $data): Stringable- Full TOML v1.1.0 spec compliance
- Strings: basic, literal, multiline, all escape sequences including
\eand\xHH - Numbers: integers (decimal, hex, octal, binary), floats, special values (
inf,nan) - Date-time: offset, local date-time, local date, local time (seconds optional)
- Tables, inline tables (multi-line with trailing commas), arrays of tables, dotted keys
- Comments preservation
- Format-preserving round-trips (hex numbers stay hex, etc.)
- Encoder outputs TOML v1.0-compatible format for maximum interoperability
Built with Claude Code