Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/orxonox/trunk/src/util/loading/factory.h @ 4729

Last change on this file since 4729 was 4729, checked in by bensch, 19 years ago

orxonox/trunk: factory-fix

File size: 2.5 KB
Line 
1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10
11   ### File Specific:
12   main-programmer: Christian Meyer
13   co-programmer: Benjamin Grauer
14*/
15
16/*!
17  \file factory.h
18  \brief A loadable object handler
19*/
20
21
22#ifndef _FACTORY_H
23#define _FACTORY_H
24
25class BaseObject;
26
27#include "tinyxml.h"
28#include "load_param.h"
29#include "base_object.h"
30#include "debug.h"
31
32/**
33    Creates a factory to a Loadable Class.
34    this should be used at the beginning of all the Classes that should be loadable (in the cc-file)
35  \todo make factoryName a BaseObject-parameter. (else it would be redundant)
36*/
37#define CREATE_FACTORY(CLASS_NAME) tFactory<CLASS_NAME>* global_##CLASS_NAME##Factory = new tFactory<CLASS_NAME>(#CLASS_NAME)
38
39//! The Factory is a loadable object handler
40class Factory : public BaseObject {
41
42 public:
43  Factory (const char* factoryName = NULL);
44  ~Factory ();
45
46
47  virtual BaseObject* fabricate(const TiXmlElement* root);
48  void initialize();
49  void registerFactory( Factory* factory);
50  /** \brief sets the Next factory in the list \param nextFactory the next factory */
51  inline void setNext( Factory* nextFactory) { this->next = nextFactory; };
52  /** \returns the next factory */
53  Factory* getNext(void) const { return this->next; };
54
55 private:
56  Factory*          next;                 //!< pointer to the next factory.
57  static Factory*   first;                //!< A pointer to the first factory.
58};
59
60/**
61   \brief a factory that is able to load any kind of Object
62   (this is a Functor)
63*/
64template<class T> class tFactory : public Factory
65{
66 public:
67  tFactory(const char* factoryName);
68  virtual ~tFactory();
69
70  private:
71  BaseObject* fabricate(const TiXmlElement* root);
72};
73
74/**
75   \brief construnts a factory with
76   \param factoryName the name of the factory
77*/
78template<class T>
79tFactory<T>::tFactory(const char* factoryName) : Factory(factoryName)
80{
81  PRINTF(5)("fileName: %s loadable\n", this->getName());
82}
83
84
85template<class T>
86tFactory<T>::~tFactory()
87{}
88
89template<class T>
90BaseObject* tFactory<T>::fabricate(const TiXmlElement* root)
91{
92  if(!strcmp(root->Value(), getName()))
93    return new T ( root);
94  else if( getNext() != NULL)
95    return getNext()->fabricate( root);
96  else
97    return NULL;
98}
99
100#endif /* _FACTORY_H */
101
Note: See TracBrowser for help on using the repository browser.