CompileOnUnix/ru

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

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

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

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

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

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


 * Source .tar.gz
 * Source .zip

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

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

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

If you already installed FreeCAD from the official repositories, you can install its build dependencies with this single line of code in a terminal: sudo apt build-dep freecad

either:
 * build-essential
 * cmake
 * python
 * python-matplotlib
 * libtool
 * libcoin80-dev (Debian jessie, stretch, Ubuntu 16.04 to 18.10)

or:
 * libcoin-dev (Debian buster, Ubuntu 19.04 and forward, as well as Ubuntu 18.04/18.10 with the freecad-stable/freecad-daily PPAs added to your software sources)

with Qt4 and Python 2 (for Debian jessie, stretch, Ubuntu 16.04):
 * 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
 * libqt4-dev
 * libqt4-opengl-dev
 * libqtwebkit-dev
 * libshiboken-dev
 * libpyside-dev
 * python-dev
 * python-pivy
 * python-ply
 * python-pyside
 * pyside-tools
 * qt4-dev-tools

or with Qt5 and Python 3 (Debian buster, Ubuntu 19.04 and forward, as well as Ubuntu 18.04/18.10 with the freecad-stable/freecad-daily PPAs added to your software sources:
 * 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

either:
 * libocct*-dev (official opencascade version, up-to-date, available in Debian buster and Ubuntu 18.10 and forward, as well as Ubuntu 18.04 with the freecad-stable/freecad-daily PPAs added to your software sources)
 * occt-draw

or:
 * liboce*-dev (opencascade community edition, outdated, available in Debian jessie, stretch, Ubuntu 16.04 and forward)
 * 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 (to make Coin to support additional image file formats)
 * checkinstall (to register your installed files into your system's package manager, so you can easily uninstall later)
 * python-matplotlib
 * doxygen and libcoin80-doc (if you intend to generate source code documentation)
 * libspnav-dev (for 3Dconnexion devices support like the Space Navigator or Space Pilot)

Single command for Qt5 and Python 3 (requires Pyside2 available in Debian buster and the freecad-stable/freecad-daily PPAs)

Single command for Qt4 and Python 2

Пользователи 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 , который вы можете выбрать для компиляции или просто использовать для получения зависимостей.

layman -a waebbl

OpenSUSE
Вам потребуются следующие пакеты: Для стабильного FreeCAD 0.14 и нестабильного 0.15, если библиотеки Eigen3 и swig не найдены в стандартных репозиториях, Вы можете получить их установкой в один клик здесь: Заметьте так же, что библиотека Eigen3 из Factory Education иногда вызывает проблемы, так что используйте её из репозитория KDE 4.8 Extra
 * gcc
 * cmake
 * OpenCASCADE-devel
 * libXerces-c-devel
 * python-devel
 * libqt4-devel
 * libshiboken-devel
 * python-pyside-devel
 * python-pyside-tools
 * Coin-devel
 * SoQt-devel
 * boost-devel
 * libode-devel
 * libQtWebKit-devel
 * libeigen3-devel
 * gcc-fortran
 * freetype2
 * freetype2-devel
 * Eigen3
 * swig
 * Eigen3
 * swig

Начиная с 0.17pre, Opensuse 13.2 слишком стара для компиляции из-за слишком старой версии boost.

Arch Linux
Вам нужны следующие библиотеки из официальных репозиториев:


 * 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)

Старые и нетрадиционные дистрибутивы
В других дистрибутивах у нас слишком мало откликов от пользователей, так что может оказаться трудно найти требуемые пакеты. Сначала попробуйте найти требуемые пакеты, упомянутые в Сторонних библиотеках. Учтите, что некоторые из них могут иметь в вашем дистрибутиве немного другие имена пакетов (Вроде 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"):

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Fedora 27/28/29
Posted by user [PrzemoF] in the forum.

{ echo "~/$MAIN_DIR already exist. Quitting.."; exit; } cd $MAIN_DIR git clone https://github.com/FreeCAD/FreeCAD.git mkdir $BUILD_DIR

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

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

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