Компонент Anizoptera CMF PHP Code Generation (дамп, сериализация).
https://github.com/anizoptera/azaphpgen
Позволяет сбрасывать сложные массивы, объекты, закрытия и основные типы данных в качестве кода PHP. Частично это можно назвать какой -то сериализацией. И вы можете настроить свой сброшенный PHP -код по своему желанию.
Это очень полезно для компиляции кода (обычно для целей кэширования).
Функции:
Преимущества над var_export() :
var_export не поддерживает закрытие сброса;var_export поддерживает только объекты с функцией __set_state . Azaphpgen поддерживает все сериализуемые объекты;iterator_to_array );var_export генерирует очень уродливый код, который неловко в использовании и может быть легко поврежден;var_export генерирует код, который не может быть оценен в пространстве имен;IPhpGenerable интерфейса;var_export никогда не выводит его :)Рекомендуемый способ установки AzaphpGen - через композитор. Вы можете увидеть информацию о пакете на Packagist.
{
"require" : {
"aza/phpgen" : " ~1.0 "
}
}Вы можете использовать примеры/example.php для запуска всех примеров.
// Get singleton instance of PhpGen (fast and simple variant)
$ phpGen = PhpGen:: instance ();
// Integer
echo $ phpGen -> getCode ( 123456789 ) . PHP_EOL ; // 123456789;
// String (binary strings are supported as well)
echo $ phpGen -> getCode ( ' some string ' . ' example ' ) . PHP_EOL ; // "some string example";
// Float without trailing semicolon
echo $ phpGen -> getCodeNoTail ( 12.345 ) . PHP_EOL ; // 12.345
// Simple serializable objects
$ var = new stdClass ();
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ; // unserialize("O:8:"stdClass":0:{}");
// Another object example
$ var = new DateTime ( ' 2013-02-23 00:49:36 ' , new DateTimeZone ( ' UTC ' ));
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ; // unserialize("O:8:"DateTime":3:{s:4:"date";s:19:"2013-02-23 00:49:36";s:13:"timezone_type";i:3;s:8:"timezone";s:3:"UTC";}"); // AzaPhpGen will use short array syntax if possible by default (PHP >= 5.4)
echo $ phpGen -> getCode ( array (
true , false , null
)) . PHP_EOL ;
/*
[
true,
false,
null,
];
*/
// Build code without formatting
echo $ phpGen -> getCodeNoFormat ( array (
true , false , null
)) . PHP_EOL ;
/*
[true,false,null];
*/
// Complex array (some sort of config for example)
$ array = array (
' key1 ' => ' value ' ,
' long_key ' => ' value ' ,
' array ' => array (
' short_value '
),
' array2 ' => array (
' very very very very very very very very very very very very long value '
),
' other ' ,
123456789
);
echo $ phpGen -> getCode ( $ array ) . PHP_EOL ;
/*
[
"key1" => "value",
"long_key" => "value",
"array" => ["short_value"],
"array2" => [
"very very very very very very very very very very very very long value",
],
0 => "other",
1 => 123456789,
];
*/
// And wothout formatting
echo $ phpGen -> getCodeNoFormat ( $ array ) . PHP_EOL ;
/*
["key1"=>"value","long_key"=>"value","array"=>["short_value"],"array2"=>["very very very very very very very very very very very very long value"],0=>"other",1=>123456789];
*/ Azaphpgen обрабатывать все обходные объекты как массивы (с итератором_to_array).
$ var = new SplFixedArray ( 3 );
$ var [ 0 ] = ' a ' ;
$ var [ 1 ] = ' b ' ;
echo $ phpGen -> getCodeNoFormat ( $ var ) . PHP_EOL ; // ["a","b",null]; Предупреждение: закрытие сбрасывается как есть. Таким образом, сложные закрытия не поддерживаются:
$this переменных; $ closure = function ( $ a , $ b ) {
return round ( $ a , $ b ) . " example tn" ;
};
echo $ phpGen -> getCode ( $ closure ) . PHP_EOL ;
/*
function($a, $b) {
return round($a, $b) . "exampletn";
};
*/
echo $ phpGen -> getCode ( array ( ' key ' => $ closure )) . PHP_EOL ;
/*
[
"key" => function($a, $b) {
return round($a, $b) . "exampletn";
},
];
*/ Вы можете настроить дамп своих классов, внедрив интерфейс IPhpGenerable .
class ExampleCustomCode implements IPhpGenerable
{
public function generateCode ()
{
return ' 32434 + 5678 ' ;
}
}
$ var = new ExampleCustomCode ();
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ; // 32434 + 5678;
echo $ phpGen -> getCode ( array ( $ var )) . PHP_EOL ; // [32434 + 5678]; Для самого простого варианта использования интерфейса IPhpGenerable вы можете использовать комплексный класс - CustomCode . Он просто принимает требуемый код в качестве аргумента конструктора.
$ var = new CustomCode ( ' "some code" . PHP_EOL ' );
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ; // "some code" . PHP_EOL;
echo $ phpGen -> getCode ( array ( $ var )) . PHP_EOL ; // ["some code" . PHP_EOL]; Второй вариант полученной настройки кода - использование определенных обработчиков (крючков) для классов. Таким образом, вы можете настроить дамп любого возможного класса!
// Set custom handler for DateTime type
$ phpGen -> addCustomHandler ( ' DateTime ' , function ( $ data ) use ( $ phpGen ) {
/** @var $data DateTime */
return $ phpGen -> getCodeNoTail (
$ data -> format ( " Y-m-dO " )
);
});
// Build code
$ var = new DateTime ( ' 2013-02-23 00:49:36 ' , new DateTimeZone ( ' UTC ' ));
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ; // "2013-02-23+0000"; У Azaphpgen есть много вариантов. Таким образом, очень просто настроить ваш полученный код для ваших особых потребностей (например, стиль кода). Вы можете увидеть все доступные параметры в коде класса PHPGEN.
// Disable short array syntax and use 6 spaces for indentation
$ phpGen -> shortArraySyntax = false ;
$ phpGen -> useSpaces = true ;
$ phpGen -> tabLength = 6 ;
$ var = array ( array ( array ( 23 => ' example ' )));
echo $ phpGen -> getCode ( $ var ) . PHP_EOL ;
/*
array(
array(
array(
23 => "example",
),
),
);
*/ Тесты находятся в папке Tests и достигают 100% кодового покрытия. Чтобы запустить их, вам нужен фпунит. Пример:
$ phpunit --configuration phpunit.xml.dist
Или с отчетом о покрытии:
$ phpunit --configuration phpunit.xml.dist --coverage-html code_coverage/
Azaphpgen является частью Anizoptera CMF, написанной Амалом Самалли (Amal.samally на Gmail.com) и командой Azagroup.
Выпущено по лицензии MIT.