|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396 |
-
- #ifndef CARLA_JUCE_APPCONFIG_H_INCLUDED
- #define CARLA_JUCE_APPCONFIG_H_INCLUDED
-
- // --------------------------------------------------------------------------------------------------------------------
- // Check OS
-
- #if defined(WIN64) || defined(_WIN64) || defined(__WIN64__)
- # define APPCONFIG_OS_WIN64
- #elif defined(WIN32) || defined(_WIN32) || defined(__WIN32__)
- # define APPCONFIG_OS_WIN32
- #elif defined(__APPLE__)
- # define APPCONFIG_OS_MAC
- #elif defined(__HAIKU__)
- # define APPCONFIG_OS_HAIKU
- #elif defined(__linux__) || defined(__linux)
- # define APPCONFIG_OS_LINUX
- #else
- # warning Unsupported platform!
- #endif
-
- #if defined(APPCONFIG_OS_WIN32) || defined(APPCONFIG_OS_WIN64)
- # define APPCONFIG_OS_WIN
- #elif defined(APPCONFIG_OS_LINUX) || defined(APPCONFIG_OS_MAC)
- # define APPCONFIG_OS_UNIX
- #endif
-
- // --------------------------------------------------------------------------------------------------------------------
-
- // always enabled
- #define JUCE_MODULE_AVAILABLE_juce_audio_basics 1
- #define JUCE_MODULE_AVAILABLE_juce_audio_formats 1
- #define JUCE_MODULE_AVAILABLE_juce_core 1
-
- // always disabled
- #define JUCE_MODULE_AVAILABLE_juce_audio_plugin_client 0
- #define JUCE_MODULE_AVAILABLE_juce_audio_utils 0
- #define JUCE_MODULE_AVAILABLE_juce_cryptography 0
- #define JUCE_MODULE_AVAILABLE_juce_opengl 0
- #define JUCE_MODULE_AVAILABLE_juce_video 0
-
- // conditional
- #if defined(APPCONFIG_OS_MAC) || defined(APPCONFIG_OS_WIN)
- # define JUCE_MODULE_AVAILABLE_juce_audio_devices 1
- # define JUCE_MODULE_AVAILABLE_juce_audio_processors 1
- # define JUCE_MODULE_AVAILABLE_juce_data_structures 1
- # define JUCE_MODULE_AVAILABLE_juce_events 1
- # define JUCE_MODULE_AVAILABLE_juce_graphics 1
- # define JUCE_MODULE_AVAILABLE_juce_gui_basics 1
- # define JUCE_MODULE_AVAILABLE_juce_gui_extra 1
- #else
- # define JUCE_MODULE_AVAILABLE_juce_audio_devices 0
- # define JUCE_MODULE_AVAILABLE_juce_audio_processors 0
- # define JUCE_MODULE_AVAILABLE_juce_data_structures 0
- # define JUCE_MODULE_AVAILABLE_juce_events 0
- # define JUCE_MODULE_AVAILABLE_juce_graphics 0
- # define JUCE_MODULE_AVAILABLE_juce_gui_basics 0
- # define JUCE_MODULE_AVAILABLE_juce_gui_extra 0
- #endif
-
- // misc
- #define JUCE_DISABLE_JUCE_VERSION_PRINTING 1
- #define JUCE_GLOBAL_MODULE_SETTINGS_INCLUDED 1
- #define JUCE_STANDALONE_APPLICATION 0
- #define JUCE_STRING_UTF_TYPE 8
- #define JUCE_USE_VFORK 1
-
- #if ! (defined(APPCONFIG_OS_MAC) || defined(APPCONFIG_OS_WIN))
- # define JUCE_MODAL_LOOPS_PERMITTED 0
- # define JUCE_AUDIO_PROCESSOR_NO_GUI 1
- #endif
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_audio_basics
-
- // nothing here
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_audio_devices
-
- //=============================================================================
- /** Config: JUCE_ASIO
- Enables ASIO audio devices (MS Windows only).
- Turning this on means that you'll need to have the Steinberg ASIO SDK installed
- on your Windows build machine.
-
- See the comments in the ASIOAudioIODevice class's header file for more
- info about this.
- */
- #ifdef APPCONFIG_OS_WIN
- #define JUCE_ASIO 1
- #else
- #define JUCE_ASIO 0
- #endif
-
- /** Config: JUCE_WASAPI
- Enables WASAPI audio devices (Windows Vista and above).
- */
- #define JUCE_WASAPI 0
-
- /** Config: JUCE_DIRECTSOUND
- Enables DirectSound audio (MS Windows only).
- */
- #ifdef APPCONFIG_OS_WIN
- #define JUCE_DIRECTSOUND 1
- #else
- #define JUCE_DIRECTSOUND 0
- #endif
-
- /** Config: JUCE_ALSA
- Enables ALSA audio devices (Linux only).
- */
- #if 0 //APPCONFIG_OS_LINUX
- #define JUCE_ALSA 1
- #define JUCE_ALSA_MIDI_INPUT_NAME "Carla"
- #define JUCE_ALSA_MIDI_OUTPUT_NAME "Carla"
- #define JUCE_ALSA_MIDI_INPUT_PORT_NAME "Midi In"
- #define JUCE_ALSA_MIDI_OUTPUT_PORT_NAME "Midi Out"
- #else
- #define JUCE_ALSA 0
- #endif
-
- /** Config: JUCE_JACK
- Enables JACK audio devices (Linux only).
- */
- #if 0 //APPCONFIG_OS_LINUX
- #define JUCE_JACK 1
- #define JUCE_JACK_CLIENT_NAME "Carla"
- #else
- #define JUCE_JACK 0
- #endif
-
- //=============================================================================
- /** Config: JUCE_USE_CDREADER
- Enables the AudioCDReader class (on supported platforms).
- */
- #define JUCE_USE_CDREADER 0
-
- /** Config: JUCE_USE_CDBURNER
- Enables the AudioCDBurner class (on supported platforms).
- */
- #define JUCE_USE_CDBURNER 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_audio_formats
-
- //=============================================================================
- /** Config: JUCE_USE_FLAC
- Enables the FLAC audio codec classes (available on all platforms).
- If your app doesn't need to read FLAC files, you might want to disable this to
- reduce the size of your codebase and build time.
- */
- #define JUCE_USE_FLAC 1
-
- /** Config: JUCE_USE_OGGVORBIS
- Enables the Ogg-Vorbis audio codec classes (available on all platforms).
- If your app doesn't need to read Ogg-Vorbis files, you might want to disable this to
- reduce the size of your codebase and build time.
- */
- #define JUCE_USE_OGGVORBIS 1
-
- /** Config: JUCE_USE_MP3AUDIOFORMAT
- Enables the software-based MP3AudioFormat class.
- IMPORTANT DISCLAIMER: By choosing to enable the JUCE_USE_MP3AUDIOFORMAT flag and to compile
- this MP3 code into your software, you do so AT YOUR OWN RISK! By doing so, you are agreeing
- that Raw Material Software is in no way responsible for any patent, copyright, or other
- legal issues that you may suffer as a result.
-
- The code in juce_MP3AudioFormat.cpp is NOT guaranteed to be free from infringements of 3rd-party
- intellectual property. If you wish to use it, please seek your own independent advice about the
- legality of doing so. If you are not willing to accept full responsibility for the consequences
- of using this code, then do not enable this setting.
- */
- #define JUCE_USE_MP3AUDIOFORMAT 0
-
- /** Config: JUCE_USE_LAME_AUDIO_FORMAT
- Enables the LameEncoderAudioFormat class.
- */
- #define JUCE_USE_LAME_AUDIO_FORMAT 1
-
- /** Config: JUCE_USE_WINDOWS_MEDIA_FORMAT
- Enables the Windows Media SDK codecs.
- */
- #define JUCE_USE_WINDOWS_MEDIA_FORMAT 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_audio_processors
-
- //=============================================================================
- /** Config: JUCE_PLUGINHOST_VST
- Enables the VST audio plugin hosting classes. This requires the Steinberg VST SDK to be
- installed on your machine.
-
- @see VSTPluginFormat, AudioPluginFormat, AudioPluginFormatManager, JUCE_PLUGINHOST_AU
- */
- #ifndef VESTIGE_HEADER
- # define JUCE_PLUGINHOST_VST 1
- #else
- # define JUCE_PLUGINHOST_VST 0
- #endif
-
- /** Config: JUCE_PLUGINHOST_VST3
- Enables the VST3 audio plugin hosting classes. This requires the Steinberg VST3 SDK to be
- installed on your machine.
-
- @see VSTPluginFormat, VST3PluginFormat, AudioPluginFormat, AudioPluginFormatManager, JUCE_PLUGINHOST_VST, JUCE_PLUGINHOST_AU
- */
- #if defined(APPCONFIG_OS_MAC) || defined(APPCONFIG_OS_WIN)
- # define JUCE_PLUGINHOST_VST3 1
- #else
- # define JUCE_PLUGINHOST_VST3 0
- #endif
-
- /** Config: JUCE_PLUGINHOST_AU
- Enables the AudioUnit plugin hosting classes. This is Mac-only, of course.
-
- @see AudioUnitPluginFormat, AudioPluginFormat, AudioPluginFormatManager, JUCE_PLUGINHOST_VST
- */
- #ifdef APPCONFIG_OS_MAC
- # define JUCE_PLUGINHOST_AU 1
- #else
- # define JUCE_PLUGINHOST_AU 0
- #endif
-
- #define JUCE_PLUGINHOST_LADSPA 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_core
-
- //=============================================================================
- /** Config: JUCE_FORCE_DEBUG
-
- Normally, JUCE_DEBUG is set to 1 or 0 based on compiler and project settings,
- but if you define this value, you can override this to force it to be true or false.
- */
- #define JUCE_FORCE_DEBUG 0
-
- //=============================================================================
- /** Config: JUCE_LOG_ASSERTIONS
-
- If this flag is enabled, the the jassert and jassertfalse macros will always use Logger::writeToLog()
- to write a message when an assertion happens.
-
- Enabling it will also leave this turned on in release builds. When it's disabled,
- however, the jassert and jassertfalse macros will not be compiled in a
- release build.
-
- @see jassert, jassertfalse, Logger
- */
- #define JUCE_LOG_ASSERTIONS 1
-
- //=============================================================================
- /** Config: JUCE_CHECK_MEMORY_LEAKS
-
- Enables a memory-leak check for certain objects when the app terminates. See the LeakedObjectDetector
- class and the JUCE_LEAK_DETECTOR macro for more details about enabling leak checking for specific classes.
- */
- #ifdef DEBUG
- #define JUCE_CHECK_MEMORY_LEAKS 1
- #else
- #define JUCE_CHECK_MEMORY_LEAKS 0
- #endif
-
- //=============================================================================
- /** Config: JUCE_DONT_AUTOLINK_TO_WIN32_LIBRARIES
-
- In a Visual C++ build, this can be used to stop the required system libs being
- automatically added to the link stage.
- */
- #define JUCE_DONT_AUTOLINK_TO_WIN32_LIBRARIES 0
-
- /** Config: JUCE_INCLUDE_ZLIB_CODE
- This can be used to disable Juce's embedded 3rd-party zlib code.
- You might need to tweak this if you're linking to an external zlib library in your app,
- but for normal apps, this option should be left alone.
-
- If you disable this, you might also want to set a value for JUCE_ZLIB_INCLUDE_PATH, to
- specify the path where your zlib headers live.
- */
- #define JUCE_INCLUDE_ZLIB_CODE 1
-
- /** Config: JUCE_USE_CURL
- Enables http/https support via libcurl (Linux only). Enabling this will add an additional
- run-time dynmic dependency to libcurl.
-
- If you disable this then https/ssl support will not be available on linux.
- */
- #define JUCE_USE_CURL 0
-
- /* Config: JUCE_CATCH_UNHANDLED_EXCEPTIONS
- If enabled, this will add some exception-catching code to forward unhandled exceptions
- to your JUCEApplicationBase::unhandledException() callback.
- */
- #define JUCE_CATCH_UNHANDLED_EXCEPTIONS 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_data_structures
-
- // nothing here
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_events
-
- // nothing here
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_graphics
-
- //=============================================================================
- /** Config: JUCE_USE_COREIMAGE_LOADER
-
- On OSX, enabling this flag means that the CoreImage codecs will be used to load
- PNG/JPEG/GIF files. It is enabled by default, but you may want to disable it if
- you'd rather use libpng, libjpeg, etc.
- */
- #define JUCE_USE_COREIMAGE_LOADER 1
-
- /** Config: JUCE_USE_DIRECTWRITE
-
- Enabling this flag means that DirectWrite will be used when available for font
- management and layout.
- */
- #define JUCE_USE_DIRECTWRITE 0
-
- #define JUCE_INCLUDE_PNGLIB_CODE 1
-
- #define JUCE_INCLUDE_JPEGLIB_CODE 1
-
- #ifdef APPCONFIG_OS_MAC
- # define USE_COREGRAPHICS_RENDERING 1
- #else
- # define USE_COREGRAPHICS_RENDERING 0
- #endif
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_gui_basics
-
- //=============================================================================
- /** Config: JUCE_ENABLE_REPAINT_DEBUGGING
- If this option is turned on, each area of the screen that gets repainted will
- flash in a random colour, so that you can see exactly which bits of your
- components are being drawn.
- */
- #define JUCE_ENABLE_REPAINT_DEBUGGING 0
-
- /** JUCE_USE_XRANDR: Enables Xrandr multi-monitor support (Linux only).
- Unless you specifically want to disable this, it's best to leave this option turned on.
- Note that your users do not need to have Xrandr installed for your JUCE app to run, as
- the availability of Xrandr is queried during runtime.
- */
- #define JUCE_USE_XRANDR 0
-
- /** JUCE_USE_XINERAMA: Enables Xinerama multi-monitor support (Linux only).
- Unless you specifically want to disable this, it's best to leave this option turned on.
- This will be used as a fallback if JUCE_USE_XRANDR not set or libxrandr cannot be found.
- Note that your users do not need to have Xrandr installed for your JUCE app to run, as
- the availability of Xinerama is queried during runtime.
- */
- #define JUCE_USE_XINERAMA 0
-
- /** Config: JUCE_USE_XSHM
- Enables X shared memory for faster rendering on Linux. This is best left turned on
- unless you have a good reason to disable it.
- */
- #define JUCE_USE_XSHM 1
-
- /** Config: JUCE_USE_XRENDER
- Enables XRender to allow semi-transparent windowing on Linux.
- */
- #define JUCE_USE_XRENDER 0
-
- /** Config: JUCE_USE_XCURSOR
- Uses XCursor to allow ARGB cursor on Linux. This is best left turned on unless you have
- a good reason to disable it.
- */
- #define JUCE_USE_XCURSOR 1
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_gui_extra
-
- //=============================================================================
- /** Config: JUCE_WEB_BROWSER
- This lets you disable the WebBrowserComponent class (Mac and Windows).
- If you're not using any embedded web-pages, turning this off may reduce your code size.
- */
- #define JUCE_WEB_BROWSER 0
-
- /** Config: JUCE_ENABLE_LIVE_CONSTANT_EDITOR
- This lets you turn on the JUCE_ENABLE_LIVE_CONSTANT_EDITOR support. See the documentation
- for that macro for more details.
- */
- #define JUCE_ENABLE_LIVE_CONSTANT_EDITOR 0
-
- // --------------------------------------------------------------------------------------------------------------------
-
- #endif // CARLA_JUCE_APPCONFIG_H_INCLUDED
|