Skip to content

QtWorks/FastCAE

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

说明

源码文件夹结构

  • cmake: cmake相关的脚本
  • doc: 生成文档需要的模板及配置文件
  • extlib: 第三方依赖库(见下文extlib获取方式)
  • src: FastCAE源码
  • test: 包含单元测试代码(待整理)

构建编译

FastCAE相关的cmake构建选项说明

  • FASTCAE_AUTO_DOWNLOAD:如果源码目录不存在extlib目录时是否会自动从gitee克隆依赖包。
  • FASTCAE_DOXYGEN_DOC:是否需要构建目标Doxygen(需要本地安装Doxygen软件)
  • FASTCAE_ENABLE_DEV:是否在构建完成时自动拷贝依赖文件到调试目录。(开启该选项会在每次编译完拷贝第三方依赖库文件到构建目录,会增加构建时间)
  • FASTCAE_ENABLE_MPI:是否开启MPI支持(目前无效)。
  • FASTCAE_ENABLE_OPENMP:是否开启OpenMP。
  • FASTCAE_ENABLE_TEST:是否构建单元测试模块(目前无效)。
  • FASTCAE_INSTALLATION_PACKAGE:是否构建安装包制作PACKAGE。

cmake预定义目标说明:

  • ALL_BUILD:生成所有项目。
  • INSTALL:安装FastCAE到CMAKE_INSTALL_PREFIX定义的目录。
  • PACKAGE或者package: 在Visual Studio中该目标为大写,在其它构建系统中该目标为小写,用于将FastCAE打包成安装包(exe、deb、rpm)。
  • DOXYGEN: 生成FastCAE的Doxygen格式文档(html)。

编译视频教程

Windows

Linux

编译说明

  • windows环境下使用vscode时,编译工具链只能使用Visual Studio,目前不支持MinGW工具

extlib目录结构

extlib
├─CGNS(version:4.3.0)
│
├─Gmsh(version:4.8.0)
│
├─HDF5(version:1.13.1)
│
├─OCC(version:7.6.0)
│
├─Python(version:3.7.0)
│
├─QuaZIP(version:0.7.3)
│
├─Qwt(version: Qwt:6.1.6 QwtPolar:1.1.1)
│
├─TecIO(version:1.4.2)
│
└─VTK(version:9.0.1)

extlib获取方式

Linux系统

git clone https://gitee.com/DISOGitee/FastCAELinuxExtlib.git extlib

windows系统

git clone https://gitee.com/DISOGitee/FastCAEWinExtlib.git extlib

编译打包

项目采用cmake构建系统组织代码,可以直接使用cmake转换visual studio 2017工程或者生成Makefile文件,或者可以直接使用支持cmake系统的IDE(比如:vscode、clion、visual studio、qtcreator等)打开项目文件夹进行构建、编译。

项目依赖文件会在构建阶段根据系统自动克隆对应的依赖库到本地extlib文件夹,如果需要离线部署,可以在“extlib获取方式”中离线下载依赖库。

构建项目:

cmake -DCMAKE_INSTALL_PREFIX:PATH=/path_to_install -DQt5_DIR:PATH=/path_of_Qt5Config.cmake  -B build -S . 

如果在windows环境下使用命令行构建项目需要增加参数-G "Visual Studio 15 2017 Win64",具体参数需要根据自己的Visual Studio的版本确定,

安装:

cmake --build build --target install

源码(.tar.gz and .zip)打包:

cmake --build build --target package_source

制作安装包(.deb .rpm .exe):

cmake --build build --target package

备注:

1、如果构建系统是Makefile、Ninja、Xcode,则生成package目标,如果是MVSC构建系统,则生成大写的PACKAGE目标。

cmake --build . --target package 或者 make package 或者 ninja package

2、如果构建系统是Makefile、Ninja,还会则生成package_source目标用于打包源码。

cmake --build . --target package_source 或者 make package_source 或者 ninja package_source

特别说明

  • 源码绝对路径中不要出现中文字符、空格以及特殊字符:(){}*/?|\等
  • 要求cmake的最低版本为3.21
  • windows环境制作安装包要求NSIS版本为3.03+
  • linux环境制作安装包需要安装dpkg-deb或者rpmbuild
  • linux的其他系统依赖包OpenGLfontconfigxkbcommon

测试平台

序号 操作系统 GLIBC版本 编译器 Qt 测试结果 备注
1 Ubuntu18.04 2.27 GNU GCC 7.5.0 Qt5.14.2 通过
2 Ubuntu20.04 2.31 GNU GCC 9.4.0 Qt5.14.2 通过
3 Ubuntu22.04 2.35 GNU GCC 11.2.0 Qt5.14.2 通过 deb成功打包
4 CentOS 7.0.1406 2.17 GNU GCC 8.3.1 Qt5.14.2 通过 借助devtoolset-8升级GCC
5 CentOS 7.9.2009 2.17 GNU GCC 7.5.0 Qt5.14.2 通过
6 CentOS 8.5.2111 2.28 GNU GCC 8.5.0 Qt5.14.2 通过 rpm成功打包
7 RedHat Server 7.0 待测试
8 RedHat 8.1 2.28 GNU GCC 8.5.0 Qt5.14.2 通过
9 RedHat 9.0 待测试
10 Windows7 X64 Visual Studio 2017 Community Qt5.14.2 通过 VS附带安装Windows 8.1SDK
11 Windows10 X64 Visual Studio 2017 Community Qt5.14.2 通过 SDK 10.0.17763.0,NSIS成功打包
12 deepin 20.7社区版 待测试
13 ubuntukylin 22.04 2.35 GNU GCC 11.2.0 Qt5.14.2 通过 基于Ubuntu22.04

相关链接

感谢开源贡献者

使用交流

技术交流QQ群:671925863

官方微信号:FastCAE-DISO