This repository contains build scripts used to build Cura and all dependencies from scratch.
The build has a number of dependencies. Ideally, these dependencies should be installed by the cura-build-environment repository. Even with cura-build-environment though, some things may still be missing from your system that we haven't thought of.
- Install CMake (available via homebrew or cmake.org)
- Install latest version of Xcode.
- On Mac OS X > 10.10, execute command: brew link openssl --force
- Because Fortran is necessary: brew install gcc
- Run these commands:
git clone [email protected]:Ultimaker/cura-build.git
cd cura-build
mkdir build
cd build
cmake ..
make
On Windows, the following dependencies are needed for building:
- git for windows (https://git-for-windows.github.io/) The
git
command should be available on your%PATH%
. Make sure that thecmd
directory in the git for windows installation directory is on the%PATH%
and not itsbin
directory, otherwise mingw32 will complain aboutsh.exe
being on the path. - CMake (http://www.cmake.org/) Once CMake is installed make sure it is available on your
%PATH%
. Check this by runningcmake --version
in the Windows console. - MinGW-W64 >= 5.3.0 (http://mingw-w64.org/doku.php) Once installed, its
bin
directory should be available on your%PATH%
. Test this by runningmingw32-make --version
in the Windows console. - Python 3.5 (http://python.org/, note that the version "3.5" is hardcoded across this project)
- NumPy (http://www.lfd.uci.edu/~gohlke/pythonlibs/#numpy)
You'll need to download a .whl from this site for Python 3.5 and install it via
pip install <your_whl_file>.whl
. - SciPy (http://www.lfd.uci.edu/~gohlke/pythonlibs/#scipy)
You'll need to download a .whl from this site for Python 3.5 and install it via
pip install <your_whl_file>.whl
. - PySerial from https://pypi.python.org/pypi/pyserial/3.2.1
It can be easily installed via
pip3 install pyserial
- PyQt5 from https://pypi.python.org/pypi/PyQt5/5.7
It can be easily installed via
pip3 install PyQt5
- SIP from https://pypi.python.org/pypi/SIP/4.18.1
It can be easily installed via
pip3 install sip
- Trimesh from https://pypi.python.org/pypi/trimesh/2.32.1
It can be easily installed via
pip3 install trimesh
- Shapely from https://pypi.python.org/pypi/Shapely/1.6.4.post2
It can be easily installed via
pip3 install shapely[vectorized]
. If it doesn't work, you'll need to download a .whl from https://www.lfd.uci.edu/~gohlke/pythonlibs/#shapely for Python 3.5 and install it viapip install <your_whl_file>.whl
. - Zeroconf from https://pypi.python.org/pypi/zeroconf/0.17.6
It can be easily installed via
pip3 install zeroconf
- NumPy-STL from https://pypi.python.org/pypi/numpy-stl/2.0.0
It can be easily installed via
pip3 install numpy-stl
- LibArcus from https://github.com/Ultimaker/libArcus
- Microsoft Visual Studio 2015 (community edition): Install Programming languages: Visual c++ (all), Python Tools for Visual Studio (Nov 2015) Windows & Web Development: Universal Windows App Development Tools (Tools 1.2 & windows 10 SDK-10/0/10586; Windows 10 SDK -10.0.10240)
- cx_Freeze (https://pypi.python.org/pypi/cx_Freeze)
The easiest way to install this is to use a wheel (*.whl file) and install it via
pip install <your_whl_file>.whl
. You may have to add<python dir>/Scripts
to you%PATH%
. (Last tested version was: cx_Freeze-5.0-cp35-cp35m-win_amd64.whl) - NSIS 3 (http://nsis.sourceforge.net/Main_Page) for creating the installer. Additional NSIS scripts are shipped with this project.
Make sure these dependencies are available from your path.
Additionally, for 32-bit builds:
- Perl (http://www.activestate.com/activeperl, Required to build Qt)
- Create in the user directory a file named pydistutils.cfg with the following contents:
[build]
compiler=mingw32
For 64-bit builds:
- PyQt 5.4 (https://riverbankcomputing.com/software/pyqt/download5, Building PyQt currently fails using MinGW 64-bit)
- Install protobuf.wheel found in cura-build-binaries (TODO: create cura-build-binaries repo)
- Create empty
__init__.py
in c:\Python34\Lib\site-packages\google (TODO: make it part of the proto.wheel installation)
REM 32-bit
git clone [email protected]:Ultimaker/cura-build.git
cd cura-build
mkdir build
cd build
..\env_win32.bat
cmake -G "MinGW Makefiles" ..
mingw32-make
mingw32-make package
REM 64-bit
git clone [email protected]:Ultimaker/cura-build.git
cd cura-build
mkdir build
cd build
..\env_win64.bat
cmake -G "MinGW Makefiles" ..
mingw32-make
mingw32-make package
Before make package - copy arduino to cura-build/
cura-build can build AppImage packages of Cura.
To build, make sure these dependencies are installed, then clone this repository and run the following commands from your clone:
git clone http://github.com/Ultimaker/cura-build.git
cd cura-build
mkdir build
cd build
cmake ..
make
make package
cura-build can build CentOS/RHEL packages of Cura.
Dependencies:
- gcc-gfortran
- python34.x86_64
- python34-devel.x86_64
- python34-numpy.x86_64
- pyserial.noarch
- PyOpenGL.noarch
- python34-setuptools.noarch
- wxPython.x86_64
- libstdc++-static.x86_64
- libstdc++-devel.x86_64
- openssl.x86_64
- openblas-devel.x86_64
- python34-numpy-f2py.x86_64
To build, make sure these dependencies are installed, then clone this repository and run the following commands from your clone:
sudo yum install gcc-gfortran python34.x86_64 python34-devel.x86_64 python34-numpy.x86_64 pyserial.noarch PyOpenGL.noarch python34-setuptools.noarch wxPython.x86_64 libstdc++-static.x86_64 libstdc++-devel.x86_64 openssl.x86_64 openblas-devel.x86_64 python34-numpy-f2py.x86_64
- download and install scipy from https://github.com/scipy/scipy/releases be sure to use python 3.5, eg. using sudo python3 setup.py 2. install (version in repository is for python 2.7)
- download and install CMake from https://cmake.org/download/ and configure CMake to use ssl
- download and install Qt5 from https://www.qt.io/download/
- download and install PyQt5 from https://www.riverbankcomputing.com/software/pyqt/download5
- download and install sip from https://www.riverbankcomputing.com/software/sip/download make sure the verion is 4.18 or newer
Alternative method for installing python at: https://edwards.sdsu.edu/research/installing-python3-4-and-the-scipy-stack-on-centos/ . Make sure, that the PYTHONPATH can find dist-packages.
git clone http://github.com/Ultimaker/cura-build.git
cd cura-build
mkdir build
cd build
cmake ..
make
make package