Componente de geração de código PHP do Anizoptera CMF (despejo, serialização).
https://github.com/anizoptera/azaphpgen
Permite despejar matrizes complexas, objetos, fechamentos e tipos de dados básicos como código PHP. Em parte, isso pode ser chamado de algum tipo de serialização. E você pode personalizar seu código PHP despejado como desejar.
É muito útil para compilação de código (geralmente para fins de cache).
Características:
Benefícios sobre var_export() :
var_export não suporta o despejo de fechamentos;var_export suporta apenas objetos com a função __set_state . Azaphpgen suporta todos os objetos serializáveis;iterator_to_array );var_export gera código muito feio que é estranho de usar e pode ser facilmente corrompido;var_export gera código que não pode ser avaliado no espaço para nome;IPhpGenerable ;var_export nunca o produz :)A maneira recomendada de instalar Azaphpgen é através do compositor. Você pode ver as informações do pacote no Packagist.
{
"require" : {
"aza/phpgen" : " ~1.0 "
}
}Você pode usar exemplos/exemplo.php para executar todos os exemplos.
// 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 trate todos os objetos percorridos como matrizes (com iterator_to_array).
$ var = new SplFixedArray ( 3 );
$ var [ 0 ] = ' a ' ;
$ var [ 1 ] = ' b ' ;
echo $ phpGen -> getCodeNoFormat ( $ var ) . PHP_EOL ; // ["a","b",null]; Aviso: os fechamentos são despejados como estão. Portanto, fechamentos complexos não são suportados:
$this uso variável; $ 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";
},
];
*/ Você pode personalizar o dumping de suas classes implementando a interface 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]; Para o VarInt mais simplificado dos usos de interface IPhpGenerable , você pode usar CLASSE - CustomCode . É preciso apenas o código necessário como um argumento construtor.
$ 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]; Segunda Varint da personalização de código resultante - Uso de manipuladores definidos (ganchos) para as classes. Dessa forma, você pode personalizar o despejo de qualquer classe possível!
// 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 tem muitas opções. Portanto, é muito simples configurar o código resultante para suas necessidades especiais (estilo de código, por exemplo). Você pode ver todas as opções disponíveis no código da classe 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",
),
),
);
*/ Os testes estão na pasta de Tests e atingem 100% de cobertura de código. Para executá -los, você precisa de phpunit. Exemplo:
$ phpunit --configuration phpunit.xml.dist
Ou com relatório de cobertura:
$ phpunit --configuration phpunit.xml.dist --coverage-html code_coverage/
Azaphpgen faz parte do Anizoptera CMF, escrito por Amal Samally (Amal.Samally no Gmail.com) e da equipe do Azagroup.
Liberado sob a licença do MIT.