-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Visual Studio Code
Visual Studio Code is a free open source code editor / IDE that is
easy to set-up.
It is a completely different editor than Visual Studio
Community.
VSCode is very well suited for Controller Scripting as
well as working on Mixxx's core with
C++.
Note: Most of this guide will assume that you have a folder named
cbuild
in the root folder of the locally cloned repository. This is
where cmake will put the buildfiles and build the mixxx binary. If you
want to use a different folder, you need to adapt the paths present in
the config file templates given.
- Check out Mixxx source and build it.
- If you haven't done this yet, follow the instructions for your operating system here.
- Install Microsoft C/C++ extension.
-
Open the extensions pane and search for "c++". Click the install button for the Microsoft extension.
-
- Select File -> Open... and open the mixxx source folder.
- Visual Studio Code saves it's configuration in a folder named .vscode in the mixxx source folder. Next time you want to work on mixxx you only need to open the mixxx source folder again.
Put the following text into your `c_cpp_properties.json` (or create it if it doesn't exist already) into the `.vscode` folder.
{
"configurations": [
{
"name": "Linux",
"compilerPath": "/usr/bin/gcc",
"cStandard": "c11",
"cppStandard": "c++17",
"intelliSenseMode": "gcc-x64",
"compileCommands": "${workspaceFolder}/cbuild/compile_commands.json"
}
],
"version": 4
}
For this to properly work, its important to enable generation of the compilation database while running CMake. The build and config tasks following do this automatically for you.
Unfortunately, I'm not able to create configs for building Mixxx through VScode on anything other than Linux. So this section assumes you are running VScode on Linux. You should also have read the compiling on linux guide with cmake to properly grasp the following section.
Use the following tasks.json
config (located in .vscode
) to be
able to generate buildfiles and compile linux from within VScode:
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"tasks": [
{
"label": "CMake generate buildfiles",
"type": "shell",
"group": "build",
"options": {
"cwd": "cbuild"
},
"command": "cmake",
"args": [
"-DCMAKE_INSTALL_PREFIX=/usr/local",
// add any further arguments for CMake here
// generate debug build
"-DCMAKE_BUILD_TYPE=Debug",
"-DDEBUG_ASSERTIONS_FATAL=ON",
"-DOPTIMIZE=native",
// generate compile_commands.json
"-DCMAKE_EXPORT_COMPILE_COMMANDS=ON",
"${workspaceFolder}"
],
"problemMatcher": []
},
{
"label": "CMake compile",
"type": "shell",
"command": "cmake --build . --parallel $(nproc)",
"group": {
"kind": "build",
"isDefault": true
},
"options": {
"cwd": "cbuild"
},
"problemMatcher": "$gcc"
}
]
}
This will add the "CMake generate buildfiles" and "CMake compile" tasks to VScode. Both can be invoked in the command prompt accessible via [CTLR]+[Shift]+P. The "CMake compile" can also be invoked directly by pressing [CTLR]+[Shift]+B.
Add this to your launch.json
file to add debugging capabilities
(based on gdb) to vscode.
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "(gdb) Launch",
"type": "cppdbg",
"request": "launch",
"program": "${workspaceFolder}/cbuild/mixxx",
"args": [
"--resourcePath res/",
"--debugAssertBreak"
// add more args here (for example a custom --settingsPath)
],
"stopAtEntry": false,
"cwd": "${workspaceFolder}",
"environment": [],
"externalConsole": false,
"MIMode": "gdb",
"setupCommands": [
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
]
}
]
}
You should now be able to launch Mixxx with gdb attached by pressing F5. If you want to know more about debugging, Microsoft has a guide which introduces to into VScodes debugging capabilities: https://code.visualstudio.com/docs/editor/debugging
Alse see Building your C++ application with Visual Studio Code.
When I try to build the code, VSCode fails with The terminal shell CWD ".../mixxx/cbuild" does not exist
the cbuild
directory is the temporary directory where CMake will generate the files for the buildsystem you are using. Since
the name of this directory is theoretically up to you, but vscode needs to know about it. To simplify this guide, we assumed this directory will be called cbuild
. However, it does not exist when you clone the mixxx repository the first time so you need to create it yourself.
#include
s are underlined in orange and the tooltip says something like #include errors detected. Consider updating your compile_commands.json or includePath. Squiggles are disabled for this translation unit.
This occurs when you either have an outdated compile_commands.json
(or its missing entirely). You can fix this by running the "CMake generate buildfiles" and "CMake compile" tasks at least once. Make sure you include -DCMAKE_EXPORT_COMPILE_COMMANDS=ON
when generating the buildfiles (this is already the case if you use the tasks.json
from above)
Mixxx is a free and open-source DJ software.
Manual
Hardware Compatibility
Reporting Bugs
Getting Involved
Contribution Guidelines
Coding Guidelines
Using Git
Developer Guide
Creating Skins
Contributing Mappings
Mixxx Controls
MIDI Scripting
Components JS
HID Scripting