9#include <QCoreApplication>
12#include "IException.h"
14#include "EmbreeTargetManager.h"
31 : m_maxCacheSize(10) {
43 for (
int i = 0; i < targetFiles.size(); i++) {
144 QString msg =
"Failed creating EmbreeTargetShape for [" + shapeFile
145 +
"] Too many EmbreeTargetShapes are already open.";
152 ++(targetShapeContainer.m_referenceCount);
154 return ( targetShapeContainer.m_targetShape );
179 QString msg =
"Cannot free EmbreeTargetShape for file ["
180 + fullPath +
"] because it is not stored in the cache.";
188 int newCount = --(
m_targeCache[fullPath].m_referenceCount);
191 if ( newCount < 1 ) {
216 QString msg =
"Cannot free EmbreeTargetShape for file ["
217 + fullPath +
"] because it is not stored in the cache.";
223 delete targetContainer.m_targetShape;
Class for managing the construction and destruction of EmbreeTargetShapes.
int maxCacheSize() const
Return the maximum number of stored EmbreeTargetShapes.
void removeTargetShape(const QString &shapeFile)
Method for removing an EmbreeTargetShape from the internal cache.
EmbreeTargetShape * create(const QString &shapeFile)
Get a pointer to an EmbreeTargetShape containing the information from a shape file.
static void DieAtExit()
Exit termination routine.
EmbreeTargetManager()
This constructor will initialize the EmbreeTargetManager object to default values.
QString fullFilePath(const QString &filePath) const
Helper function that takes a file path and returns the full file path.
bool inCache(const QString &shapeFile) const
Check if there is an already created EmbreeTargetShape for a file.
void free(const QString &shapeFile)
Notify the manager that an EmbreeTargetShape is no longer in use.
int m_maxCacheSize
!< The cache of created target shapes.
void setMaxCacheSize(const int &numShapes)
Set the maximum number of stored EmbreeTargetShapes.
static EmbreeTargetManager * getInstance()
Retrieve reference to Singleton instance of this object.
int currentCacheSize() const
Return the number of currently stored EmbreeTargetShapes.
static EmbreeTargetManager * m_maker
Initialize the singleton factory pointer.
QMap< QString, EmbreeTargetShapeContainer > m_targeCache
!< Pointer to the singleton factory.
~EmbreeTargetManager()
Destructor that frees all of the EmbreeTargetShapes managed by this object.
Embree Target Shape for planetary bodies.
File name manipulation and expansion.
QString expanded() const
Returns a QString of the full file name including the file path, excluding the attributes.
@ Programmer
This error is for when a programmer made an API call that was illegal.
This is free and unencumbered software released into the public domain.
Namespace for the standard library.
Reference counting container for EmbreeTargetShapes.