Сборка Из Исходного Кода под Unix

From FreeCAD Documentation
Jump to: navigation, search
This page is a translated version of the page CompileOnUnix and the translation is 88% complete.

Outdated translations are marked like this.
Other languages:
български • ‎čeština • ‎Deutsch • ‎English • ‎español • ‎français • ‎italiano • ‎polski • ‎português • ‎português do Brasil • ‎română • ‎русский • ‎svenska • ‎Türkçe • ‎中文(中国大陆)‎

Сборка FreeCAD в современных дистрибутивах Линукс обычно не вызывает сложностей, поскольку все зависимости разрешаются менеджером пакетов, встроенным в дистрибутив. Сборка включает 3 этапа:

  1. Загрузка исходного кода FreeCAD.
  2. Разрешение зависимостей (пакетов, от которых зависит FreeCAD).
  3. Настройка с помощью "cmake" и компиляция с помощью "make".

Ниже вы найдете подробное описание процесса сборки, некоторых скриптов компиляции и особенностей, с которыми Вы можете столкнуться. Если вы найдете ошибки, устаревшие сведения, отсутствие перевода, или если вы используете дистрибутив, которого нет в списке, то мы будем благодарны, если поможете это исправить.

Загрузка исходников

Перед началом сборки вам понадобится исходный код. Вы можете клонировать его через git или загрузить его в качестве архива.

Git

Самый простой и быстрый способ загрузить исходники заключается в клонировании репозитория, который расположен на GitHub (перед этим нужно установить git):

git clone https://github.com/FreeCAD/FreeCAD.git freecad-code

Эта команда копирует последнюю версию исходного кода FreeCAD в папку "freecad-code".

Архив исходников

Вы можете скачать архив с исходным кодом.

Разрешение зависимостей

Перед компиляцией FreeCAD под Линукс вы должны установить все библиотеки перечисленные в статье Сторонние библиотеки. Обратите внимание, что названия библиотек и их доступность зависят от вашего дистрибутива. Учтите, что в старых дистрибутивах некоторые пакеты, перечисленные ниже, могут отсутствовать в репозитории. В этом случае обратитесь к разделу Старые и нетрадиционные дистрибутивы.

Перейти к компиляции FreeCAD

Debian и Ubuntu

В дистрибутивах основанных на Debian (Debian, Ubuntu, Mint и других) достаточно просто разрешить все зависимости. Большинство библиотек можно установить с помощью apt-get или менеджера пакетов Synaptic.

Если вы уже установили FreeCAD из официальных репозиториев, вы можете установить его зависимости для сборки с помощью одной строки кода в терминале:

 sudo apt build-dep freecad
  • build-essential
  • cmake
  • python
  • python-matplotlib
  • libtool

или:

  • libcoin80-dev (Debian Jessie, stretch, Ubuntu 16.04-18.10)

или же:

  • libcoin-dev (Debian buster, Ubuntu 19.04 и более поздние версии, а также Ubuntu 18.04 / 18.10 с добавленными freecad-stable/freecad-daily PPA в ваши исходные коды программного обеспечения)
  • libboost-dev
  • libboost-date-time-dev
  • libboost-filesystem-dev
  • libboost-graph-dev
  • libboost-iostreams-dev
  • libboost-program-options-dev
  • libboost-python-dev
  • libboost-regex-dev
  • libboost-signals-dev
  • libboost-serialization-dev
  • libboost-thread-dev
  • libeigen3-dev
  • libopencv-dev | libcv-dev
  • libgts-bin
  • libgts-dev
  • libkdtree++-dev
  • libmedc-dev
  • libproj-dev
  • libvtk6-dev | libvtk7-dev
  • libx11-dev
  • libxerces-c-dev
  • libzipios++-dev
  • lsb-release
  • swig

с Qt4 и Python 2 (для Debian, jessie, stretch, Ubuntu 16.04):

  • libqt4-dev
  • libqt4-opengl-dev
  • libqtwebkit-dev
  • libshiboken-dev
  • libpyside-dev
  • python-dev
  • python-pivy
  • python-ply
  • python-pyside
  • pyside-tools
  • qt4-dev-tools

