Comments, readme, bugfixes

This commit is contained in:
Chris 2017-01-10 13:50:11 +01:00
parent dd2bb032dd
commit 156bb62367
3 changed files with 101 additions and 4 deletions

69
README.md Normal file
View File

@ -0,0 +1,69 @@
MakePhar mk2
============
This is a rewrite of my old MakePhar utility, with cleaner code and added
portability. Besides being able to pack executables, this version can also
create libraries, such as portable plugins.
## Executables
If your project is using composer, and your main stub is located in the
source directory as specified in the composer.json, you can create a
manifest easily:
$ makephar -n > makephar.sdl
Now, just update `makephar.sdl` to make sure the **stub** points to the
executable stub. Here is an example:
phar "my-project.phar" {
include {
dir "src";
dir "vendor";
}
stub "src/boot.php";
}
To build this into a .phar archive, just call `makephar`:
$ makephar
The output file `my-project.phar` should be created and be executable out of
the box.
## Libraries
Libraries work like executables, with the difference that they **require** a
composer project, or rather it requires a file named `vendor/autoload.php` in
the package.
To load your own bootstrap using composer, add them as file autoloaders:
...
"autoload": {
"psr-4": ...
"files": [ "src/my-library-stub.php" ]
}
Next, make sure you have a line in your `makephar.sdl` that reads:
library true;
You should now be able to create a library phar by invoking `makephar`.
It is recommended that you add a check in your main stub to make sure that
the plugin or library has what is needed, such as checking a define or making
sure that a method or class already exists.
## Pro Tips
* You can have multiple `phar` blocks in your `makephar.conf`. This lets
you build a main executable, libraries etc in one go. You currently can't
pick the rule to build tho, but rather all defined phars will be built.
* MakePhar will minify your files using `php_strip_whitespace()` before adding
them to the archive. This shouldn't be an issue, but if your code depends on
a specific character index in a specific php file, you might want to use
another tool for the time being.

View File

@ -52,7 +52,7 @@ class Application
}
if ($this->config->init) {
if (!file_exists("composer.json")) {
log_error("No composer.json in current directory");
error_log("No composer.json in current directory");
return 1;
}
$proj = json_decode(file_get_contents("composer.json"));

View File

@ -4,6 +4,7 @@ namespace MakePhar;
class PharBuilder
{
protected $tempFile;
protected $manifest;
@ -16,23 +17,34 @@ class PharBuilder
$this->manifest = $manifest;
}
/**
* Collect files and prepare to build the .phar
*
*/
public function prepare()
{
log_debug("Finding files to add...");
$this->files = $this->manifest->findSourceFiles();
log_debug("Found %d files", count($this->files));
$this->tempFile = "/tmp/".uniqid("phar").".phar";
}
/**
* Build the .phar archive
*
*/
public function build()
{
// Create the phar
$phar = new \Phar("/tmp/output.phar");
$phar = new \Phar($this->tempFile);
$vo = posix_isatty(STDOUT);
// Add files
log_debug("Adding files to phar archive...");
$t = count($this->files); $i = 0; $lp = null;
$phar->startBuffering();
$size_tot = 0; $size_min = 0;
foreach ($this->files as $file) {
$i++;
$tp = dirname($file->src);
@ -41,7 +53,10 @@ class PharBuilder
printf("\r\e[K%d/%d %s", $i, $t, $tp);
}
if (fnmatch("*.php",$file->src)) {
$phar->addFromString($file->dest?:$file->src, php_strip_whitespace($file->src));
$min = php_strip_whitespace($file->src);
$size_tot += filesize($file->src);
$size_min += strlen($min);
$phar->addFromString($file->dest?:$file->src, $min);
} else {
$phar->addFile($file->dest?:$file->src, $file->src);
}
@ -49,6 +64,15 @@ class PharBuilder
($vo) && printf("\r\e[K");
$phar->stopBuffering();
$formatSize = function ($s) {
$u = [ 'B', 'KB', 'MB', 'GB' ];
while (count($u)>1 && ($s > 1024)) { $s /= 1024; array_shift($u); }
return sprintf("%.2f%s", $s, array_shift($u));
};
$str_tot = $formatSize($size_tot);
$str_min = $formatSize($size_min);
log_debug("Size: {$str_tot}, Minified: {$str_min}");
// Create stub
if ($this->manifest->getIsLibrary()) {
log_debug("Creating library stub...");
@ -78,6 +102,10 @@ class PharBuilder
$phar = null;
}
/**
* Move the built .phar into its target location.
*
*/
public function finalize()
{
$output = $this->manifest->getOutput();
@ -86,7 +114,7 @@ class PharBuilder
unlink($output);
}
log_debug("Writing %s", $output);
rename("/tmp/output.phar", $output);
rename($this->tempFile, $output);
if (!$this->manifest->getIsLibrary()) {
chmod($output, 0777);