2009-02-04 02:01:00 +01:00
|
|
|
#ifndef __COSMOTOOL_CONFIG_HPP
|
|
|
|
#define __COSMOTOOL_CONFIG_HPP
|
2008-12-02 18:00:28 +01:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <exception>
|
|
|
|
#include <cstring>
|
|
|
|
|
|
|
|
namespace CosmoTool
|
|
|
|
{
|
|
|
|
|
|
|
|
#define NUMDIMS 3
|
|
|
|
#define NUMCUBES 8
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base type to specity at what precision we
|
|
|
|
* must achieve computations.
|
|
|
|
*/
|
|
|
|
typedef double ComputePrecision;
|
|
|
|
/**
|
|
|
|
* Coordinate type (should be a 3-array).
|
|
|
|
*/
|
|
|
|
typedef double Coordinates[NUMDIMS];
|
2009-01-10 02:10:49 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Single precision coordinates.
|
|
|
|
*/
|
|
|
|
typedef float FCoordinates[NUMDIMS];
|
2008-12-02 18:00:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This function is used whenever one needs a general
|
|
|
|
* conversion between mass and luminosity (or the opposite).
|
|
|
|
* It should take a "mass" (or luminosity) in input, a unit is
|
|
|
|
* given to convert this mass into solar units. The output should
|
|
|
|
* be the "luminosity" (or mass), in solar units.
|
|
|
|
*/
|
|
|
|
typedef double (*BiasFunction)(double mass, double unit);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to copy the coordinates "a" into "b".
|
|
|
|
*/
|
|
|
|
inline void copyCoordinates(const Coordinates& a, Coordinates& b)
|
|
|
|
{
|
|
|
|
memcpy(b, a, sizeof(a));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base exception class for all exceptions handled by
|
|
|
|
* this library.
|
|
|
|
*/
|
|
|
|
class Exception : public std::exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Exception(const char *mess = 0)
|
|
|
|
: msg(mess) {}
|
|
|
|
|
2009-08-26 18:54:26 +02:00
|
|
|
const char *getMessage() const { return msg != 0 ? msg : "No message"; };
|
|
|
|
virtual const char *what() const throw () { return msg != 0 ? msg : "What 'what' ?"; };
|
2008-12-02 18:00:28 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
const char *msg;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Exception raised when an invalid argument has been
|
|
|
|
* passed to a function of the library.
|
|
|
|
*/
|
|
|
|
class InvalidArgumentException : public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
InvalidArgumentException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
class InvalidRangeException : public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
InvalidRangeException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
class NoSuchFileException : public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
NoSuchFileException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
class InvalidFileFormatException : public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
InvalidFileFormatException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
2009-01-08 16:18:28 +01:00
|
|
|
|
|
|
|
class EndOfFileException: public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
EndOfFileException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
2009-08-26 18:54:26 +02:00
|
|
|
|
|
|
|
class FilesystemFullException: public Exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
FilesystemFullException(const char *mess = 0)
|
|
|
|
: Exception(mess) {}
|
|
|
|
};
|
2008-12-02 18:00:28 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|