The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

214 lines
7.3KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library - "Jules' Utility Class Extensions"
  4. Copyright 2004-11 by Raw Material Software Ltd.
  5. ------------------------------------------------------------------------------
  6. JUCE can be redistributed and/or modified under the terms of the GNU General
  7. Public License (Version 2), as published by the Free Software Foundation.
  8. A copy of the license is included in the JUCE distribution, or can be found
  9. online at www.gnu.org/licenses.
  10. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  11. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  12. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  13. ------------------------------------------------------------------------------
  14. To release a closed-source product which uses JUCE, commercial licenses are
  15. available: visit www.rawmaterialsoftware.com/juce for more information.
  16. ==============================================================================
  17. */
  18. #ifndef __JUCE_STANDARDHEADER_JUCEHEADER__
  19. #define __JUCE_STANDARDHEADER_JUCEHEADER__
  20. //==============================================================================
  21. /** Current JUCE version number.
  22. See also SystemStats::getJUCEVersion() for a string version.
  23. */
  24. #define JUCE_MAJOR_VERSION 2
  25. #define JUCE_MINOR_VERSION 0
  26. #define JUCE_BUILDNUMBER 11
  27. /** Current Juce version number.
  28. Bits 16 to 32 = major version.
  29. Bits 8 to 16 = minor version.
  30. Bits 0 to 8 = point release.
  31. See also SystemStats::getJUCEVersion() for a string version.
  32. */
  33. #define JUCE_VERSION ((JUCE_MAJOR_VERSION << 16) + (JUCE_MINOR_VERSION << 8) + JUCE_BUILDNUMBER)
  34. //==============================================================================
  35. #include "juce_TargetPlatform.h" // (sets up the various JUCE_WINDOWS, JUCE_MAC, etc flags)
  36. //==============================================================================
  37. #define JUCE_NAMESPACE juce
  38. #define BEGIN_JUCE_NAMESPACE namespace juce {
  39. #define END_JUCE_NAMESPACE }
  40. //==============================================================================
  41. #include "juce_PlatformDefs.h"
  42. // Now we'll include any OS headers we need.. (at this point we are outside the Juce namespace).
  43. #if JUCE_MSVC
  44. #if JUCE_VC6
  45. #pragma warning (disable: 4284 4786) // (spurious VC6 warnings)
  46. namespace std // VC6 doesn't have sqrt/sin/cos/tan/abs in std, so declare them here:
  47. {
  48. template <typename Type> Type abs (Type a) { if (a < 0) return -a; return a; }
  49. template <typename Type> Type tan (Type a) { return static_cast<Type> (::tan (static_cast<double> (a))); }
  50. template <typename Type> Type sin (Type a) { return static_cast<Type> (::sin (static_cast<double> (a))); }
  51. template <typename Type> Type asin (Type a) { return static_cast<Type> (::asin (static_cast<double> (a))); }
  52. template <typename Type> Type cos (Type a) { return static_cast<Type> (::cos (static_cast<double> (a))); }
  53. template <typename Type> Type sqrt (Type a) { return static_cast<Type> (::sqrt (static_cast<double> (a))); }
  54. template <typename Type> Type floor (Type a) { return static_cast<Type> (::floor (static_cast<double> (a))); }
  55. template <typename Type> Type ceil (Type a) { return static_cast<Type> (::ceil (static_cast<double> (a))); }
  56. template <typename Type> Type atan2 (Type a, Type b) { return static_cast<Type> (::atan2 (static_cast<double> (a), static_cast<double> (b))); }
  57. }
  58. #endif
  59. #pragma warning (push)
  60. #pragma warning (disable: 4514 4245 4100)
  61. #endif
  62. #include <cstdlib>
  63. #include <cstdarg>
  64. #include <climits>
  65. #include <limits>
  66. #include <cmath>
  67. #include <cwchar>
  68. #include <stdexcept>
  69. #include <typeinfo>
  70. #include <cstring>
  71. #include <cstdio>
  72. #include <iostream>
  73. #include <vector>
  74. #if JUCE_USE_INTRINSICS
  75. #include <intrin.h>
  76. #endif
  77. #if JUCE_MAC || JUCE_IOS
  78. #include <libkern/OSAtomic.h>
  79. #endif
  80. #if JUCE_LINUX
  81. #include <signal.h>
  82. #if __INTEL_COMPILER
  83. #if __ia64__
  84. #include <ia64intrin.h>
  85. #else
  86. #include <ia32intrin.h>
  87. #endif
  88. #endif
  89. #endif
  90. #if JUCE_MSVC && JUCE_DEBUG
  91. #include <crtdbg.h>
  92. #endif
  93. #if JUCE_MSVC
  94. #include <malloc.h>
  95. #pragma warning (pop)
  96. #endif
  97. #if JUCE_ANDROID
  98. #include <sys/atomics.h>
  99. #include <byteswap.h>
  100. #endif
  101. //==============================================================================
  102. // DLL building settings on Windows
  103. #if JUCE_MSVC
  104. #ifdef JUCE_DLL_BUILD
  105. #define JUCE_API __declspec (dllexport)
  106. #pragma warning (disable: 4251)
  107. #elif defined (JUCE_DLL)
  108. #define JUCE_API __declspec (dllimport)
  109. #pragma warning (disable: 4251)
  110. #endif
  111. #ifdef __INTEL_COMPILER
  112. #pragma warning (disable: 1125) // (virtual override warning)
  113. #endif
  114. #elif defined (__GNUC__) && ((__GNUC__ >= 4) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
  115. #ifdef JUCE_DLL_BUILD
  116. #define JUCE_API __attribute__ ((visibility("default")))
  117. #endif
  118. #endif
  119. #ifndef JUCE_API
  120. /** This macro is added to all juce public class declarations. */
  121. #define JUCE_API
  122. #endif
  123. /** This macro is added to all juce public function declarations. */
  124. #define JUCE_PUBLIC_FUNCTION JUCE_API JUCE_CALLTYPE
  125. /** This turns on some non-essential bits of code that should prevent old code from compiling
  126. in cases where method signatures have changed, etc.
  127. */
  128. #if (! defined (JUCE_CATCH_DEPRECATED_CODE_MISUSE)) && JUCE_DEBUG && ! DOXYGEN
  129. #define JUCE_CATCH_DEPRECATED_CODE_MISUSE 1
  130. #endif
  131. //==============================================================================
  132. // Now include some basics that are needed by most of the Juce classes...
  133. BEGIN_JUCE_NAMESPACE
  134. extern JUCE_API bool JUCE_CALLTYPE juce_isRunningUnderDebugger();
  135. #if JUCE_LOG_ASSERTIONS
  136. extern JUCE_API void juce_LogAssertion (const char* filename, int lineNum) noexcept;
  137. #endif
  138. #include "../memory/juce_Memory.h"
  139. #include "../maths/juce_MathsFunctions.h"
  140. #include "../memory/juce_ByteOrder.h"
  141. #include "../logging/juce_Logger.h"
  142. #include "../memory/juce_LeakedObjectDetector.h"
  143. // unbelievably, some system headers actually use macros to define these symbols:
  144. #undef check
  145. #undef TYPE_BOOL
  146. //==============================================================================
  147. #if JUCE_MAC || JUCE_IOS || DOXYGEN
  148. /** A handy C++ wrapper that creates and deletes an NSAutoreleasePool object using RAII.
  149. You should use the JUCE_AUTORELEASEPOOL macro to create a local auto-release pool on the stack.
  150. */
  151. class JUCE_API ScopedAutoReleasePool
  152. {
  153. public:
  154. ScopedAutoReleasePool();
  155. ~ScopedAutoReleasePool();
  156. private:
  157. void* pool;
  158. JUCE_DECLARE_NON_COPYABLE (ScopedAutoReleasePool);
  159. };
  160. /** A macro that can be used to easily declare a local ScopedAutoReleasePool object for RAII-based obj-C autoreleasing. */
  161. #define JUCE_AUTORELEASEPOOL const juce::ScopedAutoReleasePool JUCE_JOIN_MACRO (autoReleasePool_, __LINE__);
  162. #else
  163. #define JUCE_AUTORELEASEPOOL
  164. #endif
  165. END_JUCE_NAMESPACE
  166. #endif // __JUCE_STANDARDHEADER_JUCEHEADER__