-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Running Cura from Source
Make sure that the binaries for the system dependencies can be found on the PATH
- Windows 10 or higher
- Visual Studio with MSVC 2022 or higher
- Python 3.12 or higher
- venv (Python)
- sip (Python) 6.5.1
- CMake 3.23 or higher
- Ninja 1.10 or higher
- Conan >=2.7.0 <3.0.0
Executing from the Powershell is preferred. To be completely safe, start powershell inside of the x64 Native Command Tools Prompt.
We recommend using brew to install these dependencies.
- macOS 11 or higher
- xcode 12 or higher
- apple-clang-12.0 or higher
- Python 3.12 or higher
- venv (Python)
- sip (Python) 6.5.0 or higher
- altool
- automake
- CMake 3.23 or higher
- Ninja 1.10 or higher
- Conan >=2.7.0 <3.0.0
- Ubuntu/Debian/Arch/Manjaro (glibc 2.28 or higher)
- gcc-13 or higher
- Python 3.12 or higher
- venv (Python)
- sip (Python) 6.5.0 or higher
- CMake 3.23 or higher
- Ninja 1.10 or higher
- Conan >=2.7.0 <3.0.0
- autoreconf
- ( xtrans )
- First we will create a Python virtual environment (venv) so that your work with Cura will not mess up with the rest of the system. You could skip this, but e.g. on Ubuntu 24.04 this is almost mandatory.
python -m venv cura_venv
- Now activate this new venv
- On Linux/MacOS
source cura_venv/bin/activate
- On Windows
cura_venv\Scripts\activate.ps1
- Finally, install and setup conan inside the venv
pip install conan==2.7.0
conan config install https://github.com/ultimaker/conan-config.git
conan profile new default --detect --force
Clone Cura and enter the Cura root directory.
git clone https://github.com/Ultimaker/Cura.git
cd Cura
We will now use conan to install the required dependencies for the development environment. The following command should be executed in the root directory of the Cura repository:
conan install . --build=missing --update -g VirtualPythonEnv
Now let's see what this does:
-
conan install .
is the basic command to install the dependencies for the recipe (conanfile.py) present in the current directory -
--build=missing
build dependencies for which there is no remote pre-built binary package (which is very likely) -
--update
download the most recent versions of recipes for each dependency (you may skip it next time, it will be faster) -
-g VirtualPythonEnv
run a specific "generator" that will create a fully-preconfigured Python environment for you to run Cura
You can also use a few extra options:
-
-g PyCharmRunEnv
if you use PyCharm, this will create appropriate run/debug/test configurations. You must clickAdd Configuration...
, and clickApply
for these to be displayed. -
-c user.generator.virtual_python_env:dev_tools=True
will install extra dev tools in the Python environment, like pytest
The generated files you will need are placed in a new build/generators
folder. You can safely delete this file later to re-create the environment.
If you get an error like
ERROR: while executing system_requirements(): Aborted due to CONAN_SYSREQUIRES_MODE=verify. Some system packages need to be installed
you need to install the required system packages.
During the conan install
, the VirtualPythonEnv
generator has created a new Python virtual environment, different from the first one:
- It uses the CPython interpreter built/installed as a conan dependency
- It contains python packages that are the direct dependencies of Cura (e.g. Uranium, pyArcus, ...)
- It contains third-party packages that are necessary to run Cura (e.g. PyQt, pyserial, ...)
This environment is located in build/generators/cura_venv
. You can activate it by executing the following command in the root directory of the Cura repository:
- On Linux/MacOS
source build/generators/virtual_python_env.sh
- On Windows
build/generators/virtual_python_env.ps1
If you want more control over the execution virtual environment, you can also do something like:
source build/generators/conanrun.sh # Will set environment variables to link to conan dependencies
python -m venv cura_run_venv # Manually create the virtual environment using the proper CPython interpreter
source cura_run_venv/bin/activate # Activate the virtual environment
After that, you can install the third-party dependencies manually, by using the generated requirements files in build/generators/
:
ls build/generators/pip_requirements_{core,dev}_*.txt | xargs -I {} pip install -r {}
Or select specifically which set of packages you want to install:
pip install -r build/generators/pip_requirements_core_basic.txt
pip install -r build/generators/pip_requirements_core_hashes.txt
Now you have all the dependencies setup, you should be able to run cura:
python cura_app.py
- Welcome
- Getting Started
- Reporting An Issue
- Core Development
- Plugins & Material Packages
- Printers
- Translations
- Best Practices
- Settings
- 3D Scene
- Profiling
- Cura User Files
- GitHub Actions