|
- /*
- * Carla Plugin Host
- * Copyright (C) 2011-2022 Filipe Coelho <falktx@falktx.com>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License as
- * published by the Free Software Foundation; either version 2 of
- * the License, or any later version.
- *
- * 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
- * GNU General Public License for more details.
- *
- * For a full copy of the GNU General Public License see the doc/GPL.txt file.
- */
-
- #ifndef CARLA_JUCE_APPCONFIG_H_INCLUDED
- #define CARLA_JUCE_APPCONFIG_H_INCLUDED
-
- #if defined(DEBUG) && defined(NDEBUG)
- # undef DEBUG
- #endif
-
- #define juce carlajuce
-
- // --------------------------------------------------------------------------------------------------------------------
- // 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(__linux__) || defined(__linux)
- # define APPCONFIG_OS_LINUX
- #elif defined(__FreeBSD__)
- # define APPCONFIG_OS_FREEBSD
- #endif
-
- #if defined(APPCONFIG_OS_WIN32) || defined(APPCONFIG_OS_WIN64)
- # define APPCONFIG_OS_WIN
- #elif defined(APPCONFIG_OS_LINUX) || defined(APPCONFIG_OS_FREEBSD) || 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_processors 1
- #define JUCE_MODULE_AVAILABLE_juce_core 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
-
- // always disabled
- #define JUCE_MODULE_AVAILABLE_juce_audio_formats 0
- #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(USING_JUCE_AUDIO_DEVICES) && !defined(BUILD_BRIDGE)
- # define JUCE_MODULE_AVAILABLE_juce_audio_devices 1
- #else
- # define JUCE_MODULE_AVAILABLE_juce_audio_devices 0
- #endif
-
- // misc
- #define JUCE_DISABLE_JUCE_VERSION_PRINTING 1
- #define JUCE_GLOBAL_MODULE_SETTINGS_INCLUDED 1
- #define JUCE_STANDALONE_APPLICATION 0
- #define JUCE_REPORT_APP_USAGE 0
- #define JUCE_DISPLAY_SPLASH_SCREEN 0
- #define JUCE_USE_DARK_SPLASH_SCREEN 0
- #define JUCE_STRING_UTF_TYPE 8
- #define JUCE_USE_VFORK 1
-
- #if defined(APPCONFIG_OS_LINUX) || defined(APPCONFIG_OS_FREEBSD)
- # define JUCE_DISABLE_NATIVE_FILECHOOSERS 1
- # define JUCE_MODAL_LOOPS_PERMITTED 0
- // # define JUCE_AUDIOPROCESSOR_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).
- */
- #if defined(APPCONFIG_OS_WIN) && !defined(BUILDING_CARLA_NOOPT)
- #define JUCE_WASAPI 1
- #else
- #define JUCE_WASAPI 0
- #endif
-
- /** 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).
- */
- #ifdef APPCONFIG_OS_LINUX
- #define JUCE_ALSA 1
- #define JUCE_ALSA_MIDI_NAME "Carla"
- #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 defined(APPCONFIG_OS_LINUX) || defined(APPCONFIG_OS_FREEBSD)
- #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 0
-
- /** 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 0
-
- /** 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 0
-
- /** Config: JUCE_USE_WINDOWS_MEDIA_FORMAT
- Enables the Windows Media SDK codecs.
- */
- #define JUCE_USE_WINDOWS_MEDIA_FORMAT 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_audio_processors
-
- #define JUCE_VST_FALLBACK_HOST_NAME "Carla"
-
- //=============================================================================
- /** 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
- */
- #if defined(APPCONFIG_OS_MAC) || defined(APPCONFIG_OS_WIN)
- # 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_LINUX) || 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
- // #define JUCE_DISABLE_ASSERTIONS 1
- #else
- #define JUCE_CHECK_MEMORY_LEAKS 0
- // #define JUCE_DISABLE_ASSERTIONS 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
-
- /** Config: JUCE_ALLOW_STATIC_NULL_VARIABLES
- If disabled, this will turn off dangerous static globals like String::empty, var::null, etc
- which can cause nasty order-of-initialisation problems if they are referenced during static
- constructor code.
- */
- #define JUCE_ALLOW_STATIC_NULL_VARIABLES 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_data_structures
-
- // nothing here
-
- // --------------------------------------------------------------------------------------------------------------------
- // juce_dsp
-
- //==============================================================================
- /** Config: JUCE_ASSERTION_FIRFILTER
-
- When this flag is enabled, an assertion will be generated during the
- execution of DEBUG configurations if you use a FIRFilter class to process
- FIRCoefficients with a size higher than 128, to tell you that's it would be
- more efficient to use the Convolution class instead. It is enabled by
- default, but you may want to disable it if you really want to process such
- a filter in the time domain.
- */
- #define JUCE_ASSERTION_FIRFILTER 0
-
- /** Config: JUCE_DSP_USE_INTEL_MKL
-
- If this flag is set, then JUCE will use Intel's MKL for JUCE's FFT and
- convolution classes.
-
- If you're using the Projucer's Visual Studio exporter, you should also set
- the "Use MKL Library (oneAPI)" option in the exporter settings to
- "Sequential" or "Parallel". If you're not using the Visual Studio exporter,
- the folder containing the mkl_dfti.h header must be in your header search
- paths, and you must link against all the necessary MKL libraries.
- */
- #define JUCE_DSP_USE_INTEL_MKL 0
-
- /** Config: JUCE_DSP_USE_SHARED_FFTW
-
- If this flag is set, then JUCE will search for the fftw shared libraries
- at runtime and use the library for JUCE's FFT and convolution classes.
-
- If the library is not found, then JUCE's fallback FFT routines will be used.
-
- This is especially useful on linux as fftw often comes pre-installed on
- popular linux distros.
-
- You must respect the FFTW license when enabling this option.
- */
- #define JUCE_DSP_USE_SHARED_FFTW 0
-
- /** Config: JUCE_DSP_USE_STATIC_FFTW
-
- If this flag is set, then JUCE will use the statically linked fftw libraries
- for JUCE's FFT and convolution classes.
-
- You must add the fftw header/library folder to the extra header/library search
- paths of your JUCE project. You also need to add the fftw library itself
- to the extra libraries supplied to your JUCE project during linking.
-
- You must respect the FFTW license when enabling this option.
- */
- #define JUCE_DSP_USE_STATIC_FFTW 0
-
- /** Config: JUCE_DSP_ENABLE_SNAP_TO_ZERO
-
- Enables code in the dsp module to avoid floating point denormals during the
- processing of some of the dsp module's filters.
-
- Enabling this will add a slight performance overhead to the DSP module's
- filters and algorithms. If your audio app already disables denormals altogether
- (for example, by using the ScopedNoDenormals class or the
- FloatVectorOperations::disableDenormalisedNumberSupport method), then you
- can safely disable this flag to shave off a few cpu cycles from the DSP module's
- filters and algorithms.
- */
- #define JUCE_DSP_ENABLE_SNAP_TO_ZERO 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // 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
-
- #define USE_COREGRAPHICS_RENDERING 0
-
- // --------------------------------------------------------------------------------------------------------------------
- // 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
|