2017 © Pedro Peláez
 

library patcher

Replace build in php functions

image

icewind/patcher

Replace build in php functions

  • Saturday, October 24, 2015
  • by icewind1991
  • Repository
  • 0 Watchers
  • 0 Stars
  • 18 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

Patcher

Build Status Code Coverage Scrutinizer Code Quality, (*1)

Replace build in php functions, (*2)

composer require icewind/patcher

Usage

Overwriting a method

use Icewind\Patcher\Patcher;

$patcher = new Patcher();
$patcher->patchMethod('time', function () {
    return 100;
});
$patcher->whiteListDirectory(__DIR__ . '/src');
$patcher->autoPatch();

include 'src/....';

Using the original method

use Icewind\Patcher\Patcher;

$patcher = new Patcher();
$patcher->patchMethod('time', function ($method, $arguments, $original) {
    $time = $original();
    error_log("Time: $time");
    return $time;
});
$patcher->whiteListDirectory(__DIR__ . '/src');
$patcher->autoPatch();

include 'src/....';

Overwriting a class

use Icewind\Patcher\Patcher;

class DummyDateTime extends DateTime {
    public function __construct() {
        parent::__construct("1970-01-01 00:00:00 UTC");
    }
}

$patcher = new Patcher();
$patcher->patchClass('\DateTime', '\DummyDateTime');
$patcher->whiteListDirectory(__DIR__ . '/src');
$patcher->autoPatch();

include 'src/....';

API

  • patchMethod(string $method, callable $handler): Set the handler for a method
    • The handler will be called with the following three arguments
    • string $method the name of the method being called
    • array $arguments the arguments the method was called with
    • callable $original a closure which will call the overwriten method with the correct arguments and return the result
  • patchClass(string $method, string $replacement): Overwrite a class with a different one
    • Note, at the moment this only works with classes in the global namespace
  • whiteListDirectory(string $path): Add a directory to the white list for the auto patcher
  • blackListDirectory(string $path): Add a directory to the black list for the auto patcher
  • autoPatch(): Enable auto patching for all files included from this point
    • Automatically apply the patch methods for any namespace defined
    • Will only be applied for files within a whitelisted directory

The Versions

24/10 2015

dev-master

9999999-dev

Replace build in php functions

  Sources   Download

MIT

The Requires

 

The Development Requires

24/10 2015

v0.4.0

0.4.0.0

Replace build in php functions

  Sources   Download

MIT

The Requires

 

The Development Requires

17/10 2015

v0.3.0

0.3.0.0

Replace build in php functions

  Sources   Download

MIT

The Requires

 

The Development Requires

04/10 2015

v0.2.0

0.2.0.0

Replace build in php functions

  Sources   Download

MIT

The Requires

 

The Development Requires

28/09 2015

v0.1.0

0.1.0.0

Replace build in php functions

  Sources   Download

MIT

The Requires

 

The Development Requires