git clone [email protected]:BombaxCeiba/AutoStarRail.git
建议使用Visual Studio或安装了CMake插件的Visual Studio Code或CLion打开源码目录,这几个软件会自动开始配置项目。
在没有任何配置的情况下,不会生成任何其它语言的接口,也不会需要SWIG。项目会自动寻找环境中的Boost和OpenCV,若没有找到,会自动下载并配置为从源码编译。如果需要构建GUI,则需要Qt5,找不到则会直接报错。在任何情况下,都会从Github下载spdlog、nlohmann_json等库,因此需要有良好的网络环境。
以下是项目中CMake变量的定义
名称 | 默认值 | 说明 |
---|---|---|
EXPORT_JAVA | OFF | 是否导出Java接口 |
EXPORT_CSHARP | OFF | 是否导出C#接口 |
EXPORT_PYTHON | OFF | 是否导出Python接口 |
DAS_SPDLOG_USE_STD_FMT | 由DAS_STD_FMT_SUPPORT决定 | 是否将项目自带的spdlog设置为使用标准库的fmt |
DAS_USE_BUNDLED_FMT | 由DAS_STD_FMT_SUPPORT决定 | 是否使用下载的fmt,此项为ON时,DAS_SPDLOG_USE_STD_FMT默认为OFF |
DAS_BUILD_TEST | OFF | 是否构建测试 |
DAS_BUILD_QT5_GUI | ON | 是否构建GUI |
DAS_USE_LLD | OFF | 是否添加编译选项(非MSVC时)-fuse-ld=lld |
DAS_USE_CCACHE | OFF | 是否使用ccache |
DAS_USE_BUNDLED_BOOST | OFF | 是否下载Boost源码编译 |
DAS_USE_BUNDLED_EIGEN | OFF | 是否下载Eigen用于编译OpenCV |
DAS_USE_BUNDLED_OPENCV | OFF | 是否下载OpenCV源码编译 |
DAS_LLD_EXECUTABLE | lld | lld文件路径,似乎一般也不需要设置 |
GITHUB_MIRROR_URL | https://github.com |
需要导出其它语言接口时,需要使用SWIG,找不到SWIG时则会报错。可以通过-DSWIG_EXECUTABLE:Path=/Path/to/your/swig/executable来方便CMake寻找SWIG。
SWIG使用Windows版时,请勿使用MinGW版的CMake。CMake会选择错误的SWIG的lib路径,导致出现swig.swg not found的问题。
MSYS的GCC 13.1无法使用spdlog自带的fmt库通过编译
在Visual Studio Code中,可以通过编辑工作区内settings.json中的"cmake.configureArgs"来设置这些CMake变量。
对本项目CMake目标AutoStarRailQt5Gui的编译产物,使用AGPL 3授权,许可文件为LICENSE.AGPL;对本项目的其它部分,使用LGPL 3授权,许可文件为LICENSE.LGPL。