Skip to content

LordMonoxide/facade

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This package has been superceded by BapCat/Facade.

Build Status Coverage Status License

Phi Facades

Facades are a way to make Phi bindings feel more natural.

Installation

Composer

Composer is the recommended method of installation for Facade.

$ composer require lordmonoxide/facade

GitHub

Facade may be downloaded from GitHub.

Features

Pseudo-Static Access To Phi Singletons

A common use-case for Phi Facades is logging:

namespace Vendor\Package\Logging;

class Logger {
  public function warning($text) {
    // ...
  }
}
$logger = new Vendor\Package\Logging\Logger;

$phi = LordMonoxide\Phi\Phi::instance();
$phi->bind('core.log', $logger);
use LordMonoxide\Facade\Facade;

class Log extends Facade {
  protected static $_binding = 'core.log';
}

Once the facade is set up, the Vendor\Package\Logging singleton can be accessed like this:

Log::warning('Something bad happened!');

Phi Facades can even be used to create a facade for Phi:

$phi = LordMonoxide\Phi\Phi::instance();
$phi->bind('phi', $phi);
use LordMonoxide\Facade\Facade;

class Phi extends Facade {
  protected static $_binding = 'phi';
}

This will allow Phi to be accessed as such:

Phi::bind('Bar', 'Foo');
$foo = Phi::make('Bar');

Phi Custom Resolvers

If you are using Phi 1.2.0 or greater, Phi facades will work seamlessly with custom resolvers.

About

This package has been superceded by BapCat/Facade

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages