Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

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

Last change on this file since 5155 was 5155, checked in by bensch, 20 years ago

orxonox/trunk: now one should be able to create entities on the Fly

File size: 2.5 KB
RevLine 
[4597]1/*
[4250]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
[4597]16/*!
[4885]17 * @file factory.h
18 * @brief A loadable object handler
[3940]19*/
20
[4250]21
[3940]22#ifndef _FACTORY_H
23#define _FACTORY_H
24
25class BaseObject;
26
[4239]27#include "tinyxml.h"
[4597]28#include "base_object.h"
[4171]29#include "debug.h"
[3940]30
[4597]31/**
[4885]32 * Creates a factory to a Loadable Class.
33 * this should be used at the beginning of all the Classes that should be loadable (in the cc-file)
[4004]34*/
[4885]35#define CREATE_FACTORY(CLASS_NAME) \
36    tFactory<CLASS_NAME>* global_##CLASS_NAME##_Factory = new tFactory<CLASS_NAME>(#CLASS_NAME)
[4487]37
38//! The Factory is a loadable object handler
[4597]39class Factory : public BaseObject {
[3940]40
41 public:
[4487]42  Factory (const char* factoryName = NULL);
[3940]43  ~Factory ();
44
[5155]45  void fabricate(const char* className, const char* entityName);
[4730]46  virtual BaseObject* fabricate(const TiXmlElement* root) = NULL;
[4739]47
48  static void registerFactory( Factory* factory);
[4836]49  /** @returns the first factory */
[4739]50  static Factory* getFirst() { return Factory::first; };
[4597]51
[4932]52  protected:
53    /** sets the Next factory in the list @param nextFactory the next factory */
54    inline void setNext( Factory* nextFactory) { this->next = nextFactory; };
55    /** @returns the next factory */
56    Factory* getNext() const { return this->next; };
57
[4739]58  private:
59    Factory*          next;                 //!< pointer to the next factory.
60    static Factory*   first;                //!< A pointer to the first factory.
[3940]61};
62
[4487]63/**
[4836]64 *  a factory that is able to load any kind of Object
[4487]65   (this is a Functor)
66*/
[4004]67template<class T> class tFactory : public Factory
68{
69 public:
[4487]70  tFactory(const char* factoryName);
[4004]71  virtual ~tFactory();
[4597]72
[4004]73  private:
[4730]74  virtual BaseObject* fabricate(const TiXmlElement* root);
[4004]75};
76
[4487]77/**
[4836]78 *  construnts a factory with
79 * @param factoryName the name of the factory
[4487]80*/
[4004]81template<class T>
[4487]82tFactory<T>::tFactory(const char* factoryName) : Factory(factoryName)
[4004]83{
[4730]84  PRINTF(5)("Class: %s loadable\n", this->getName());
[4004]85}
86
[4597]87
[4004]88template<class T>
89tFactory<T>::~tFactory()
90{}
91
92template<class T>
[4597]93BaseObject* tFactory<T>::fabricate(const TiXmlElement* root)
94{
[4730]95  if(!strcmp(root->Value(), this->getName()))
[4004]96    return new T ( root);
[4597]97  else if( getNext() != NULL)
[4004]98    return getNext()->fabricate( root);
[4597]99  else
[4004]100    return NULL;
101}
102
[3940]103#endif /* _FACTORY_H */
104
Note: See TracBrowser for help on using the repository browser.