Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/orxonox/trunk/src/util/object_manager.cc @ 4695

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

orxonox/trunk: setClassID implemented in all files

File size: 3.0 KB
RevLine 
[4592]1/*
[4245]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: Patrick Boenzli
13*/
14
15#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_OBJECT_MANAGER
16
17#include "object_manager.h"
[4288]18#include "garbage_collector.h"
[4286]19#include "list.h"
[4245]20
[4288]21
[4245]22using namespace std;
23
24
25/**
26   \brief standard constructor
27*/
[4592]28ObjectManager::ObjectManager ()
[4245]29{
[4320]30  this->setClassID(CL_OBJECT_MANAGER, "ObjectManager");
[4597]31  this->setName("ObjectManager");
[4592]32
[4286]33  this->managedObjectList = new tList<BaseObject>*[CL_NUMBER];
[4318]34  for(int i = 0; i < CL_NUMBER; ++i)
35    {
36      this->managedObjectList[i] = NULL;
37    }
[4288]38
39  this->garbageCollector = GarbageCollector::getInstance();
[4245]40}
41
[4322]42
[4245]43/**
44   \brief the singleton reference to this class
45*/
46ObjectManager* ObjectManager::singletonRef = NULL;
47
48/**
49   \brief standard deconstructor
50*/
[4592]51ObjectManager::~ObjectManager ()
[4245]52{
53  ObjectManager::singletonRef = NULL;
[4285]54}
[4245]55
[4485]56/**
57   \brief adds an element to the list of dead objects
58   \param index: The type of object to add
59   \param object: pointer to the object at hand
60*/
[4322]61void ObjectManager::addToDeadList(int index, BaseObject* object)
[4288]62{
63  if( likely(this->managedObjectList[index] != NULL))
64    this->managedObjectList[index]->add(object);
65  else
[4324]66    PRINTF(0)(" Critical: unable to add object to the list nr. %i: no list initialized - ignoring\n", index);
[4288]67}
[4285]68
[4485]69/**
70   \brief resurects an object
71   \param index: the type of resource to load
72   \param number: how many of them
[4285]73
[4485]74   \todo if it is unable to get an object from the deadList, it should create it
75*/
[4322]76BaseObject* ObjectManager::getFromDeadList(int index, int number)
[4289]77{
78  if( likely(this->managedObjectList[index] != NULL))
79    {
80      BaseObject* obj = this->managedObjectList[index]->firstElement();
81      this->managedObjectList[index]->remove(obj);
[4324]82      if( unlikely(obj == NULL))
[4592]83        {
84          PRINTF(0)("Critical: there was no object anymore in the dead list! This could result in Segfaults\n");
85        }
[4289]86      return obj;
87    }
88  else
[4324]89    PRINTF(0)(" Critical: unable to get object from the list nr. %i: no elements initialized - ignoring\n", index);
90  return NULL;
[4289]91}
[4287]92
[4485]93/**
94   \brief outputs some simple debug information about the ObjectManage
95*/
96void ObjectManager::debug(void) const
[4287]97{
98  PRINT(0)("\n==========================| ObjectManager::debug() |===\n");
[4592]99  PRINT(0)("=  Number of registerable classes: %i\n", CL_NUMBER );
[4287]100  PRINT(0)("=  Currently cached objects: \n");
101  for(int i = 0; i < CL_NUMBER; ++i)
102    {
[4318]103      if( this->managedObjectList[i] != NULL)
[4592]104        PRINT(0)("=   o Class Nr. %i has cached %i object(s)\n", i, this->managedObjectList[i]->getSize());
[4287]105      else
[4592]106        PRINT(0)("=   o Class Nr. %i has cached 0 object(s)\n", i);
[4287]107    }
108  PRINT(0)("=======================================================\n");
109}
Note: See TracBrowser for help on using the repository browser.