1
0
mirror of synced 2025-01-20 23:41:39 +03:00

some tweaks to class descriptions

This commit is contained in:
Chris Woodford 2011-05-03 23:04:41 -04:00
parent a51f182cc0
commit c242ab4371

View File

@ -3,38 +3,22 @@ Persisting the Decorator Pattern
.. sectionauthor:: Chris Woodford <chris.woodford@gmail.com> .. sectionauthor:: Chris Woodford <chris.woodford@gmail.com>
INTRO
Decorator Pattern
-----------------
Let's take a quick look at a visual representation of the Decorator Let's take a quick look at a visual representation of the Decorator
pattern pattern
DECORATOR PATTERN IMAGE
Doctrine Implementation Component
----------------------- ---------
In order to persist this pattern, we need fields in the Component
class to be stored and shared among the entire hierarchy, and we
needed any additional fields in the ConcreteComponent and
ConcreteDecorator to be stored as well. In this design, the Decorator
class just delegates calls to the Component decorated and doesn't
require any persistence of its own. However, the Decorator class
does have an association to the persistent Component that it's
decorating, and does need to be a part of this persistence hierarchy.
Since the Component class needs to be persisted, it's going to be a Since the Component class needs to be persisted, it's going to be a
Doctrine Entity. As the top of the inheritance hierarchy, it's going Doctrine Entity. As the top of the inheritance hierarchy, it's going
to have to define the persistent inheritance. For this example, we to have to define the persistent inheritance. For this example, we
will use Single Table Inheritance, but Class Table Inheritance will use Single Table Inheritance, but Class Table Inheritance
would work as well. would work as well. In the discriminator map, we will define two
concrete subclasses, ConcreteComponent and ConcreteDecorator.
In the discriminator map, we need to define two concrete subclasses,
ConcreteComponent and ConcreteDecorator.
Component
---------
.. code-block:: php .. code-block:: php
@ -46,8 +30,8 @@ Component
* @Entity * @Entity
* @InheritanceType("SINGLE_TABLE") * @InheritanceType("SINGLE_TABLE")
* @DiscriminatorColumn(name="discr", type="string") * @DiscriminatorColumn(name="discr", type="string")
* @DiscriminatorMap({"cc" = "TestComponentConcreteComponent", * @DiscriminatorMap({"cc" = "Test\Component\Concrete\Component",
"cd" = "TestDecoratorConcreteDecorator"}) "cd" = "Test\Decorator\Concrete\Decorator"})
*/ */
abstract class Component abstract class Component
{ {
@ -189,6 +173,13 @@ getName() method.
ConcreteDecorator ConcreteDecorator
----------------- -----------------
The final class required to complete a simple implementation of the
Decorator pattern is the ConcreteDecorator. In order to further
illustrate how the Decorator can alter data as it moves through the
chain of decoration, a new field, "special", has been added to this
class. The getName() has been overridden and appends the value of the
getSpecial() method to its return value.
.. code-block:: php .. code-block:: php
<?php <?php
@ -234,8 +225,11 @@ ConcreteDecorator
} }
Tests Examples
----- --------
Here is an example of how to persist and retrieve your decorated
objects
.. code-block:: php .. code-block:: php