Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

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

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

orxonox/trunk: renamed all the \param → @param and so on in Doxygen tags.
Thanks a lot to the kDevelop team. this took since the last commit :)

File size: 2.9 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/**
[4836]26 *  standard constructor
[4245]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    }
[4245]38}
39
[4322]40
[4245]41/**
[4836]42 *  the singleton reference to this class
[4245]43*/
44ObjectManager* ObjectManager::singletonRef = NULL;
45
46/**
[4836]47 *  standard deconstructor
[4245]48*/
[4592]49ObjectManager::~ObjectManager ()
[4245]50{
51  ObjectManager::singletonRef = NULL;
[4285]52}
[4245]53
[4485]54/**
[4836]55 *  adds an element to the list of dead objects
56 * @param index: The type of object to add
57 * @param object: pointer to the object at hand
[4485]58*/
[4322]59void ObjectManager::addToDeadList(int index, BaseObject* object)
[4288]60{
61  if( likely(this->managedObjectList[index] != NULL))
62    this->managedObjectList[index]->add(object);
63  else
[4324]64    PRINTF(0)(" Critical: unable to add object to the list nr. %i: no list initialized - ignoring\n", index);
[4288]65}
[4285]66
[4485]67/**
[4836]68 *  resurects an object
69 * @param index: the type of resource to load
70 * @param number: how many of them
[4285]71
[4836]72   @todo if it is unable to get an object from the deadList, it should create it
[4485]73*/
[4322]74BaseObject* ObjectManager::getFromDeadList(int index, int number)
[4289]75{
76  if( likely(this->managedObjectList[index] != NULL))
77    {
78      BaseObject* obj = this->managedObjectList[index]->firstElement();
79      this->managedObjectList[index]->remove(obj);
[4324]80      if( unlikely(obj == NULL))
[4592]81        {
82          PRINTF(0)("Critical: there was no object anymore in the dead list! This could result in Segfaults\n");
83        }
[4289]84      return obj;
85    }
86  else
[4324]87    PRINTF(0)(" Critical: unable to get object from the list nr. %i: no elements initialized - ignoring\n", index);
88  return NULL;
[4289]89}
[4287]90
[4485]91/**
[4836]92 *  outputs some simple debug information about the ObjectManage
[4485]93*/
[4746]94void ObjectManager::debug() const
[4287]95{
96  PRINT(0)("\n==========================| ObjectManager::debug() |===\n");
[4592]97  PRINT(0)("=  Number of registerable classes: %i\n", CL_NUMBER );
[4287]98  PRINT(0)("=  Currently cached objects: \n");
99  for(int i = 0; i < CL_NUMBER; ++i)
100    {
[4318]101      if( this->managedObjectList[i] != NULL)
[4592]102        PRINT(0)("=   o Class Nr. %i has cached %i object(s)\n", i, this->managedObjectList[i]->getSize());
[4287]103      else
[4592]104        PRINT(0)("=   o Class Nr. %i has cached 0 object(s)\n", i);
[4287]105    }
106  PRINT(0)("=======================================================\n");
107}
Note: See TracBrowser for help on using the repository browser.