FreeCAD官方存储库有标准的github项目布局,存储库根目录中包含README,License, Continuous Integration安装文件。src/
文件夹中的FreeCAD源代码结构树反映了其模块化的设计。
FreeCAD源文件夹中的文件和文件夹列表
[本段将由python脚本生成]
FreeCAD Mod文件夹中的模块列表
[本段将由python脚本生成]
文档
Doxygen生成的文档
源代码文档由doxygen从C++和python源代码文档字符串生成。doxygen项目支持的doxygen官网在编写源代码文件和文档生成方面表现出色。FreeCAD项目有一个专门的维基 Doxygen页面:https://www.freecadweb.org/wiki/Doxygen。
Schematic of documentation generation by doxygen
生成的doxygen文档(静态html内容)可以在作者的个人网站上找到Doxygen generated online documentation of source for 0.19dev on 2019-06-24。
FreeCAD 维基
除了doxygen生成的源文档,FreeCAD维基是源文档的另一个来源,提供了关于软件设计,特定模块等主题的更多信息。
https://www.freecadweb.org/wiki/Main_Page
有3个用户中心
Crystal Clear app display.png 用户中心: 此页面包含对一般用户有用的文档:所有工作台的列表,有关如何安装并使用FreeCAD应用程序的详细说明,教程以及所有你需要的入门资料。
Crystal Clear app terminal.png 超级用户中心: 此页面收集了适用于高级用户和有兴趣编写python脚本的人员的文档。在这里您还能找到宏存储库,有关如何安装和使用这些宏的说明,以及关于如何根据特定需求来自定义FreeCAD的更多信息。
Crystal Clear app tutorials.png 开发人员中心: 此页面包含面向开发人员的资料:如何自己编译FreeCAD,FreeCAD的源代码结构以及如何浏览,如何开发新的工作台,或将FreeCAD嵌入您自己的程序中。
其中,开发人员中心是模块开发人员的必读资料。
用户手册
一位开发人员已经为FreeCAD 0.18版编写了合适的用户手册。
Crystal Clear manual.png FreeCAD用户手册以更线性方式呈现此维基中的信息。它被设计得可以像书一样阅读,从上面的用户中心开始,轻松地向你介绍许许多多的其他页面。
构建FreeCAD环境
CMake简介
CMake是FreeCAD的跨平台构建工具。 除了生成用于构建FC的制作文件外,它还生成Windows的安装程序,Linux的DEB / RPM软件包以及MacOSX映像包。
有关CMake的快速入门,请参见附录2 cmake速查表。
FreeCAD中的CMake
根目录中的项目顶层CMakeLists.txt
很长,它检测第三方库并处理编译器和操作系统的差异。相应地,源代码树中的[src / CMakeLists.txt]要简短得多,并带有add_directory(subfolder_name)
。
存储库根目录中的CMake
文件夹中有* .cmake文件,用于检测库。 如果添加了带有c ++代码的新工作台,则可能需要CMake的第三方检测器。
set(CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cMake")
以下假设代码演示了如何使用CMake指定不从源代码构建OpenFOAM,而是可以将其作为二进制文件进行安装。 对于其他依赖项,例如像netgen和gmsh之类的FEM网格划分工具,也可以这样做。
if(NOT MSVC)
OPTION(BUILD_FEM_FOAM "Build the FreeCAD FEM module with the OpenFOAM CFD solver" ON)
else
OPTION(BUILD_FEM_FOAM "Build the FreeCAD FEM module with the OpenFOAM CFD solver" OFF)
endif(NOT MSVC)
深入探索,我们可以在顶层CMake文件[src / CMakeLists.txt]中看到以下内容
# -------------------- OpenFOAM --------------------
if (BUILD_FEM_FOAM)
find_package(FOAM)
endif(BUILD_FEM_FOAM)
cMake/FindSMESH.cmake代码分析
# Try to find Salome SMESH
# Once complete, this will define
#
# SMESH_FOUND - if the current system has Salome SMESH
# SMESH_INCLUDE_DIR - path to the Salome SMESH include directory
# SMESH_LIBRARIES - path to the Salome SMESH libraries
#
IF (CMAKE_COMPILER_IS_GNUCC)
FIND_PATH(SMESH_INCLUDE_DIR SMESH_Mesh.hxx
# These are default search paths, why specify them?
# /usr/include
# /usr/local/include
PATH_SUFFIXES smesh
)
FIND_LIBRARY(SMESH_LIBRARY SMESH
# /usr/lib
# /usr/local/lib
)
ELSE (CMAKE_COMPILER_IS_GNUCC)
# Not yet implemented
ENDIF (CMAKE_COMPILER_IS_GNUCC)
SET(SMESH_FOUND FALSE)
IF(SMESH_LIBRARY)
SET(SMESH_FOUND TRUE)
GET_FILENAME_COMPONENT(SMESH_LIBRARY_DIR ${SMESH_LIBRARY} PATH)
set(SMESH_LIBRARIES
${SMESH_LIBRARY_DIR}/libDriver.so
${SMESH_LIBRARY_DIR}/libDriverDAT.so
${SMESH_LIBRARY_DIR}/libDriverSTL.so
${SMESH_LIBRARY_DIR}/libDriverUNV.so
${SMESH_LIBRARY_DIR}/libSMDS.so
${SMESH_LIBRARY_DIR}/libSMESH.so
${SMESH_LIBRARY_DIR}/libSMESHDS.so
${SMESH_LIBRARY_DIR}/libStdMeshers.so
)
ENDIF(SMESH_LIBRARY)
持续集成(CI)
持续集成(CI)基本上是构建和测试自动化的范例。 CI对于有效维护软件项目至关重要。 FreeCAD使用多种CI工具。
Travis CI
Travis与github紧密集成,并在FreeCAD github存储库中广泛使用。 有关如何为代码存储库设置Travis CI的更多信息,请阅读此实用指南。
Travis使用YAML文件。 对于Linux和MacOS平台,FreeCAD的主要Travis配置文件是.travis.yml。
对于Windows,配置文件为.travis/build.bat。
其他CI工具
除Travis外,还有一个完整的CI软件生态系统,您可以通过专门的维基百科页面了解有关它们的更多信息。
.circleci/config.yml文件将建立镜像容器以设置测试环境。
arcconfig 和 phabricator
"phabricator.uri" : "http://pha.geofinder.eu/"
流浪者云虚拟机
FreeCAD有一个子文件夹来设置云虚拟机,用于构建和测试。
Docker容器配置
subuser/freecad-dev[.subuser.json]添加了用于在Docker容器中开发freecad的子用户文件。
AppVoyer
注册并设置github和bitbucket存储库很简单,请参见官方文档https://www.appveyor.com/docs/。FreeCAD项目使用AppVoyer在Windows上进行构建,尽管它是跨平台的解决方案。
打包和部署
Linux RPM和Deb,AppImage
FreeCAD已经出现在主要linux发行版的官方存储库中,但版本可能已过时。 对于Ubuntu,有PPA可以安装最新甚至每天更新的开发版本。 建议开发人员安装最新版本,尤其是Qt5 + Python3组合。
Windows 和 OSX 预构建
Windows安装程序由NSIS生成,并且是开源的Windows安装程序生成工具。 为Windows打包是在另一个子项目FreeCADInstProj
中,请参阅[https://github.com/FreeCAD/FreeCAD/tree/master/src/WindowsInstaller](https://github.com/FreeCAD/FreeCAD/tree/master/ src / WindowsInstaller)。
其他跨平台软件包管理器
存储库根目录中的package文件夹包含[conda]()
配方以构建Anaconda软件包。 Conda是流行的二进制python软件包(从其他语言编译的python模块)分发系统。
fedora
子文件夹包含配置。
学习路径
- 作为用户,熟悉FreeCAD GUI操作。
请参见FreeCAD维基 用户中心
,youtube上的教程和用户手册。 - 熟悉Python脚本,从宏录制中学习。
FreeCAD的优秀特性是所有GUI操作都记录在Python控制台中。
FreeCAD维基 高级用户中心 FreeCAD维基 开发人员中心。 - 熟悉FreeCAD源代码中的关键类:Base,App,Gui,Part。
用C++,Python GIL,Coin3D,OCC编程确实很有挑战性。不过,作为模块开发人员,不需要了解OCC。 FreeCAD有一个在线API文档,用于导入类例如如属性,文档对象等,请参见https://www.freecadweb.org/wiki/Power_users_hub#API_Functions。
要探索源代码,可在iesensor.com
上找到doxygen生成的文档。 此外,Sourcetrail
也是帮助此工作的工具之一,它是一个功能强大的工具,可免费用于非商业用途,用于探索大型软件项目,请参见FreeCAD论坛讨论。可以从https://www.sourcetrail.com/下载该软件。 - 开发/扩展纯Python模块,可以避免具有挑战性的Python包装工作。
- 开发/扩展C ++和Python混合模块。
- 编写3D渲染代码,即ViewProvider派生的类。
版权声明:本文翻译自《Module developer's guide to FreeCAD source code》,遵循 CC 4.0 BY-SA 协议(https://creativecommons.org/licenses/by-sa/4.0/),转载请附上原文出处链接及本声明。原文链接:https://github.com/qingfengxia/FreeCAD_Mod_Dev_Guide/blob/f9d5ebc48f94dece49c88afe7ad4542751a0f074/chapters/2.FreeCAD_source_code_structure.md#appvoyer。