fontebasso/json-to-toon

json-to-toon converts verbose JSON into a lightweight, LLM-friendly “Toon” format — optimized for ChatGPT and other AI models to cut token usage, boost context efficiency, and keep responses sharp.

Installs: 1

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/fontebasso/json-to-toon

1.0.0 2025-11-12 11:42 UTC

This package is auto-updated.

Last update: 2025-11-12 11:45:06 UTC


README

Tests License: MIT

json-to-toon is a lightweight PHP library that converts verbose JSON into a compact, LLM-optimized format called TOON. The TOON format preserves structure while minimizing token usage, improving context efficiency for large language models such as ChatGPT and Claude.

This implementation follows the TOON Specification v2.0, supporting arrays, nested objects, primitives, and non-uniform structures — including compact representation of associative and nested data.

Installation

You can install the library via Composer:

composer require fontebasso/json-to-toon

Overview

Traditional JSON structures are often verbose and redundant, especially when serialized for language models. json-to-toon introduces a concise syntax that encodes data in a tabular form, preserving semantics while reducing size.

Example

Input JSON:

[
  {"id": 1, "name": "Alice", "role": "admin"},
  {"id": 2, "name": "Bob", "role": "user"}
]

Converted Toon:

users[2]{id,name,role}:
1,Alice,admin
2,Bob,user

This representation is shorter, token-efficient, and ideal for transmitting structured context to LLMs such as ChatGPT or Claude.

Usage

From PHP Array

<?php

use Fontebasso\JsonToToon\Toon;

require 'vendor/autoload.php';

$data = [
  ["id" => 1, "name" => "Alice", "role" => "admin"],
  ["id" => 2, "name" => "Bob", "role" => "user"]
];

$toon = Toon::encode('users', $data);

echo $toon;

From JSON String

<?php

use Fontebasso\JsonToToon\Toon;

require 'vendor/autoload.php';

$json = '[
  {"id": 1, "name": "Alice", "role": "admin"},
  {"id": 2, "name": "Bob", "role": "user"}
]';

$toon = Toon::encode('users', $json);

echo $toon;

Output

users[2]{id,name,role}:
1,Alice,admin
2,Bob,user

Compact Mode

json-to-toon automatically encodes associative objects using the compact TOON syntax:

$data = [
  'meta' => ['a' => 1, 'b' => 2],
  'tags' => ['x', 'y'],
];

echo Toon::encode('data', $data);

Output

data:
meta{a=1;b=2}
tags[2]{value}:
x
y

Nested arrays are represented recursively:

profile{name=Alice;skills=[PHP|Go]}

Tests

Run the PHPUnit suite:

composer test

Open the generated coverage report at:

coverage/html/index.html

Continuous Integration

The repository includes a GitHub Actions workflow that automatically runs tests on PHP 8.2, 8.3, and 8.4 for every push or pull request to main.

License

This library is licensed under the MIT License. See the LICENSE file for details.