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.

163 lines
4.6KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2017 - ROLI Ltd.
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. The code included in this file is provided under the terms of the ISC license
  8. http://www.isc.org/downloads/software-support-policy/isc-license. Permission
  9. To use, copy, modify, and/or distribute this software for any purpose with or
  10. without fee is hereby granted provided that the above copyright notice and
  11. this permission notice appear in all copies.
  12. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  13. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  14. DISCLAIMED.
  15. ==============================================================================
  16. */
  17. #pragma once
  18. //==============================================================================
  19. /** Current JUCE version number.
  20. See also SystemStats::getJUCEVersion() for a string version.
  21. */
  22. #define JUCE_MAJOR_VERSION 5
  23. #define JUCE_MINOR_VERSION 1
  24. #define JUCE_BUILDNUMBER 1
  25. /** Current Juce version number.
  26. Bits 16 to 32 = major version.
  27. Bits 8 to 16 = minor version.
  28. Bits 0 to 8 = point release.
  29. See also SystemStats::getJUCEVersion() for a string version.
  30. */
  31. #define JUCE_VERSION ((JUCE_MAJOR_VERSION << 16) + (JUCE_MINOR_VERSION << 8) + JUCE_BUILDNUMBER)
  32. //==============================================================================
  33. #include <memory>
  34. #include <cmath>
  35. #include <vector>
  36. #include <iostream>
  37. #include <functional>
  38. #include <algorithm>
  39. #include <limits>
  40. //==============================================================================
  41. #include "juce_CompilerSupport.h"
  42. #include "juce_PlatformDefs.h"
  43. //==============================================================================
  44. // Now we'll include some common OS headers..
  45. #if JUCE_MSVC
  46. #pragma warning (push)
  47. #pragma warning (disable: 4514 4245 4100)
  48. #include <intrin.h>
  49. #endif
  50. #if JUCE_MAC || JUCE_IOS
  51. #include <libkern/OSAtomic.h>
  52. #include <xlocale.h>
  53. #endif
  54. #if JUCE_LINUX
  55. #include <cstring>
  56. #include <signal.h>
  57. #if __INTEL_COMPILER
  58. #if __ia64__
  59. #include <ia64intrin.h>
  60. #else
  61. #include <ia32intrin.h>
  62. #endif
  63. #endif
  64. #endif
  65. #if JUCE_MSVC && JUCE_DEBUG
  66. #include <crtdbg.h>
  67. #endif
  68. #if JUCE_MSVC
  69. #pragma warning (pop)
  70. #endif
  71. #if JUCE_MINGW
  72. #include <cstring>
  73. #include <sys/types.h>
  74. #endif
  75. #if JUCE_ANDROID
  76. #include <cstring>
  77. #include <atomic>
  78. #include <byteswap.h>
  79. #endif
  80. // undef symbols that are sometimes set by misguided 3rd-party headers..
  81. #undef TYPE_BOOL
  82. #undef max
  83. #undef min
  84. #undef major
  85. #undef minor
  86. #undef KeyPress
  87. // Include a replacement for std::function on older platforms and the live
  88. // build
  89. #if JUCE_PROJUCER_LIVE_BUILD || ! defined (JUCE_STDLIB_HAS_STD_FUNCTION_SUPPORT)
  90. #include "../misc/juce_StdFunctionCompat.h"
  91. #endif
  92. // Include std::atomic if it's supported by the compiler
  93. #if JUCE_ATOMIC_AVAILABLE
  94. #include <atomic>
  95. #endif
  96. //==============================================================================
  97. // DLL building settings on Windows
  98. #if JUCE_MSVC
  99. #ifdef JUCE_DLL_BUILD
  100. #define JUCE_API __declspec (dllexport)
  101. #pragma warning (disable: 4251)
  102. #elif defined (JUCE_DLL)
  103. #define JUCE_API __declspec (dllimport)
  104. #pragma warning (disable: 4251)
  105. #endif
  106. #ifdef __INTEL_COMPILER
  107. #pragma warning (disable: 1125) // (virtual override warning)
  108. #endif
  109. #elif defined (JUCE_DLL) || defined (JUCE_DLL_BUILD)
  110. #define JUCE_API __attribute__ ((visibility("default")))
  111. #endif
  112. //==============================================================================
  113. #ifndef JUCE_API
  114. #define JUCE_API /**< This macro is added to all juce public class declarations. */
  115. #endif
  116. #if JUCE_MSVC && JUCE_DLL_BUILD
  117. #define JUCE_PUBLIC_IN_DLL_BUILD(declaration) public: declaration; private:
  118. #else
  119. #define JUCE_PUBLIC_IN_DLL_BUILD(declaration) declaration;
  120. #endif
  121. /** This macro is added to all juce public function declarations. */
  122. #define JUCE_PUBLIC_FUNCTION JUCE_API JUCE_CALLTYPE
  123. #if (! defined (JUCE_CATCH_DEPRECATED_CODE_MISUSE)) && JUCE_DEBUG && ! DOXYGEN
  124. /** This turns on some non-essential bits of code that should prevent old code from compiling
  125. in cases where method signatures have changed, etc.
  126. */
  127. #define JUCE_CATCH_DEPRECATED_CODE_MISUSE 1
  128. #endif
  129. #ifndef DOXYGEN
  130. #define JUCE_NAMESPACE juce // This old macro is deprecated: you should just use the juce namespace directly.
  131. #endif