или с Qt5 и Python 3 (Debian Buster, Ubuntu 19.04 и выше, а также Ubuntu 18.04/18.10 с добавленными freecad-stable/freecad-daily PPA источниками вашего программного обеспечения:

  • libqt5opengl5-dev
  • libqt5svg5-dev
  • libqt5webkit5-dev or qtwebengine5-dev
  • libqt5x11extras5-dev
  • libpyside2-dev
  • libshiboken2-dev
  • pyside2-tools
  • python3-dev
  • python3-pivy
  • python3-ply
  • python3-pyside2.qtcore
  • python3-pyside2.qtgui
  • python3-pyside2.qtsvg
  • python3-pyside2.qtwidgets
  • python3-pyside2uic
  • qtbase5-dev
  • qttools5-dev

или:

* libocct * -dev (официальная версия opencascade, последняя версия, доступная в Debian Buster и Ubuntu 18.10 и более поздних версиях, а также в Ubuntu 18.04 с freecad-stable/freecad-daily PPA добавлены в ваши программные источники)
*occt-draw

или же:

* liboce * -dev (версия сообщества opencascade, устаревшая, доступна в Debian jessie, stretch, Ubuntu 16.04 и более поздних версиях)
*oce-draw

Обратите внимание, что liboce*-dev/libocct*-dev включает следующие библиотеки (замените oce на oct):

  • liboce-foundation-dev
  • liboce-modeling-dev
  • liboce-ocaf-dev
  • liboce-visualization-dev
  • liboce-ocaf-lite-dev

Вам может понадобиться установить эти пакеты по одному.

Дополнительно Вы можете установить следующие дополнительные пакеты:

  • libsimage-dev (чтобы Coin поддерживал дополнительные форматы графических файлов)
  • checkinstall (чтобы зарегистрировать установленные файлы в менеджере пакетов вашей системы, чтобы вы могли легко удалить их позже)
  • python-matplotlib
  • doxygen and libcoin80-doc (если вы собираетесь создавать документацию по исходному коду)
  • libspnav-dev (для устройств 3Dconnexion, таких как Space Navigator или Space Pilot)


Отдельная команда для Qt5 и Python 3 (требуется Pyside2, доступный в Debian Buster и PPC freecad-stable / freecad-daily)

sudo apt install cmake debhelper dh-exec dh-python libboost-date-time-dev libboost-dev libboost-filesystem-dev libboost-graph-dev libboost-iostreams-dev libboost-program-options-dev libboost-python-dev libboost-regex-dev libboost-serialization-dev libboost-signals-dev libboost-thread-dev libcoin-dev libcv-dev libeigen3-dev libgts-bin libgts-dev libkdtree++-dev libmedc-dev libocct-data-exchange-dev libocct-ocaf-dev libocct-visualization-dev libopencv-dev libproj-dev libpyside2-dev libqt5opengl5-dev libqt5svg5-dev libqt5x11extras5-dev libshiboken2-dev libspnav-dev libvtk7-dev libx11-dev libxerces-c-dev libzipios++-dev lsb-release occt-draw pyside2-tools python-matplotlib python3-dev python3-pivy python3-ply python3-pyside2.qtcore python3-pyside2.qtgui python3-pyside2.qtsvg python3-pyside2.qtwidgets python3-pyside2uic qtbase5-dev qttools5-dev libqt5webkit5-dev swig

Отдельная команда для Qt4 и Python 2

sudo apt install cmake debhelper dh-exec dh-python libboost-date-time-dev libboost-dev libboost-filesystem-dev libboost-graph-dev libboost-iostreams-dev libboost-program-options-dev libboost-python-dev libboost-regex-dev libboost-serialization-dev libboost-signals-dev libboost-thread-dev libcoin80-dev libopencv-dev libeigen3-dev libgts-bin libgts-dev libkdtree++-dev libmedc-dev libocct-data-exchange-dev libocct-ocaf-dev libocct-visualization-dev libproj-dev libpyside-dev libqt4-dev libqt4-opengl-dev libqtwebkit-dev libshiboken-dev libspnav-dev libvtk6-dev libx11-dev libxerces-c-dev libzipios++-dev lsb-release occt-draw pyside-tools python-dev python-matplotlib python-pivy python-ply swig

Пользователи Ubuntu 16.04, пожалуйста, смотрите так же эти дополнительные инструкции (en).

Fedora

Вам нужны следующие пакеты:

  • gcc-c++ (or possibly another C++ compiler?)
  • cmake
  • doxygen
  • swig
  • gettext
  • dos2unix
  • desktop-file-utils
  • libXmu-devel
  • freeimage-devel
  • mesa-libGLU-devel
  • OCE-devel
  • python
  • python-devel
  • python-pyside-devel
  • pyside-tools
  • boost-devel
  • tbb-devel
  • eigen3-devel
  • qt-devel
  • qt-webkit-devel
  • ode-devel
  • xerces-c
  • xerces-c-devel
  • opencv-devel
  • smesh-devel
  • coin3-devel

(Если в вашей версии Fedora последнее, что доступно, это coin2, используйте пакеты из http://www.zultron.com/rpm-repo/)

  • soqt-devel
  • freetype
  • freetype-devel

Добавьте, если нужно:

  • libspnav-devel (для поддержки устройств 3Dconnexion, вроде Space Navigator или Space Pilot)
  • pivy ( https://bugzilla.redhat.com/show_bug.cgi?id=458975 Pivy не обязателен, но нужен для модуля Draft)

Gentoo

Простейший путь узнать, какие пакеты нужны для компиляции FreeCAD - проверить через portage:

emerge -pv freecad

Вы получите список дополнительных пакетов, которые следует установить на Вашей системе.

Если FreeCAD недоступен в portage, он доступен в оверлее waebbl. Система отслеживания ошибок на оверлее waebbl Github может помочь решить некоторые проблемы, с которыми вы можете столкнуться. Оверлей предоставляет freecad-9999 </ tt>, который вы можете выбрать для компиляции или просто использовать для получения зависимостей.

<tt>layman -a waebbl</tt>

</div> </div> </div> </div>

openSUSE

Tumbleweed

The following commands will install the packages required for building FreeCAD with Qt5 and Python 3.

zypper in --no-recommends -t pattern devel_C_C++ devel_qt5

zypper in libqt5-qtbase-devel libqt5-qtsvg-devel libqt5-qttools-devel boost-devel swig libboost_program_options-devel libboost_mpi_python3-devel libboost_system-devel libboost_program_options-devel libboost_regex-devel libboost_python3-devel libboost_thread-devel libboost_system-devel libboost_headers-devel libboost_graph-devel python3 python3-devel python3-matplotlib python3-matplotlib-qt5 python3-pyside2 python3-pyside2-devel python3-pivy gcc gcc-fortran cmake occt-devel libXi-devel opencv-devel libxerces-c-devel Coin-devel SoQt-devel freetype2-devel eigen3-devel libode6 vtk-devel libmed-devel hdf5-openmpi-devel openmpi2-devel netgen-devel freeglut-devel libspnav-devel f2c doxygen dos2unix glew-devel

The following command will install Qt Creator and the GNU Project Debugger.

zypper in libqt5-creator gdb

If any packages are missing, then you can check the Tumbleweed "FreeCAD.spec" file on the Open Build Service.

Also, check to see if there are any patches you need to apply (such as 0001-find-openmpi2-include-files.patch).

Leap

If there is a difference between the available packages on Tumbleweed and Leap, then you can read the Leap "FreeCAD.spec" file on the Open Build Service to determine the required packages.

Arch Linux

You will need the following libraries from the official repositories:

  • boost-libs
  • curl
  • hicolor-icon-theme
  • libspnav
  • opencascade
  • python2-matplotlib
  • shared-mime-info
  • xerces-c
  • boost
  • cmake
  • desktop-file-utils
  • eigen
  • gcc-fortran
  • swig

Так же обязательно проверьте AUR насчёт пропущенных пакетов, которые сейчас вне репозиториев:

  • coin
  • python2-pivy
  • python2-pyside
  • python2-pyside-tools
  • python2-shiboken
  • qtwebkit
  • med (Modelisation et Echanges de Donnees)
sudo pacman -S boost-libs curl hicolor-icon-theme libspnav opencascade python2-pivy python2-matplotlib python2-pyside python2-shiboken qtwebkit shared-mime-info xerces-c boost cmake coin desktop-file-utils eigen gcc-fortran med python2-pyside-tools

Старые и нетрадиционные дистрибутивы

В других дистрибутивах у нас слишком мало откликов от пользователей, так что может оказаться трудно найти требуемые пакеты. Сначала попробуйте найти требуемые пакеты, упомянутые в Сторонних библиотеках. Учтите, что некоторые из них могут иметь в вашем дистрибутиве немного другие имена пакетов (Вроде name, libname, name-dev, name-devel, и так далее...).

Вам так же нужен компилятор GNU GCC версии 3.0.0 или выше. Так же нужен g++, поскольку FreeCAD полностью написан на C++. Во время компиляции исполняются некоторые скрипты Python, поэтому ваш интерпретатор Python должен работать правильно. Во избежание проблем компоновки во время процесса сборки системы, хорошо бы иметь путь к библиотекам или в переменной LD_LIBRARY_PATH, или в конфигурационном файле ld.so.conf. Это обычно уже так в последних дистрибутивах.

Для дополнительных деталей смотрите так же в исходных кодах README.Linux.

Pivy

Pivy не обязателен ни для компиляции, ни для работы FreeCAD. Он нужен для работы Draft модуля . Если Вы не собираетесь использовать этот модуль, Вам не нужен pivy. С ноября 2015 устаревшая версия Pivy включённая в исходные коду FreeCAD более не компилируется на многих системах из-за устаревания. Если Вы не можете найти Pivy в своём дистрибутиве, Вы можете скомпилировать pivy самостоятельно:

Инструкции по компиляции Pivy

Компиляция FreeCAD

FreeCAD использует CMake в качестве основной системы сборки. CMake - это система сборки, доступная во всех основных операционных системах. Компиляция с помощью CMake обычно очень проста и происходит в два этапа.

  1. CMake проверяет наличие всех необходимых программ и библиотек в вашей системе и настраивает систему сборки для второго шага. Хотя FreeCAD имеет несколько вариантов конфигурации на выбор, значения по умолчанию достаточны. Некоторые альтернативные конфигурации подробно описаны ниже.
  2. Сама компиляция, которая создает исполняемый файл FreeCAD.

Так как FreeCAD большое приложение, компиляция может занять от 10 до 30 минут, в зависимости от мощности оборудования, выполняющего компиляцию.

Компиляций вне исходников

Если Вы намерены следовать за быстрой эволюцией FreeCAD, сборка в отдельном каталоге подходит лучше. Каждый раз, когда Вы обновляете исходные коды, СMake интеллектуально отметит изменённые файлы и перекомпилирует только то, что нужно. Сборка вне исходников особо полезно при использовании системы Git, поскольку Вы можете запросто попробовать другие ветви исходных кодов, не приводя в смущение систему сборки. Для сборки вне исходников создайте сборочный каталог, и внутри него укажите СMake каталог исходников (при использовании графического интерфейса замените в нижеследующем коде "cmake" на "cmake-gui"):

$ mkdir freecad-build
$ cd freecad-build
$ cmake ../freecad-code (or whatever the path is to your FreeCAD source folder)
$ make -j$(nproc --ignore=2)

Исполняемый файл FreeCAD будет находиться в каталоге <tt> freecad-build / bin </ tt>.

Сборка внутри древа исходников

Сборки внутри древа исходников хороши, если вы хотите просто посмотреть на FreeCAD, и хотите с лёгкостью удалить его прямо с этим каталогом. Однако, если вы не знаете какой способ выбрать, не делайте сборку внутри древа исходников. Создайте сборку вне исходного кода, как описано ранее. Однако FreeCAD может быть собран внутри исходного кода, что означает, что все файлы, полученные в результате компиляции, остаются в той же папке, что и исходный код.

Для компиляции FreeCAD используйте следующие команды:

$ cd freecad-source
$ cmake .
$ make -j$(nproc --ignore=2)

Исполняемый файл FreeCAD будет находиться в каталоге <tt>freecad-source/bin.

Как восстановить каталог исходных кодов после случайного запуска компиляции внутри исходников.

Для восстановления каталога исходных кодов после случайного запуска компиляции внутри исходников существует метод с использованием Git. Если вы не очистите его, последующие запуски cmake</ tt> могут не учитывать все ваши новые параметры.

$ > .gitignore
$ git clean -df
$ git reset --hard HEAD

Первая строка очищает файл <tt> .gitignore </ tt>. Это гарантирует, что следующие команды clean и reset будут влиять на все в каталоге и не будут игнорировать элементы, соответствующие выражениям в <tt> .gitignore </ tt>. Во второй строке удаляются все файлы и каталоги, которые не отслеживаются репозиторием git, а затем reset сбрасывает все изменения в отслеживаемых файлах (включая первую команду, которая очистила файл <tt> .gitignore </ tt>.

Конфигурация

Передавая различные параметры в CMake, вы можете изменить способ компиляции FreeCAD. Это может быть полезно для нескольких целей. Например, запустив CMake следующим образом, вы можете отменить сборку модуля FEM:

cmake -D BUILD_FEM:BOOL=OFF ''path-to-freecad-root''

Все возможные параметры перечислены в главном файле <tt> CMakeLists.txt FreeCAD . Попробуйте найти строку OPTION . Или используйте команду cmake -LH . Ниже приведен список наиболее важных параметров, которые вы можете настроить.

Чтобы передать значение для параметра, найденного в файле CMakeLists.txt , используйте следующий флаг: -D <var>: <type> = <value>

Для версии Debug
$ cmake -DCMAKE_BUILD_TYPE=Debug .
Для версии Release

Сборка Release будет работать намного быстрее, чем сборка Debug. Sketcher становится очень медленным со сложными набросками для Debug сборки FreeCAD.

$ cmake -DCMAKE_BUILD_TYPE=Release .

Внешний или встроенный Pivy

Если вы хотите использовать системную копию Pivy, что обычно и происходит для Linux-систем, установите флаг компилятора для использования правильного pivy с -DFREECAD_USE_EXTERNAL_PIVY = 1 </ tt>. Использование внешнего Pivy стало стандартом для Linux при разработке FreeCAD 0.16, поэтому его не нужно настраивать вручную при компиляции этой и более новой версии в Linux.

Сборка для Qt5

По умолчанию FreeCAD собирается для Qt4. Можно собрать для Qt5, включив опцию <tt> -DBUILD-QT5 .

cmake -DBUILD_QT5=ON .

Сборка для конкретной версии Python

По умолчанию FreeCAD может обнаруживать только Python 2. Можно выбрать способ сборки для конкретной версии Python (например, Python 2 или Python 3), установив некоторые параметры cmake. Пример для Python 3 показан ниже:

cmake -DPYTHON_LIBRARY=/usr/lib64/libpython3.6m.so \
    -DPYTHON_INCLUDE_DIR=/usr/include/python3.6m \
    -DPYTHON_PACKAGES_PATH=/usr/lib64/python3.6/site-packages \
    -DPYTHON_EXECUTABLE=/usr/bin/python3.6 \
    .

Расположение и номера версий ваших файлов и каталогов Python будут различаться в зависимости от того, какой дистрибутив вы используете. Вы можете найти их, используя команды Unix locate или which .

Building with Qt Creator

To use Qt5 and Python 3, add the following to the bottom of: Projects → Manage Kits → Kits → Default (or your kit) → CMake Configuration:

PYTHON_EXECUTABLE=/usr/bin/python3.7
PYTHON_INCLUDE_DIR=/usr/include/python3.7m
PYTHON_LIBRARY=/usr/lib64/libpython3.7m.so
PYTHON_PACKAGES_PATH=/usr/lib64/python3.7/site-packages
BUILD_QT5=ON

The paths used for python depend on your system and might need to be changed. "python3 -m site" in a terminal will at least help with determining the site-package directory.

If you aren't using Python 3.7.x, you will need to replace the "3.7". From a terminal you can check with "python3 -V" and ignore the number furthest right.

Switch Projects → Run → Run Configuration from FreeCADMainCMD to FreeCADMain (unless you want the command line only version).

Плагин Qt Designer

Если вы хотите разрабатывать Qt вещи для FreeCAD, вам понадобится плагин Qt Designer, который предоставляет все пользовательские виджеты FreeCAD. Следуйте по ссылке:

freecad/src/Tools/plugins/widget

Пока что мы не предоставляем make-файл - но запуск команды

qmake plugin.pro

создаст его. После этого запуск команды

make

создаст библиотеку libFreeCAD_widgets.so. Чтобы сделать эту библиотеку доступной для Qt Designer, вы должны скопировать файл в $QTDIR/plugin/designer

Doxygen

Если вы чувствуете себя достаточно смелым, чтобы погрузиться в код, вы могли бы воспользоваться возможностью для создания и изучения сгенерированной Doxygen FreeCAD исходной документации

Создание пакета debian

Если Вы планируете создать пакет Debian вне исходников, Вам следует сначала установить следующие пакеты:

dh-make
devscripts

#optional, used for checking if packages are standard-compliant
lintian

Для сборки пакета откройте консоль, перейдите в каталог FreeCAD и вызовите

debuild

Когда пакет построен, Вы можете использовать lintian для проверки, содержит ли пакет ошибки

#replace by the name of the package you just created
lintian your-fresh-new-freecad-package.deb

Разрешение проблем

Примечание для 64-битных систем

При компиляции FreeCAD на 64-бит известна проблема с 64-битным пакетом OpenCASCADE. Чтобы FreeCAD правильно заработал, Вам нужно запустить скрипт ./configure с дополнительно установленным define _OCC64:

./configure CXXFLAGS="-D_OCC64"

Для систем, основанных на Debian, этот обходной путь при использовании прекомпилированных пакетов не требуется, поскольку пакет OpenCASCADE собран так, чтобы всё это было уже установлено. Теперь Вам только нужно скомпилировать FreeCAD так, как описано выше.

Скрипты автоматической компиляции

Это всё, что Вам нужно для полной компиляции FreeCAD. Это односкриптовое решение, работающее на свежеустановленном дистрибутиве. Команда запросит пароль root (для установки пакетов) и порой для подтверждения входа на внешний сервер репозитория. Эти скрипты должны запускаться на 32- 64-битных версиях. Они написаны для разных версий, но, скорее всего, будут работать для позднейший версий с небольшими изменениями или без них.

Если у Вас есть такой скрипт для Вашего любимого дистрибутива, пришлите его, пожалуйста! Мы вставим его в эту статью.

Ubuntu

Эти скрипты обеспечивают надёжный путь для установки верного набора зависимостей, требуемых для сборки и запуска FreeCAD в Ubuntu. Они используют репозитории PPA Ubuntu FreeCAD, и должны работать на любой версии Ubuntu, для которой есть целевой PPA. 'Ежедневный' PPA нацелен на последнюю версию Ubuntu, а 'стабильный' PPA нацелен на все официально поддерживаемые версии Ubuntu.

Этот скрипт устанавливает зависимости для ежедневных слепков текущей разработки FreeCAD.

#!/bin/sh
sudo add-apt-repository --enable-source ppa:freecad-maintainers/freecad-daily && sudo apt-get update
# Install the dependencies needed to build FreeCAD
sudo apt-get build-dep freecad-daily
# Install the dependencies needed to run FreeCAD (and a build of FreeCAD itself)
sudo apt-get install freecad-daily

Этот скрипт устанавливает зависимости для последнего стабильного выпуска FreeCAD. (Для Ubuntu 12.04, уберите "--enable-source" из команды add-apt-repository.)

#!/bin/sh
sudo add-apt-repository --enable-source ppa:freecad-maintainers/freecad-stable && sudo apt-get update
# Install the dependencies needed to build FreeCAD
sudo apt-get build-dep freecad
# Install the dependencies needed to run FreeCAD (and a build of FreeCAD itself)
sudo apt-get install freecad

(Эти скрипты, кроме того, устанавливают сборки PPA самого FreeCAD. Вы можете деинсталлировать это, оставив зависимости. Однако оставив их установленными, менеджер пакетов будет поддерживать актуальность версий этих зависимостей, что полезно, если Вы будете следовать разработке в течение долгого времени.)

После установки зависимостей посмотрите общие инструкции для получения исходного кода, запуска CMake и компиляции. Следующий скрипт служит примером одного из способов сделать это.

#!/bin/sh

# checkout the latest source
git clone https://github.com/FreeCAD/FreeCAD.git freecad

# go to source dir
cd freecad

# open cmake-gui window
cmake-gui .

# build configuration
cmake .

# build FreeCAD
# Note: to speed up build use all CPU cores: make -j$(nproc)
make

OpenSUSE 12.2

Внешние репозитории для компиляции FreeCAD 0.13 с этим релизом не требуются. Однако есть несовместимость с python3-devel, который надо удалить. FreeCAD может быть скомпилирован из GIT так же как в OpenSUSE 12.2

# install needed packages for development
sudo zypper install gcc cmake OpenCASCADE-devel libXerces-c-devel \
python-devel libqt4-devel python-qt4 Coin-devel SoQt-devel boost-devel \
libode-devel libQtWebKit-devel libeigen3-devel gcc-fortran git swig
 
# create new dir, and go into it
mkdir FreeCAD-Compiled 
cd FreeCAD-Compiled
 
# get the source
git clone https://github.com/FreeCAD/FreeCAD.git free-cad
 
# Now you will have subfolder in this location called free-cad. It contains the source
 
# make another dir for compilation, and go into it
mkdir FreeCAD-Build1
cd FreeCAD-Build1 
 
# build configuration 
cmake ../free-cad
 
# build FreeCAD
make
 
# test FreeCAD
cd bin
./FreeCAD -t 0

Since you are using git, next time you wish to compile you do not have to clone everything, just pull from git and compile once more

# go into free-cad dir created earlier
cd free-cad
 
# pull
git pull
 
# get back to previous dir
cd ..
 
# Now repeat last few steps from before.
 
# make another dir for compilation, and go into it
mkdir FreeCAD-Build2
cd FreeCAD-Build2
 
# build configuration 
cmake ../free-cad
 
# build FreeCAD
# Note: to speed up build use all CPU cores: make -j$(nproc)
make
 
# test FreeCAD
cd bin
./FreeCAD -t 0

Debian Squeeze

# get the needed tools and libs
sudo apt-get install build-essential python libcoin60-dev libsoqt4-dev \
libxerces-c2-dev libboost-dev libboost-date-time-dev libboost-filesystem-dev \
libboost-graph-dev libboost-iostreams-dev libboost-program-options-dev \
libboost-serialization-dev libboost-signals-dev libboost-regex-dev \
libqt4-dev qt4-dev-tools python2.5-dev \
libsimage-dev libopencascade-dev \
libsoqt4-dev libode-dev subversion cmake libeigen2-dev python-pivy \
libtool autotools-dev automake gfortran
 
# checkout the latest source
git clone https://github.com/FreeCAD/FreeCAD.git freecad
 
# go to source dir
cd freecad
 
# build configuration 
cmake .
 
# build FreeCAD
# Note: to speed up build use all CPU cores: make -j$(nproc)
make
 
# test FreeCAD
cd bin
./FreeCAD -t 0

Fedora 27/28/29

Posted by user [PrzemoF] in the forum.

#!/bin/bash

ARCH=$(arch)

MAIN_DIR=FreeCAD
BUILD_DIR=build

#FEDORA_VERSION=27
#FEDORA_VERSION=28
FEDORA_VERSION=29

PACKAGES="gcc cmake gcc-c++ boost-devel zlib-devel swig eigen3 qt-devel \
shiboken shiboken-devel pyside-tools python-pyside python-pyside-devel xerces-c \
xerces-c-devel OCE-devel smesh graphviz python-pivy python-matplotlib tbb-devel \
 freeimage-devel Coin3 Coin3-devel med-devel vtk-devel"

FEDORA_29_PACKAGES="boost-python2 boost-python3 boost-python2-devel boost-python3-devel"

if [ "$FEDORA_VERSION" = "29" ]; then
    PACKAGES="$PACKAGES $FEDORA_29_PACKAGES"
fi

echo "Installing packages required to build FreeCAD"
sudo dnf -y install $PACKAGES
cd ~
mkdir $MAIN_DIR || { echo "~/$MAIN_DIR already exist. Quitting.."; exit; }
cd $MAIN_DIR
git clone https://github.com/FreeCAD/FreeCAD.git
mkdir $BUILD_DIR || { echo "~/$BUILD_DIR already exist. Quitting.."; exit; }
cd $BUILD_DIR
cmake ../FreeCAD 
make -j$(nproc)

Обновление исходного кода

Разработка FreeCAD ведётся быстро, примерно ежедневно появляются исправления ошибок или расширение возможностей. Система cmake позволяет Вам по-умному обновить исходный код и перекомпилировать только изменения, делая последовательные компиляции очень быстрыми. Обновление исходного кода через git или subversion очень просто:

#Replace with the location where you cloned the source code the first time
cd freecad-code
#If you are using git
git pull

Перейдите в соответствующий каталог сборки и запустите cmake снова (поскольку cmake обновит данные номера версии из меню Help, ...about FreeCAD), но вам не нужно добавить путь к исходному коду после "cmake", только пробел и точку:

#Replace with the location of the build directory
cd ../freecad-build
cmake .
# to use all cpu cores change to: make -j$(nproc)
make

Ссылки

Смотрите так же Ускорение компиляции.