Atenção |
Este módulo é EXPERIMENTAL. Isso quer dizer que o comportamento neste módulo --- incluindo suas funções e seus nomes, e TUDO mais que está documentado sobre esse módulo --- poderá mudar em futuras versões do PHP, SEM QUALQUER NOTIFICAÇÃO. Esteja avisado, e use este módulo por sua própria conta e risco. |
Bcompiler foi escrito por duas razões:
Para codificar script em uma aplicação PHP proprietária |
Para codificar algumas classes e/ou funções em uma aplicação PHP proprietária |
Para disponibilizar a produção de aplicações php-gtk que poderiam ser usadas em clientes desktops, sem precisa do php.exe. |
Para estudar a possibilidade de fazer um conversor de PHP para C |
O segundo desses objetivos é alcançado usando as funções bcompiler_write_header(), bcompiler_write_class(), bcompiler_write_footer(), bcompiler_read(), e bcompiler_load(). Os arquivos bytecode podem ser escritos ou como não-compactados ou planos. O bcompiler_load() lê um arquivo compactador bzip que contem bytecodes, o que tende a ser 1/3 do tamanho original do arquivo.
Para criar arquivos do tipo EXE, bcompiler tem que ser usado com um arquivo de SAPI modificado ou uma versão do PHP que tenha sido compilada como uma biblioteca compartilhada. Nesse cenário, bcompiler ler o bytecode compactador do fim do arquivo executável.
bcompiler pode aumentar performance em volta de 30% quando usado com bytecodes não-compactados apenas. Mas lembre-se que bytecode não-compactado pode ser até 5 vezes maior que o código-fonte original. Usar compactação de bytecode pode evitar gasto de espaço, mas descompactar requer muito mais tempo do que avaliar um fonte. bcompiler também não faz nenhuma otimização de bytecode, isso pode ser acrescentado no futuro...
Em termos de proteção de código, é seguro dizer que é seria impossível recriar o código-fonte exato do qual ele foi criado, e sem os comentários acompanhando o código-font. Seria efetivamente inútil usar o bcompiler para recriar ou modificar uma classe. No entanto, é possível recuperar dados de um arquivo bytecode compactado - então não ponha suas senhas pessoais ou coisa do tipo nele.
Nota curta de instalação:
Você precisa de pelo menos o PHP 4.3. para a compressão funcionar
Para instalar no PHP 4.3 e superior no shell do unix digite pear install bcompiler
Para instalar no Windows, até o mecanismo de distribuíção de pacotes binários estiver completo, favor procure os arquivos da lista de discussão pear-general pelos pacotes pré-compilados. (ou mande um e-mail para a lista de você não conseguir achar uma referência).
Para instalar em versões mais antigas, você precisa fazer algumas pequenas alterações ao binário compilado.
untar o arquivo bcompiler.tgz no diretório php4/ext.(Pegue o diretamente da PECL http://pecl.php.net/get/bcompiler)
Se o novo diretório for chamado algo como bcompiler-0.x, então você deve renomeá-lo para bcompiler (exceto se você só quiser compilá-lo como um módulo do php auto-contido).
Se você estiver usando versões anteriores ao PHP 4.3, você terá que copiar os arquivos Makefile.in.old para Makefile.in e config.m4.old para config.m4.
execute phpize no diretório ext/bcompiler
execute ./buildconf no diretório php4
execute o script configure com a opção --enable-bcompiler e as suas outras opções
make; make install
E por hoje é só pessoal.
Se você tiver comentários, resoluções de bugs, melhoramentos ou quer ajudar a desenvolver essa fera, você pode me enviar um e-mail para alan_k@php.net. Qualquer ajuda é muito bem-vinda.