/usr/include/ql/qldefines.hpp is in libquantlib0-dev 1.4-2+b1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2000, 2001, 2002, 2003 RiskMap srl
Copyright (C) 2003, 2004, 2005, 2006, 2007 StatPro Italia srl
This file is part of QuantLib, a free-software/open-source library
for financial quantitative analysts and developers - http://quantlib.org/
QuantLib is free software: you can redistribute it and/or modify it
under the terms of the QuantLib license. You should have received a
copy of the license along with this program; if not, please email
<quantlib-dev@lists.sf.net>. The license is also available online at
<http://quantlib.org/license.shtml>.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the license for more details.
*/
/*! \file qldefines.hpp
\brief Global definitions and compiler switches.
*/
#ifndef quantlib_defines_hpp
#define QL_HAVE_CONFIG_H
#define quantlib_defines_hpp
#ifdef _MSC_VER
/* Microsoft-specific, but needs to be defined before
including <boost/config.hpp> which somehow includes
<math.h> under VC++10
*/
#define _USE_MATH_DEFINES
#endif
#include <boost/config.hpp>
#include <boost/version.hpp>
#if BOOST_VERSION < 103900
#error using an old version of Boost, please update.
#endif
#if !defined(BOOST_ENABLE_ASSERT_HANDLER)
#define BOOST_ENABLE_ASSERT_HANDLER
#endif
/* eventually these will go into userconfig.hpp.
For the time being, we hard code them here.
*/
#define QL_INTEGER int
#define QL_BIG_INTEGER long
#define QL_REAL double
/*! \defgroup macros QuantLib macros
Global definitions and a few macros which help porting the
code to different compilers.
@{
*/
#if (defined(_DEBUG) || defined(DEBUG))
#define QL_DEBUG
#endif
#if defined(QL_HAVE_CONFIG_H) // Dynamically created by configure
#include <ql/config.hpp>
/* Use BOOST_MSVC instead of _MSC_VER since some other vendors (Metrowerks,
for example) also #define _MSC_VER
*/
#elif defined(BOOST_MSVC) // Microsoft Visual C++
#include <ql/config.msvc.hpp>
#elif defined(__MINGW32__) // Minimalistic GNU for Windows
#include <ql/config.mingw.hpp>
#elif defined(__SUNPRO_CC) // Sun Studio
#include <ql/config.sun.hpp>
#else // We hope that the compiler follows ANSI
#include <ql/config.ansi.hpp>
#endif
// extra debug checks
#ifdef QL_DEBUG
#ifndef QL_EXTRA_SAFETY_CHECKS
#define QL_EXTRA_SAFETY_CHECKS
#endif
#endif
// ensure that needed math constants are defined
#include <ql/mathconstants.hpp>
// import global functions into std namespace
#if defined(BOOST_NO_STDC_NAMESPACE)
#include <cmath>
namespace std {
using ::sqrt; using ::abs; using ::fabs;
using ::exp; using ::log; using ::pow;
using ::sin; using ::cos; using ::asin; using ::acos;
using ::sinh; using ::cosh;
using ::floor; using ::fmod; using ::modf;
}
#endif
/*! \defgroup limitMacros Numeric limits
Some compilers do not give an implementation of
<code>\<limits\></code> yet. For the code to be portable
these macros should be used instead of the corresponding method of
<code>std::numeric_limits</code> or the corresponding macro
defined in <code><limits.h></code>.
@{
*/
/*! \def QL_MIN_INTEGER
Defines the value of the largest representable negative integer value
*/
/*! \def QL_MAX_INTEGER
Defines the value of the largest representable integer value
*/
/*! \def QL_MIN_REAL
Defines the value of the largest representable negative
floating-point value
*/
/*! \def QL_MIN_POSITIVE_REAL
Defines the value of the smallest representable positive double value
*/
/*! \def QL_MAX_REAL
Defines the value of the largest representable floating-point value
*/
/*! \def QL_EPSILON
Defines the machine precision for operations over doubles
*/
#include <boost/limits.hpp>
// limits used as such
#define QL_MIN_INTEGER ((std::numeric_limits<QL_INTEGER>::min)())
#define QL_MAX_INTEGER ((std::numeric_limits<QL_INTEGER>::max)())
#define QL_MIN_REAL -((std::numeric_limits<QL_REAL>::max)())
#define QL_MAX_REAL ((std::numeric_limits<QL_REAL>::max)())
#define QL_MIN_POSITIVE_REAL ((std::numeric_limits<QL_REAL>::min)())
#define QL_EPSILON ((std::numeric_limits<QL_REAL>::epsilon)())
// specific values---these should fit into any Integer or Real
#define QL_NULL_INTEGER ((std::numeric_limits<int>::max)())
#define QL_NULL_REAL ((std::numeric_limits<float>::max)())
/*! @} */
/*! @} */
// emit warning when using deprecated features
#if defined(BOOST_MSVC) // Microsoft Visual C++
#define QL_DEPRECATED __declspec(deprecated)
#elif defined(__GNUC__) || defined(__clang__)
#define QL_DEPRECATED __attribute__((deprecated))
#else
// we don't know how to enable it, just define the macro away
#define QL_DEPRECATED
#endif
#endif
|