source: src/Patterns/Clone.hpp@ d76c105

Last change on this file since d76c105 was 1afcbe, checked in by Frederik Heber <heber@…>, 15 years ago

Added Clone pattern.

  • Clone is necessary for having prototypes, i.e. it defines an interface class that has a virtual * clone() const function that each derived type has to implement.
  • Added unit test.
  • made CommonStub a bit cleaner.
  • updated documentation fo Factory and FactoryTypeList
  • Library version is now 2:2:0, API is 1.0.4.
  • Property mode set to 100644
File size: 1.2 KB
Line 
1/*
2 * Clone.hpp
3 *
4 * Created on: Jan 4, 2011
5 * Author: heber
6 */
7
8#ifndef CLONE_HPP_
9#define CLONE_HPP_
10
11/** \section <Clone> (Clone Howto)
12 *
13 * Prototypes serves as templates in object creation, i.e. new objects are
14 * created by coping the prototype. Therefore each prototypical type has to
15 * implement a clone() function.
16 *
17 * By inheriting this pattern and implementing the clone function you make
18 * sure that the prototypes, e.g. to be stored in a factory table, can be
19 * safely copied (the factory just calls clone of the prototype) and can
20 * be handed out by the abstract and common interface.
21 *
22 * <h2> Howto </h2.
23 *
24 * Basically, you if you have your Prototype types, e.g. \a Prototype1 that
25 * all have a common interface, \a IPrototype, you just inherit additionally
26 * the specific Clone<IPrototype> class as follows:
27 *
28 * @code
29 * class Prototype1 :
30 * public IPrototype,
31 * public Clone<IPrototype>
32 * {
33 * public:
34 * IPrototype clone()
35 * {
36 * ... do something to clone the class ...
37 * };
38 * };
39 * @endcode
40 *
41 */
42template <class interface>
43class Clone
44{
45public:
46 virtual ~Clone() {};
47 virtual interface* clone() const = 0;
48};
49
50#endif /* CLONE_HPP_ */
Note: See TracBrowser for help on using the repository browser.