FreeCAD模块开发指南 第2章 FreeCAD源代码结构

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子文件夹包含配置。

学习路径

  1. 作为用户,熟悉FreeCAD GUI操作。
    请参见FreeCAD维基 用户中心
    ,youtube上的教程和用户手册
  2. 熟悉Python脚本,从宏录制中学习。
    FreeCAD的优秀特性是所有GUI操作都记录在Python控制台中。
    FreeCAD维基 高级用户中心 FreeCAD维基 开发人员中心
  3. 熟悉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/下载该软件。
  4. 开发/扩展纯Python模块,可以避免具有挑战性的Python包装工作。
  5. 开发/扩展C ++和Python混合模块。
  6. 编写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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容