mirror of
https://github.com/DesignPatternsPHP/DesignPatternsPHP.git
synced 2025-08-06 06:57:25 +02:00
execute read-the-docs.sh
This commit is contained in:
65
Structural/Facade/index.rst
Normal file
65
Structural/Facade/index.rst
Normal file
@@ -0,0 +1,65 @@
|
||||
Facade
|
||||
======
|
||||
|
||||
Purpose
|
||||
-------
|
||||
|
||||
The primary goal of a Facade Pattern is not to avoid you to read the
|
||||
manual of a complex API. It's only a side-effect. The first goal is to
|
||||
reduce coupling and follow the Law of Demeter.
|
||||
|
||||
A Facade is meant to decouple a client and a sub-system by embedding
|
||||
many (but sometimes just one) interface, and of course to reduce
|
||||
complexity.
|
||||
|
||||
- A facade does not forbid you the access to the sub-system
|
||||
- You can (you should) have multiple facades for one sub-system
|
||||
|
||||
That's why a good facade has no ``new`` in it. If there are multiple
|
||||
creations for each method, it is not a Facade, it's a Builder or a
|
||||
[Abstract\|Static\|Simple] Factory [Method].
|
||||
|
||||
The best facade has no ``new`` and a constructor with
|
||||
interface-type-hinted parameters. If you need creation of new instances,
|
||||
use a Factory as argument.
|
||||
|
||||
UML Diagram
|
||||
-----------
|
||||
|
||||
.. image:: uml/uml.png
|
||||
:alt: Alt Facade UML Diagram
|
||||
:align: center
|
||||
|
||||
Code
|
||||
----
|
||||
|
||||
You can also find these code on `GitHub`_
|
||||
|
||||
OsInterface.php
|
||||
|
||||
.. literalinclude:: OsInterface.php
|
||||
:language: php
|
||||
:linenos:
|
||||
|
||||
Facade.php
|
||||
|
||||
.. literalinclude:: Facade.php
|
||||
:language: php
|
||||
:linenos:
|
||||
|
||||
BiosInterface.php
|
||||
|
||||
.. literalinclude:: BiosInterface.php
|
||||
:language: php
|
||||
:linenos:
|
||||
|
||||
Test
|
||||
----
|
||||
|
||||
Tests/FacadeTest.php
|
||||
|
||||
.. literalinclude:: Tests/FacadeTest.php
|
||||
:language: php
|
||||
:linenos:
|
||||
|
||||
.. _`GitHub`: https://github.com/domnikl/DesignPatternsPHP/tree/master/Structural/Facade
|
Reference in New Issue
Block a user