16.3. Launching Mixxx from the Command Line
To launch Mixxx using the command line:
- Windows
- Locate the folder where Mixxx is installed and copy the file path. You can also obtain the file path by right clicking on the Mixxx icon and then choosing ‘Properties’. Copy the path and paste it in terminal and add - \mixxxat the end - everything should be inside quotes. Press Enter. The entire command will look like this- "C:\Program Files\Mixxx\mixxx"
- macOS
- Similarly, for macOS, the command will be - /Applications/Mixxx.app/Contents/MacOS/mixxx 
- GNU/ Linux
- If Mixxx is in your system’s search path ( - $PATH), you can just type- mixxx
Command line options
Mixxx is designed to be as user-friendly as possible. As such, its command line options are only useful for development or debugging, as they make these tasks easier. Command line options are case-sensitive.
To launch Mixxx with any of these command line options, simply append the option to the base command for your operating system. For example, to launch Mixxx in developer mode on Windows, type this in terminal
"C:\Program Files\Mixxx\mixxx" --developer
In addition to these options, it is possible to specify one or more music file(s) on the command line. These will be loaded at start-up. Each file you specify will be loaded into the next virtual deck. For a list of supported file types, go to Compatible file formats.
- --resource-path PATH
- Top-level directory where Mixxx will look for its resource files such as MIDI mappings, overriding the default installation location. 
- --start-autodj
- Enables Auto DJ when starting Mixxx. 
- --settings-path PATH
- Top-level directory where Mixxx will look for user settings files such as the library database and preferences configuration file. 
- --enable-legacy-vumeter
- Do not use OpenGL vu meter 
- --controller-debug
- Log all controller data Mixxx sends and receives as well as scripts it loads. 
- --controller-abort-on-warning
- The controller mapping will issue more aggressive warnings and errors when detecting misuse of controller APIs. New Controller Mappings should be developed with this option enabled! 
- --developer
- Enable developer mode. Includes extra logs, stats on performance and the Developer tools menu as well as tooltips and logs useful for skin developers. 
- --safe-mode
- Disable OpenGL widgets (scrolling waveforms, spinnies) to work around GPU driver bugs. If Mixxx is crashing on startup, try using this. - Automatically loads empty waveforms 
- Disables spinning vinyl widgets 
- Disables synchronization polling 
- Doesn’t open controllers by default 
 
- --start-autodj
- Automatically start Auto DJ when Mixxx finished loading. 
- --color <color>
- [auto|always|never] Use colors on the console output. 
- --locale LOCALE
- Use a custom locale for loading translations (e.g - fr)
- -f, --full-screen
- Start Mixxx in full-screen mode. 
- --log-level LEVEL
- Set the verbosity of command line logging. - Value - Significado - critical- Critical/Fatal only - warning- Above + Warnings - info- Above + Informational messages - debug- Above + Debug/Developer messages - trace- Above + Profiling messages 
- --log-flush-level LEVEL
- Set the logging level at which the log buffer is flushed to - mixxx.log.- LEVELis one of the values defined at- --logLevelabove.
- --debug-assert-break
- Breaks ( - SIGINT) Mixxx if a- DEBUG_ASSERTevaluates to false. A debugger can then be used to continue. This disables the- MIXXX_DEBUG_ASSERTIONS_FATALflag which can otherwise lead to a time consuming full rebuild.
- -h, --help
- Display this help message and exit 
16.4. Developer tools
To start Mixxx in Developer mode with a custom resource directory with MIDI and HID logging enabled, type the following line into the terminal and hit return:
./mixxx --controller-debug --developer --resource-path res
Experiment modes for rapid development and testing
Adds a static Experiment class with a tri-state mode flag that indicates whether the experiment mode is OFF, BASE, or EXPERIMENT.
Adds and . Each one toggles between OFF and BASE/EXPERIMENT so you can choose exactly what time spans you would like to collect in your base and experiment buckets.
Updates StatsManager to segment collected stats into a base and experiment bucket. This allows you to quickly measure the difference a code change has on relevant counters / timers within the same execution of Mixxx.
This is useful for quickly enabling and disabling a code change without a re-compile/re-run cycle to get an anecdotal sense of how it “feels” as well as a quantified sense of how it differs in terms of stats Mixxx collects.
All stats collected via the usual Counter/Timer/ScopedTimer/etc. tools are segmented into a BASE STATS and EXPERIMENT STATS section printed to the log on exit.